/* ==================================================
  Base
================================================== */
:root{
  --bgSide:#ede8e4;
  --bgCenter:#F5F0EB;
  --line:rgba(15,23,42,.10);
  --radius:0px;
  --shadow:none;
}

*{ box-sizing:border-box; }
html,body{ height:100%; }

body{
  margin:0;
  background:#fff;
  font-family: system-ui, -apple-system, "Noto Sans JP", "Hiragino Kaku Gothic ProN", sans-serif;
  overflow:hidden;
}

#s10{
  padding-bottom: 30px;
}

.w-95{
  width: 95% !important;
  margin: 0 auto;
}

.mb-24{
  margin-bottom: 24px;
}

/* ==================================================
  Layout Shell
================================================== */
.lpShell{
  height:100vh;
  display:grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap:0;
  margin:0;
  padding:0;
}

/* ==================================================
  Side Columns
================================================== */
.lpSide{
  height:100%;
}

.lpSide__inner{
  position:sticky;
  top:0;
  height:100vh;
  background:var(--bgSide);
  display:flex;
  align-items:center;
  justify-content:center;
  padding:0;
}

.sidePitch--lite img{
  display: block;
  margin: 0 auto 20px;
}

/* ==================================================
  Right Menu
================================================== */
.lpSideNav{
  display:flex;
  flex-direction:column;
  gap:8px;
}

.lpSideNav__link{
  display:block;
  text-decoration:none;
  color:#333;
  font-weight:800;
  text-align:center;
  padding:10px 0;
  background:transparent;

  opacity:.6;
  transition: opacity .2s ease;
}

.lpSideNav__link:hover{
  opacity:.8;
}

.lpSideNav__link.is-active{
  opacity:1;
}

/* ==================================================
  CTA Button
================================================== */
@keyframes btnShine {
  0%   { left: -80%; }
  40%  { left: 120%; }
  100% { left: 120%; }
}

.sideCta,
.sideCta_g {
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:100vmax;
  border:0.125rem solid #3D4F58;
  box-shadow:0.1875rem 0.1875rem 0 0 #3D4F58;
  background:#F4845F;
  color:#fff;
  font-weight:900;
  letter-spacing:0.05em;
  line-height:1.4;
  text-decoration:none;
  text-align:center;
  width:400px;
  max-width: calc(100vw - 48px);
  padding:18px 22px;
  position: relative;
  overflow: hidden;
  transition: color .2s ease-out, background-color .2s ease-out, transform .05s ease-out, box-shadow .05s ease-out;
}

.sideCta::before,
.sideCta_g::before {
  content: '';
  position: absolute;
  top: 0;
  left: -80%;
  width: 50%;
  height: 100%;
  background: linear-gradient(
    120deg,
    transparent 0%,
    rgba(255,255,255,0.55) 50%,
    transparent 100%
  );
  transform: skewX(-20deg);
  animation: btnShine 3s ease-in-out infinite;
  pointer-events: none;
}

.sideCta:hover,
.sideCta_g:hover {
  background:#fff;
  color:#3D4F58;
}
.sideCta:active,
.sideCta_g:active {
  transform: translate(0.1875rem, 0.1875rem);
  box-shadow:0 0 0 0 #3D4F58;
}

.voice-before{
  padding-bottom: 30px;
}
/* ==================================================
  Center Column
================================================== */
.lpMain{
  height:100%;
  overflow-y:auto;
  overscroll-behavior:contain;
  scroll-behavior:smooth;
  background:var(--bgCenter);
}
.lpMain::-webkit-scrollbar{ display:none; }
.lpMain{ scrollbar-width:none; -ms-overflow-style:none; }

/* ==================================================
  Sections / Images
================================================== */
.imgSection{ padding:0; }
.fv{ position:relative; }

.stack{
  position:relative;
  width:100%;
  border-radius:0;
  background:transparent;
  border:none;
  box-shadow:none;
}

.stack img{
  display:block;
  width:100%;
  height:auto;
}

/* ==================================================
  #s01 CTA（FV）
================================================== */
#s01 .stack{
  aspect-ratio: 9 / 16;
  overflow:hidden;
}

#s01 .stack img{
  width:100%;
  height:100%;
  object-fit:cover;
}

#s01 .fvCta{
  position:absolute;
  left:50%;
  top:89%;
  transform:translate(-50%, -50%);
  z-index:10;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:10px;
  pointer-events:auto;
}

#s01 .fvCta__note{
  margin:0;
  color:#3D4F58;
  font-weight:700;
  font-size:14px;
  letter-spacing:.06em;
  line-height:1.4;
}

#s01 .fvCta__btns{
  display:flex;
  flex-direction:column;
  gap:12px;
}

/* ==================================================
  #s02 CTA（FV）
================================================== */
#s02{
  padding-top: 20px;
}

/* ==================================================
  s03 Worries Section
================================================== */
.worriesSection {
  padding: 30px 24px 50px;
}

.worriesInner {
  max-width: 560px;
  margin: 0 auto;
}

.worriesTitle {
  font-size: clamp(20px, 4vw, 26px);
  font-weight: 400;
  color: #3D4F58;
  line-height: 1.6;
  letter-spacing: .05em;
  text-align: center;
}

.worriesList {
  list-style: none;
  margin: 0 auto;
  padding: 28px 24px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  text-align: left;
  background: #fff;
  border-radius: 16px;
  max-width: 460px;
}

.worriesList li {
  display: flex;
  align-items: center;
  gap: 12px;
  font-size: clamp(15px, 3vw, 18px);
  color: #3D4F58;
  line-height: 1.5;
}

.worriesList li::before {
  content: '';
  flex-shrink: 0;
  width: 26px;
  height: 26px;
  border-radius: 50%;
  background: #A8D8EA;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23fff' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");
  background-size: 14px;
  background-repeat: no-repeat;
  background-position: center;
}

/* SP調整 */
@media (max-width: 600px) {
  .worriesTitle {
    font-size: 18px;
  }
  .worriesList li {
    font-size: 15px;
  }
}

/* ==================================================
  s02 Easy Step ズームイン
================================================== */
#s02 .stack {
  opacity: 0;
  transform: scale(0.9);
  transition: opacity 0.7s ease, transform 0.7s ease;
}

#s02 .stack.is-visible {
  opacity: 1;
  transform: scale(1);
}

/* ==================================================
  #s04
================================================== */
#s04 .point{
  width: 90%;
  margin: 18px auto 0;
}

#s04 .security-block{
  display: block;
  margin: 0 auto 40px;
  width: 95%;
}

/* ==================================================
  #s05
================================================== */

#s05 .busy_title,
#s05 .busy_subtitle,
#s05 .busy_contents{
  margin: 20px auto 0;
}

#s05 .busy_title{
  width: 90%;
  padding-top: 50px;
}

#s05 .busy_subtitle{
  width: 80%;
}

#s05 .busy_contents{
  padding-top: 120px;
}

/* ==================================================
  Point フェードイン
================================================== */
#s04 .point {
  opacity: 0;
  transform: translateY(32px);
  transition: opacity 0.65s ease, transform 0.65s ease;
}

#s04 .point.is-visible {
  opacity: 1;
  transform: translateY(0);
}

#s04 .point:nth-child(2) { transition-delay: 0.1s; }
#s04 .point:nth-child(3) { transition-delay: 0.25s; }
#s04 .point:nth-child(4) { transition-delay: 0.4s; }

/* ==================================================
  #s05 CTA（FV）
================================================== */
#s13 {
  padding-top: 40px;
  padding-bottom: 140px;
  background-color: #fff;
}

/* ==================================================
  section--cta（被せCTA共通）
================================================== */
.section--cta{ position:relative; }

.section--cta .sectionCta{
  position:absolute;
  left:50%;
  bottom:2%;
  transform:translateX(-50%);
  z-index:5;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:6px;
  pointer-events:auto;
  padding:0;
}

.sectionCta__note{
  margin:0;
  font-size:14px;
  font-weight:700;
  letter-spacing:.06em;
  color:#3D4F58;
  line-height:1.4;
}

.sectionCta__bottom{
  margin:0;
  font-size:18px;
  font-weight:500;
  color:#fff;
  text-align: center;
}

/* ==================================================
  ミドルCTA
================================================== */
.middle-section{
  display: block;
  margin: 0 auto 50px;
}

.middle-section .sectionCta{
  display:block;
  pointer-events:auto;
  padding:0;
  text-align: center;
}

/* ==================================================
  左側
================================================== */
.sidePitch{
  color:#4e3636;
}

.sidePitch__cta{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:10px;
}

.sidePitch__micro{
  margin:0;
  font-size:16px;
  font-weight:700;
  opacity:.9;
}

.lpSide--left .fvCta__note{
  color:#4e3636;
  font-weight:900;
  margin:0;
}

/* ==================================================
  LP 最後の CTA
================================================== */
.lpLastCta {
  background: var(--bgCenter);
  padding: 96px 24px;
}
.lpLastCta__inner {
  max-width: 520px;
  margin: 0 auto;
  display: block;
  flex-direction: column;
}
.lpLastCta__noteImg {
  display: block;
  width: 100%;
  max-width: 360px;
  height: auto;
}
.lpLastCta__micro{
  margin:0;
  font-size: 11px;
  text-align: center;
}

/* ==================================================
  Footer
================================================== */
.siteFooter {
  background: #A8D8EA;
  color: rgba(255,255,255,.9);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 40px 16px;
}
.siteFooter small {
  font-size: 13px;
  letter-spacing: .08em;
  line-height: 1.6;
  text-align: center;
  opacity: .9;
}

/* ==================================================
  Responsive（順番が超重要：大きい→小さい）
================================================== */

/* Tablet（左右なし：2カラム：中央+右メニュー） */
@media (max-width: 1100px){
  body{
    overflow:hidden;
    background:var(--bgSide);
  }

  .lpShell{
    grid-template-columns: 1fr 1fr; /* 左＝中央スクロール / 右＝メニュー */
  }

  .lpShell > .lpSide:first-child{
    display:none; /* 左CTAを消す */
  }

  .lpMain{
    grid-column: 1;
  }

  .lpShell > .lpSide:last-child{
    display:block;
    grid-column: 2;
  }

  .lpSideNav{
    transform:none;
  }
}

/* SP（1カラム） */
@media (max-width:1024px){
  body{
    overflow-x:hidden;
    overflow-y:auto;
    background:var(--bgCenter);
  }

  .lpShell{
    grid-template-columns:1fr;
    overflow-x:hidden;
  }

  .lpSide{
    display:none !important;
  }

  .lpMain{
    height:auto;
    overflow-x:hidden;
    overflow-y:visible;
    padding:0;
    grid-column: 1 / -1;
    max-width:100vw;
  }

  .siteFooter{
    padding: 32px 16px;
  }
  .siteFooter small{
    font-size: 12.5px;
  }
}

@media (max-width:600px){
  .sideCta_g{
    width: 300px;
    font-size: 14px;
  }
  .siteFooter{
    padding: 28px 16px;
  }
  .siteFooter small{
    font-size: 12px;
    letter-spacing: .06em;
  }
}

.stack{
 position:relative;
}

.stack .sectionCta{
  position:absolute;
  left:50%;
  top:var(--ctaTop, 95%);
  transform:translate(-50%, -50%);
  z-index:10;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:12px;
  pointer-events:auto;
}

/* 例：セクションごとに位置だけ変える */
#s07{ --ctaTop: 90%; }
#s09{ --ctaTop: 90%; }
#s12{ --ctaTop: 82%; }

.fvCta__note{
  margin: 0;
}

/* ==================================================
  FAQ アコーディオン
================================================== */
.faqSection{
  background: #fff;
  padding: 60px 0 70px;
}

.faqInner{
  max-width: 700px;
  margin: 0 auto;
  padding: 0 24px;
}

.faqTitle{
  text-align: center;
  font-size: 24px;
  font-weight: 900;
  color: #3D4F58;
  margin: 0 0 40px;
  letter-spacing: .06em;
}

.faqList{
  margin: 0;
  padding: 0;
}

.faqItem{
  border-bottom: 2px solid var(--bgSide);
}
.faqItem:first-child{
  border-top: 2px solid var(--bgSide);
}

.faqQ{
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 22px 4px;
  cursor: pointer;
  user-select: none;
  list-style: none;
}

.faqQ__label{
  flex-shrink: 0;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: #A8D8EA;
  color: #fff;
  font-weight: 900;
  font-size: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.faqQ__text{
  flex: 1;
  font-size: 15px;
  font-weight: 800;
  color: #3D4F58;
  line-height: 1.5;
}

.faqQ__icon{
  flex-shrink: 0;
  width: 20px;
  height: 20px;
  position: relative;
  transition: transform .3s ease;
}
.faqQ__icon::before,
.faqQ__icon::after{
  content: '';
  position: absolute;
  background: #132e89;
  border-radius: 2px;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
.faqQ__icon::before{ width: 2px; height: 14px; }
.faqQ__icon::after{  width: 14px; height: 2px; }

/* 開いた時：縦線を回転して×→＋の逆 */
.faqItem.is-open .faqQ__icon::before{
  transform: translate(-50%, -50%) rotate(90deg);
  opacity: 0;
}

.faqA{
  display: grid;
  grid-template-rows: 0fr;
  transition: grid-template-rows .3s ease;
}
.faqItem.is-open .faqA{
  grid-template-rows: 1fr;
}

.faqA__inner{
  overflow: hidden;
  font-size: 14px;
  line-height: 1.8;
  color: #444;
  padding: 0 4px 0 40px;
}
.faqItem.is-open .faqA__inner{
  padding-bottom: 22px;
}

/* ==================================================
  Worries フェードイン
================================================== */
.worriesTitle,
.worriesList li {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 0.6s ease, transform 0.6s ease;
}

.worriesTitle.is-visible,
.worriesList li.is-visible {
  opacity: 1;
  transform: translateY(0);
}

/* リストは1つずつ時間差で */
.worriesList li:nth-child(1) { transition-delay: 0.05s; }
.worriesList li:nth-child(2) { transition-delay: 0.15s; }
.worriesList li:nth-child(3) { transition-delay: 0.25s; }
.worriesList li:nth-child(4) { transition-delay: 0.35s; }
.worriesList li:nth-child(5) { transition-delay: 0.45s; }
.worriesList li:nth-child(6) { transition-delay: 0.55s; }

/* ==================================================
  Busy フェードイン
================================================== */
#s05 .busy {
  opacity: 0;
  transform: translateY(32px);
  transition: opacity 0.65s ease, transform 0.65s ease;
}

#s05 .busy.is-visible {
  opacity: 1;
  transform: translateY(0);
}
