/* ===========================
   RESET & BASE
=========================== */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body {
  font-family:'Noto Sans JP', sans-serif;
  background:#fff;
  color:#1a1a1a;
  overflow-x:hidden;
  padding-bottom:80px; /* for fixed CTA bar */
}

/* ===========================
   CSS VARIABLES
=========================== */
:root {
  --pink: #E8336D;
  --pink-light: #FF5C8D;
  --pink-dark: #C0184F;
  --green: #1A7A4A;
  --green-light: #22A05A;
  --green-dark: #0F5C35;
  --black: #0F0F0F;
  --dark: #1C1C1C;
  --gray-bg: #F5F5F5;
  --gray-line: #E0E0E0;
  --gold: #F5B742;
  --white: #FFFFFF;
  --text: #1a1a1a;
  --text-muted: #666;
}

/* ===========================
   UTILITY
=========================== */
.section-inner { max-width:800px; margin:0 auto; padding:0 20px; }
.section-inner--wide { max-width:1000px; margin:0 auto; padding:0 20px; }

/* ===========================
   HEADER
=========================== */
header {
  position:fixed;
  top:0; left:0; right:0;
  z-index:200;
  background:var(--black);
  padding:12px 20px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  border-bottom:2px solid var(--green);
}
.header-logo {
  font-family:'Oswald', sans-serif;
  font-size:1.4rem;
  font-weight:700;
  color:#fff;
  letter-spacing:.1em;
  text-decoration:none;
}
.header-logo em { color:var(--green-light); font-style:normal; }
.header-cta {
  background:var(--pink);
  color:#fff;
  border:none;
  padding:9px 20px;
  border-radius:4px;
  font-family:'Noto Sans JP', sans-serif;
  font-size:.8rem;
  font-weight:700;
  cursor:pointer;
  text-decoration:none;
  transition:background .2s;
}
.header-cta:hover { background:var(--pink-dark); }

/* ===========================
   HERO / FV
=========================== */
.hero {
  margin-top:50px;
  background:var(--black);
  padding:0;
  position:relative;
  overflow:hidden;
}

/* FV キャッチコピー帯 */
.hero-eyebrow-bar {
  background:var(--green);
  text-align:center;
  padding:10px 20px;
  font-size:.82rem;
  font-weight:700;
  color:#fff;
  letter-spacing:.06em;
}

.hero-main {
  padding:48px 20px 0;
  text-align:center;
  position:relative;
}

.hero-catch {
  font-size:clamp(2rem,7vw,3.2rem);
  font-weight:900;
  color:#fff;
  line-height:1.3;
  margin-bottom:8px;
}
.hero-catch em {
  color:var(--green-light);
  font-style:normal;
  display:block;
}

.hero-sub-copy {
  font-size:.9rem;
  color:rgba(255,255,255,.65);
  margin-bottom:32px;
  line-height:1.8;
}

/* FV 画像スクロール */
.fv-img-scroll {
  display: flex;
  overflow-x: auto;
  gap: 12px;
  padding: 16px 20px;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
}

.fv-img-scroll::-webkit-scrollbar {
  display: none; /* スクロールバーを非表示 */
}

.fv-img-scroll img {
  flex-shrink: 0;
  width: 80vw;      /* 画面幅の80%で1枚見切れて「続きがある」感を出す */
  max-width: 360px;
  height: 220px;
  object-fit: cover;
  border-radius: 12px;
  scroll-snap-align: start;
}

/* 価格バナー */
.price-banner {
  background:linear-gradient(135deg, #fff 0%, #f5fcf8 100%);
  border:3px solid var(--green);
  border-radius:12px;
  padding:20px 24px;
  margin:0 auto 32px;
  max-width:400px;
  position:relative;
}
.price-banner::before {
  content:'マシン使い放題プラン';
  position:absolute;
  top:-14px; left:50%; transform:translateX(-50%);
  background:var(--green);
  color:#fff;
  font-size:.72rem;
  font-weight:700;
  padding:4px 16px;
  border-radius:20px;
  white-space:nowrap;
  letter-spacing:.06em;
}
.price-main {
  font-family:'Oswald', sans-serif;
  font-size:3.8rem;
  font-weight:700;
  color:var(--green-dark);
  line-height:1;
}
.price-main span { font-size:1.2rem; color:#333; }
.price-note { font-size:.72rem; color:#888; margin-top:6px; }

/* 3バッジ */
.hero-badges {
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  gap:10px;
  margin-bottom:32px;
  padding:0 10px;
}
.hero-badge {
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.2);
  border-radius:6px;
  padding:10px 14px;
  text-align:center;
  flex:1; min-width:140px; max-width:200px;
}
.hero-badge .b-icon { font-size:1.5rem; display:block; margin-bottom:4px; }
.hero-badge .b-text { font-size:.78rem; color:rgba(255,255,255,.8); font-weight:700; line-height:1.4; }
.hero-badge strong { color:var(--gold); font-size:.95rem; display:block; }
.hero-badge .b-smalltext { font-size:.50rem; color:rgba(255,255,255,.8); font-weight:700; line-height:1.4; }

/* 信頼性 3点 */
.hero-trust {
  background:rgba(255,255,255,.06);
  border-top:1px solid rgba(255,255,255,.12);
  padding:20px;
  margin-top:0;
  display:grid;
  grid-template-columns:repeat(3,1fr);
  text-align:center;
}
.trust-item { padding:10px 6px; display:flex; flex-direction:column; align-items:center; justify-content:center; }
.trust-item .t-num {
  font-family:'Oswald', sans-serif;
  font-size:1.6rem;
  font-weight:700;
  color:#ffffff;
  line-height:1.1;
  display:block;
  white-space:nowrap;
}
.trust-item .t-label { font-size:.65rem; color:rgba(255,255,255,.65); margin-top:5px; display:block; line-height:1.4; text-align:center; }

/* CTA buttons */
.hero-cta-wrap {
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:12px;
  padding:28px 20px 36px;
}
.btn-pink {
  display:block;
  width:100%; max-width:380px;
  background:var(--pink);
  color:#fff;
  text-align:center;
  padding:18px 20px;
  border-radius:6px;
  font-weight:900;
  font-size:1rem;
  text-decoration:none;
  border:none;
  cursor:pointer;
  position:relative;
  box-shadow:0 6px 20px rgba(232,51,109,.4);
  transition:background .2s, transform .15s;
}
.btn-pink:hover { background:var(--pink-dark); transform:translateY(-2px); }
.btn-pink::after {
  content:'▶';
  position:absolute;
  right:18px;
  top:50%; transform:translateY(-50%);
  font-size:.8rem;
}
.btn-outline {
  display:block;
  width:100%; max-width:380px;
  background:transparent;
  color:#fff;
  text-align:center;
  padding:15px 20px;
  border-radius:6px;
  font-weight:700;
  font-size:.9rem;
  text-decoration:none;
  border:2px solid rgba(255,255,255,.3);
  transition:border-color .2s;
}
.btn-outline:hover { border-color:#fff; }

/* ===========================
   SECTION COMMON
=========================== */
section { padding:60px 0; }

.sec-title-wrap { text-align:center; margin-bottom:36px; padding:0 20px; }
.sec-eyebrow {
  display:inline-block;
  background:var(--green);
  color:#fff;
  font-size:.7rem;
  font-weight:700;
  padding:4px 14px;
  border-radius:3px;
  letter-spacing:.1em;
  margin-bottom:10px;
}
.sec-title {
  font-size:clamp(1.4rem,4vw,2rem);
  font-weight:900;
  line-height:1.4;
}
.sec-title span { color:var(--green); }
.sec-desc {
  font-size:.88rem;
  color:var(--text-muted);
  line-height:1.9;
  margin-top:12px;
}

/* Skew divider */
.skew-top {
  width:100%; height:40px;
  background:inherit;
  position:relative; overflow:hidden;
}
.skew-top::before {
  content:'';
  position:absolute;
  top:0; left:-5%; right:-5%;
  height:100%;
  background:inherit;
  transform:skewY(-2deg);
  transform-origin:top left;
}

/* ===========================
   PAIN POINTS – 横スクロール
=========================== */
.pain-section { background:var(--gray-bg); }

.pain-scroll-wrap { position:relative; }
.pain-scroll {
  display:flex;
  gap:16px;
  overflow-x:auto;
  scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch;
  padding:4px 20px 20px;
  cursor:grab;
}
.pain-scroll::-webkit-scrollbar { height:3px; }
.pain-scroll::-webkit-scrollbar-track { background:#ddd; }
.pain-scroll::-webkit-scrollbar-thumb { background:var(--green); border-radius:2px; }
.pain-scroll:active { cursor:grabbing; }

.pain-card {
  flex:0 0 260px;
  scroll-snap-align:start;
  background:#fff;
  border-radius:8px;
  padding:24px 20px;
  border-top:4px solid var(--green);
  box-shadow:0 2px 12px rgba(0,0,0,.06);
  user-select:none;
}
.pain-card .p-icon { font-size:2rem; margin-bottom:12px; display:block; }
.pain-card p { font-size:.85rem; line-height:1.8; color:#333; font-weight:500; }

.scroll-indicator {
  text-align:right;
  padding:0 20px;
  font-size:.72rem;
  color:#aaa;
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:4px;
  margin-top:4px;
}
.scroll-indicator .arrow { display:inline-block; animation:arrowBounce 1.2s ease-in-out infinite; }

/* ===========================
   RESOLVE BAND
=========================== */
.resolve-band {
  background:var(--green-dark);
  padding:40px 20px;
  text-align:center;
}
.resolve-band h2 {
  font-size:clamp(1.2rem,4vw,1.8rem);
  font-weight:900;
  color:#fff;
  line-height:1.5;
  margin-bottom:12px;
}
.resolve-band p {
  font-size:.85rem;
  color:rgba(255,255,255,.85);
  line-height:1.9;
}

/* ===========================
   REASONS
=========================== */
.reasons-section { background:#fff; }

.reason-list { padding:0 20px; display:flex; flex-direction:column; gap:20px; }
.reason-item {
  display:flex;
  gap:16px;
  background:var(--gray-bg);
  border-radius:8px;
  padding:24px 20px;
  align-items:flex-start;
  position:relative;
  overflow:hidden;
}
.reason-item::before {
  content:'';
  position:absolute;
  left:0; top:0; bottom:0;
  width:4px;
  background:var(--green);
}
.reason-num-box {
  background:var(--green);
  color:#fff;
  font-family:'Oswald', sans-serif;
  font-size:1.4rem;
  font-weight:700;
  width:44px; height:44px;
  border-radius:6px;
  display:flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0;
}
.reason-content h3 { font-size:.95rem; font-weight:900; margin-bottom:6px; color:var(--dark); }
.reason-content p { font-size:.82rem; color:#555; line-height:1.8; }

/* ===========================
   MEDALS / STATS
=========================== */
.medals-section { background:var(--dark); padding:48px 0; }
.medals-grid {
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:16px;
  padding:0 20px;
  max-width:600px;
  margin:0 auto;
}
.medal-item {
  background:rgba(255,255,255,.05);
  border:2px solid var(--green);
  border-radius:12px;
  padding:24px 16px;
  text-align:center;
}
.medal-num {
  font-family:'Oswald', sans-serif;
  font-size:2.4rem;
  font-weight:700;
  color:#ffffff;
  line-height:1;
  display:block;
}
.medal-label { font-size:.72rem; color:rgba(255,255,255,.75); margin-top:6px; display:block; line-height:1.5; }

/* ===========================
   VALUE PROPS
=========================== */
.value-section { background:var(--gray-bg); }

.value-grid {
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:14px;
  padding:0 20px;
  max-width:800px;
  margin:0 auto;
}
.value-card {
  background:#fff;
  border-radius:8px;
  padding:22px 18px;
  border-bottom:3px solid var(--green);
  box-shadow:0 2px 8px rgba(0,0,0,.05);
}
.value-card .v-icon { font-size:1.8rem; margin-bottom:10px; display:block; }
.value-card h3 { font-size:.88rem; font-weight:900; color:var(--dark); margin-bottom:6px; line-height:1.4; }
.value-card p { font-size:.78rem; color:#666; line-height:1.75; }

/* ===========================
   TESTIMONIALS – 横スクロール
=========================== */
.voice-section { background:#fff; }

.voice-scroll {
  display:flex;
  gap:16px;
  overflow-x:auto;
  scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch;
  padding:4px 20px 20px;
  cursor:grab;
}
.voice-scroll::-webkit-scrollbar { height:3px; }
.voice-scroll::-webkit-scrollbar-thumb { background:var(--green); border-radius:2px; }
.voice-scroll:active { cursor:grabbing; }

.voice-card {
  flex:0 0 300px;
  scroll-snap-align:start;
  background:var(--gray-bg);
  border-radius:8px;
  padding:24px 20px;
  user-select:none;
  position:relative;
}
.voice-card::before {
  content:'"';
  font-size:5rem;
  color:var(--green);
  opacity:.15;
  position:absolute;
  top:-8px; left:12px;
  font-family:Georgia,serif;
  line-height:1;
}
.voice-meta {
  display:flex;
  align-items:center;
  gap:12px;
  margin-bottom:14px;
}
.voice-avatar {
  width:48px; height:48px;
  border-radius:50%;
  background:linear-gradient(135deg,var(--green),var(--gold));
  display:flex; align-items:center; justify-content:center;
  font-size:1.3rem;
  flex-shrink:0;
}
.voice-who strong { display:block; font-size:.88rem; color:var(--dark); margin-bottom:2px; }
.voice-who span { font-size:.72rem; color:#888; }
.voice-stars { color:var(--gold); font-size:.8rem; margin-bottom:10px; }
.voice-card p { font-size:.82rem; line-height:1.85; color:#444; }

/* ===========================
   TRAINING MENU – 横スクロール
=========================== */
.menu-section { background:var(--dark); }
.menu-section .sec-title { color:#fff; }
.menu-section .sec-eyebrow { background:rgba(255,255,255,.15); color:#fff; }

.menu-scroll {
  display:flex;
  gap:14px;
  overflow-x:auto;
  scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch;
  padding:4px 20px 20px;
  cursor:grab;
}
.menu-scroll::-webkit-scrollbar { height:3px; }
.menu-scroll::-webkit-scrollbar-thumb { background:var(--green); border-radius:2px; }
.menu-scroll:active { cursor:grabbing; }

.menu-card {
  flex:0 0 220px;
  scroll-snap-align:start;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.12);
  border-radius:8px;
  padding:20px 16px;
  user-select:none;
}
.menu-card h4 {
  font-size:.82rem;
  font-weight:700;
  color:var(--green-light);
  padding-bottom:10px;
  margin-bottom:12px;
  border-bottom:1px solid rgba(255,255,255,.1);
  display:flex; align-items:center; gap:6px;
}
.menu-card ul { list-style:none; }
.menu-card li {
  font-size:.75rem;
  color:rgba(255,255,255,.7);
  padding:4px 0;
  border-bottom:1px solid rgba(255,255,255,.05);
  line-height:1.5;
}
.menu-card li:last-child { border-bottom:none; }

.menu-extra {
  flex:0 0 220px;
  scroll-snap-align:start;
  background:var(--green-dark);
  border-radius:8px;
  padding:20px 16px;
  user-select:none;
}
.menu-extra h4 { font-size:.82rem; font-weight:700; color:#fff; padding-bottom:10px; margin-bottom:12px; border-bottom:1px solid rgba(255,255,255,.3); }
.menu-extra li { font-size:.75rem; color:rgba(255,255,255,.85); padding:4px 0; list-style:none; }

/* ===========================
   INTERIOR – 横スクロール
=========================== */
.interior-section { background:var(--gray-bg); }

.interior-scroll {
  display:flex;
  gap:14px;
  overflow-x:auto;
  scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch;
  padding:4px 20px 20px;
  cursor:grab;
}
.interior-scroll::-webkit-scrollbar { height:3px; }
.interior-scroll::-webkit-scrollbar-thumb { background:var(--green); border-radius:2px; }
.interior-scroll:active { cursor:grabbing; }

.interior-card {
  flex:0 0 240px;
  scroll-snap-align:start;
  border-radius:8px;
  overflow:hidden;
  user-select:none;
  background:var(--dark);
}
.interior-card-img {
  height:160px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:3rem;
  position:relative;
  overflow:hidden;
  flex-direction:column;
  gap:8px;
  text-align:center;
}
/* gradient overlay simulation */
.interior-card-img::after {
  content:'';
  position:absolute;
  inset:0;
  background:linear-gradient(135deg, rgba(232,51,109,.15), rgba(0,0,0,.3));
}
.interior-card-label {
  padding:10px 14px;
  font-size:.78rem;
  font-weight:700;
  color:#fff;
  background:rgba(255,255,255,.05);
}

/* ===========================
   トレーニング室紹介
=========================== */

.interior-card-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* ===========================
   PLANS
=========================== */
.plans-section { background:#fff; }

.plans-stack {
  display:flex;
  flex-direction:column;
  gap:20px;
  padding:0 20px;
  max-width:600px;
  margin:0 auto;
}

.plan-card {
  border-radius:8px;
  overflow:hidden;
  box-shadow:0 4px 16px rgba(0,0,0,.08);
  border:2px solid var(--gray-line);
  transition:border-color .2s, transform .2s;
  display:flex;
  flex-direction:column;
}
.plan-card:hover { border-color:var(--green); transform:translateY(-3px); }
.plan-card.featured {
  border-color:var(--green);
  box-shadow:0 8px 30px rgba(26,122,74,.2);
}

.plan-tag {
  background:var(--green);
  color:#fff;
  font-size:.7rem;
  font-weight:700;
  text-align:center;
  padding:6px;
  letter-spacing:.08em;
}
.plan-card:not(.featured) .plan-tag { background:var(--dark); }

.plan-head {
  background:var(--dark);
  padding:22px 20px;
  text-align:center;
}
.plan-card.featured .plan-head { background:linear-gradient(135deg,#071f12,#0f3d22); }

.plan-name { font-size:.82rem; font-weight:700; color:rgba(255,255,255,.65); margin-bottom:2px; letter-spacing:.05em; }
.plan-time { font-size:.72rem; color:rgba(255,255,255,.45); margin-bottom:14px; }
.plan-price-num {
  font-family:'Oswald', sans-serif;
  font-size:3rem;
  font-weight:700;
  color:#ffffff !important;
  line-height:1;
}
.plan-price-num span { font-size:1rem; color:rgba(255,255,255,.6); }

.plan-body { padding:20px; background:#fff; display:flex; flex-direction:column; flex:1; }
.plan-feat {
  display:flex;
  align-items:center;
  gap:10px;
  padding:9px 0;
  font-size:.85rem;
  color:#333;
  border-bottom:1px solid #f0f0f0;
}
.plan-feat:last-of-type { border-bottom:none; }
.plan-feat .chk { color:var(--green); font-size:1rem; flex-shrink:0; font-weight:700; }
.plan-note { font-size:.7rem; color:#aaa; margin-top:12px; margin-bottom:16px; line-height:1.7; }
.plan-btn {
  display:block;
  text-align:center;
  background:var(--pink);
  color:#fff;
  padding:14px;
  border-radius:6px;
  font-weight:900;
  font-size:.9rem;
  text-decoration:none;
  margin-top:auto;
  padding-top:14px;
  transition:background .2s;
}
.plan-btn:hover { background:var(--pink-dark); }
.plan-card:not(.featured) .plan-btn { background:var(--dark); }
.plan-card:not(.featured) .plan-btn:hover { background:#333; }

/* ===========================
   CTA BAND
=========================== */
.cta-band {
  background:var(--green-dark);
  padding:48px 20px;
  text-align:center;
}
.cta-band h2 {
  font-size:clamp(1.2rem,4vw,1.7rem);
  font-weight:900;
  color:#fff;
  margin-bottom:10px;
  line-height:1.5;
}
.cta-band p { font-size:.85rem; color:rgba(255,255,255,.85); margin-bottom:28px; line-height:1.8; }
.btn-white {
  display:inline-block;
  background:#fff;
  color:var(--pink);
  padding:16px 48px;
  border-radius:6px;
  font-weight:900;
  font-size:1rem;
  text-decoration:none;
  box-shadow:0 4px 20px rgba(0,0,0,.15);
  transition:transform .15s, box-shadow .15s;
}
.btn-white:hover { transform:translateY(-2px); box-shadow:0 8px 28px rgba(0,0,0,.2); }
.btn-white br {
  display: none;
}
@media (max-width: 400px) {
  .btn-white br {
    display: block;
  }
}

/* ===========================
   FAQ
=========================== */
.faq-section { background:var(--gray-bg); }

.faq-list { padding:0 20px; max-width:700px; margin:0 auto; display:flex; flex-direction:column; gap:12px; }

.faq-item { background:#fff; border-radius:8px; overflow:hidden; box-shadow:0 2px 8px rgba(0,0,0,.05); }
.faq-q-btn {
  width:100%;
  background:#fff;
  border:none;
  padding:18px 20px;
  display:flex;
  align-items:flex-start;
  gap:12px;
  cursor:pointer;
  text-align:left;
  font-family:'Noto Sans JP', sans-serif;
  transition:background .15s;
}
.faq-q-btn:hover { background:#fafafa; }
.faq-q-badge {
  background:var(--green);
  color:#fff;
  font-size:.72rem;
  font-weight:700;
  padding:3px 10px;
  border-radius:3px;
  flex-shrink:0;
  margin-top:2px;
}
.faq-q-text { font-size:.88rem; font-weight:700; color:var(--dark); line-height:1.5; flex:1; }
.faq-chevron { font-size:.9rem; color:var(--green); flex-shrink:0; transition:transform .3s; margin-top:2px; }
.faq-item.open .faq-chevron { transform:rotate(180deg); }
.faq-a-wrap {
  overflow:hidden;
  max-height:0;
  transition:max-height .4s ease;
}
.faq-item.open .faq-a-wrap { max-height:500px; }
.faq-a-inner {
  padding:0 20px 18px 20px;
  display:flex;
  gap:12px;
  align-items:flex-start;
}
.faq-a-badge {
  background:var(--dark);
  color:#fff;
  font-size:.72rem;
  font-weight:700;
  padding:3px 10px;
  border-radius:3px;
  flex-shrink:0;
  margin-top:2px;
}
.faq-a-text { font-size:.82rem; color:#555; line-height:1.85; }

/* ===========================
   FORM
=========================== */
.form-section { background:var(--dark); }
.form-section .sec-title { color:#fff; }
.form-section .sec-eyebrow { background:rgba(255,255,255,.15); color:#fff; }

.form-box {
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.12);
  border-radius:10px;
  padding:32px 24px;
  max-width:560px;
  margin:0 auto;
  width:100%;
  box-sizing:border-box;
}
.form-row { margin-bottom:18px; }
.form-row label { display:block; font-size:.78rem; font-weight:700; color:rgba(255,255,255,.65); margin-bottom:8px; }
.form-row input, .form-row textarea {
  width:100%;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.18);
  border-radius:6px;
  padding:12px 14px;
  color:#fff;
  font-family:'Noto Sans JP', sans-serif;
  font-size:.88rem;
  outline:none;
  transition:border-color .2s;
}
.form-row input::placeholder, .form-row textarea::placeholder { color:rgba(255,255,255,.3); }
.form-row input:focus, .form-row textarea:focus { border-color:var(--green); }
.form-row textarea { min-height:110px; resize:vertical; }
.form-submit {
  width:100%;
  background:var(--pink);
  color:#fff;
  border:none;
  padding:16px;
  border-radius:6px;
  font-family:'Noto Sans JP', sans-serif;
  font-weight:900;
  font-size:1rem;
  cursor:pointer;
  margin-top:8px;
  transition:background .2s, transform .15s;
}
.form-submit:hover { background:var(--pink-dark); transform:translateY(-2px); }

/* TEL */
.tel-box {
  text-align:center;
  margin-top:24px;
  padding-top:24px;
  border-top:1px solid rgba(255,255,255,.1);
}
.tel-box p { font-size:.75rem; color:rgba(255,255,255,.5); margin-bottom:6px; }
.tel-num {
  font-family:'Oswald', sans-serif;
  font-size:1.8rem;
  font-weight:700;
  color:#fff;
  text-decoration:none;
  letter-spacing:.05em;
}
.tel-num:hover { color:var(--green-light); }
.tel-hours { font-size:.72rem; color:rgba(255,255,255,.45); margin-top:4px; }

/* ===========================
   SNS
=========================== */
.sns-section { background:var(--black); padding:40px 20px; text-align:center; }
.sns-section p { font-size:.82rem; color:rgba(255,255,255,.55); margin-bottom:20px; }
.sns-list {
  display:flex;
  justify-content:center;
  gap:20px;
}
.sns-link {
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:6px;
  text-decoration:none;
  color:rgba(255,255,255,.65);
  font-size:.72rem;
  font-weight:700;
  transition:color .2s;
}
.sns-link:hover { color:var(--green-light); }
.sns-icon {
  width:50px; height:50px;
  border-radius:12px;
  background:rgba(255,255,255,.08);
  display:flex; align-items:center; justify-content:center;
  font-size:1.6rem;
  transition:background .2s;
}
.sns-link:hover .sns-icon { background:var(--green); }

/* ===========================
   FOOTER
=========================== */
footer {
  background:#080808;
  padding:32px 20px;
  text-align:center;
}
.footer-logo {
  font-family:'Oswald', sans-serif;
  font-size:1.4rem;
  font-weight:700;
  color:#fff;
  letter-spacing:.1em;
  margin-bottom:10px;
}
.footer-logo em { color:var(--green-light); font-style:normal; }
footer nav {
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  gap:12px 20px;
  margin-bottom:16px;
}
footer nav a { font-size:.72rem; color:rgba(255,255,255,.4); text-decoration:none; }
footer nav a:hover { color:rgba(255,255,255,.7); }
footer small { font-size:.68rem; color:rgba(255,255,255,.25); }

/* ===========================
   FIXED BOTTOM CTA BAR
=========================== */
.fixed-cta-bar {
  position:fixed;
  bottom:0; left:0; right:0;
  z-index:300;
  display:flex;
  height:64px;
}
.fixed-cta-web {
  flex:1;
  background:var(--pink);
  color:#fff;
  text-decoration:none;
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight:900;
  font-size:.88rem;
  gap:6px;
  transition:background .2s;
}
.fixed-cta-web:hover { background:var(--pink-dark); }
.fixed-cta-tel {
  flex:1;
  background:var(--dark);
  color:#fff;
  text-decoration:none;
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight:900;
  font-size:.88rem;
  gap:6px;
  border-left:1px solid rgba(255,255,255,.1);
  transition:background .2s;
}
.fixed-cta-tel:hover { background:#333; }

/* ===========================
   ANIMATIONS
=========================== */
@keyframes arrowBounce {
  0%,100% { transform:translateX(0); }
  50% { transform:translateX(6px); }
}

/* ===========================
   SCROLL REVEAL
=========================== */
.reveal { opacity:0; transform:translateY(24px); transition:opacity .55s ease, transform .55s ease; }
.reveal.visible { opacity:1; transform:none; }

/* ===========================
   RESPONSIVE
=========================== */

/* ---- スマホ（〜599px）---- */
@media (max-width:599px) {
  header { padding:10px 14px; }
  .header-logo { font-size:1.1rem; }
  .header-cta { font-size:.72rem; padding:8px 12px; }

  .hero-main { padding:32px 16px 0; }
  .hero-catch { font-size:1.9rem; }
  .hero-sub-copy { font-size:.82rem; }
  .price-banner { padding:16px 18px; }
  .price-main { font-size:3rem; }
  .hero-badges { gap:8px; }
  .hero-badge { min-width:120px; padding:8px 10px; }
  .hero-trust { grid-template-columns:repeat(3,1fr); }
  .t-num { font-size:1.4rem; }

  section { padding:48px 0; }
  .sec-title { font-size:1.4rem; }

  .reason-item { flex-direction:column; gap:10px; }
  .reason-num-box { width:36px; height:36px; font-size:1.1rem; }

  .medals-grid { max-width:100% !important; padding:0 16px; grid-template-columns:1fr 1fr; }
  .medal-num { font-size:2rem; }

  .value-grid { grid-template-columns:1fr; padding:0 16px; }

  .pain-scroll, .voice-scroll, .menu-scroll, .interior-scroll { padding:4px 16px 16px; }
  .pain-card { flex:0 0 240px; }
  .voice-card { flex:0 0 270px; }
  .menu-card, .menu-extra { flex:0 0 200px; }
  .interior-card { flex:0 0 200px; }

  .form-box { padding:24px 16px; margin:0 auto; max-width:100%; }
  .fixed-cta-bar a { font-size:.78rem; }
}

/* ---- タブレット（600〜899px）---- */
@media (min-width:600px) and (max-width:899px) {
  .hero-catch { font-size:2.4rem; }
  .value-grid { grid-template-columns:repeat(2,1fr); }
  .form-box { margin:0 auto; }
}

/* ---- PC（900px〜）---- */
@media (min-width:900px) {
  .hero-main { padding:64px 40px 0; max-width:720px; margin:0 auto; }
  .hero-cta-wrap { flex-direction:row; justify-content:center; }
  .btn-pink, .btn-outline { width:auto; }
  section { padding:80px 0; }
  .sec-title { font-size:2rem; }
  .value-grid { grid-template-columns:repeat(2,1fr); }
  .reason-list { max-width:720px; }
  .pain-card { flex:0 0 300px; }
  .voice-card { flex:0 0 340px; }
  .menu-card, .menu-extra { flex:0 0 240px; }
  .interior-card { flex:0 0 260px; }
}

/* プランは常に横並び＋横スクロール */
.plans-stack {
  flex-direction:row !important;
  flex-wrap:nowrap !important;
  justify-content:flex-start !important;
}
.plans-stack .plan-card { flex:0 0 260px !important; max-width:260px !important; }
.plans-stack .plan-card.featured { flex:0 0 280px !important; max-width:280px !important; }

/* ===========================
   キャンペーン　レスポンシブ
=========================== */
.sp-br {
  display: none;
}

@media (max-width: 400px) {
  .sp-br {
    display: block;
  }
}

/* ===========================
   フォーム ステップUI
=========================== */
.form-steps {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  margin-bottom: 24px;
}
.form-step {
  font-size: .75rem;
  font-weight: 700;
  color: rgba(255,255,255,.35);
  padding: 5px 12px;
  border-radius: 20px;
  border: 1px solid rgba(255,255,255,.15);
  transition: all .2s;
}
.form-step.active {
  color: #fff;
  background: var(--green);
  border-color: var(--green);
}
.form-step.done {
  color: rgba(255,255,255,.6);
  border-color: rgba(255,255,255,.3);
}
.form-step-arrow {
  color: rgba(255,255,255,.25);
  font-size: .9rem;
}

/* 必須・任意バッジ */
.form-required {
  font-size: .68rem;
  background: var(--pink);
  color: #fff;
  padding: 1px 6px;
  border-radius: 3px;
  margin-left: 4px;
  font-weight: 700;
}
.form-optional {
  font-size: .68rem;
  background: rgba(255,255,255,.15);
  color: rgba(255,255,255,.6);
  padding: 1px 6px;
  border-radius: 3px;
  margin-left: 4px;
}

/* select */
.form-row select {
  width: 100%;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.18);
  border-radius: 6px;
  padding: 12px 14px;
  color: #fff;
  font-family: 'Noto Sans JP', sans-serif;
  font-size: .88rem;
  outline: none;
  transition: border-color .2s;
  appearance: none;
  cursor: pointer;
}
.form-row select:focus { border-color: var(--green); }
.form-row select option { background: #1a1a2e; color: #fff; }

/* 戻るボタン */
.form-back {
  width: 100%;
  background: transparent;
  border: 1px solid rgba(255,255,255,.2);
  border-radius: 6px;
  padding: 12px;
  color: rgba(255,255,255,.5);
  font-family: 'Noto Sans JP', sans-serif;
  font-size: .88rem;
  cursor: pointer;
  margin-top: 8px;
  transition: border-color .2s, color .2s;
}
.form-back:hover { border-color: rgba(255,255,255,.5); color: rgba(255,255,255,.8); }

/* ===========================
   カレンダーUI（テーブル形式）
=========================== */
.cal-guide {
  font-size: .82rem;
  color: rgba(255,255,255,.55);
  margin-bottom: 10px;
}
.cal-loading-text {
  text-align: center;
  padding: 24px;
  color: rgba(255,255,255,.4);
  font-size: .88rem;
}
.cal-load-error {
  text-align: center;
  padding: 16px;
  color: var(--pink);
  font-size: .85rem;
}

/* スケジュールリスト外枠 */
.schedule-list {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  margin-bottom: 12px;
}
.schedule-list::-webkit-scrollbar { height: 4px; }
.schedule-list::-webkit-scrollbar-thumb { background: rgba(255,255,255,.2); border-radius: 4px; }

/* テーブル本体 */
.schedule-table {
  width: 100%;
  border-collapse: collapse;
  min-width: 420px;
  font-size: .75rem;
}
.schedule-table th,
.schedule-table td {
  border: 1px solid rgba(255,255,255,.1);
  padding: 6px 4px;
  text-align: center;
  color: rgba(255,255,255,.7);
  min-width: 40px;
}
.schedule-table .dayWeek th {
  background: rgba(255,255,255,.06);
  font-weight: 700;
  font-size: .72rem;
  line-height: 1.4;
}
.schedule-table tr th:first-child {
  background: rgba(255,255,255,.04);
  font-size: .72rem;
  color: rgba(255,255,255,.5);
  white-space: nowrap;
}

/* スタンプセル */
.schedule-button { color: rgba(255,255,255,.25); }
.schedule-blue   { background: rgba(91,191,154,.08); }
.schedule-purple { background: rgba(155,127,232,.08); }

/* 選択可能ボタン */
.schedule-available-button {
  display: inline-block;
  cursor: pointer;
  font-weight: 700;
  padding: 2px 4px;
  border-radius: 4px;
  transition: all .15s;
}
.schedule-blue   .schedule-available-button { color: var(--green); }
.schedule-purple .schedule-available-button { color: #b39df0; }
.schedule-available-button:hover { opacity: .75; transform: scale(1.1); }
.schedule-button-clicked {
  background: var(--green) !important;
  color: #fff !important;
  border-radius: 4px;
}

/* 曜日カラー */
.sunday-color   { color: #f87171; }
.saturday-color { color: #60a5fa; }

/* 次週・前週ボタン */
.schedule-list-next,
.schedule-list-before {
  display: inline-block;
  margin: 8px 6px 0 0;
  padding: 7px 16px;
  background: rgba(255,255,255,.07);
  border: 1px solid rgba(255,255,255,.2);
  border-radius: 6px;
  color: rgba(255,255,255,.6);
  font-size: .82rem;
  cursor: pointer;
  transition: all .15s;
}
.schedule-list-next:hover,
.schedule-list-before:hover {
  border-color: var(--green);
  color: var(--green);
}

/* 選択中表示 */
.cal-selected-display {
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.15);
  border-radius: 6px;
  padding: 12px 14px;
  color: rgba(255,255,255,.4);
  font-size: .88rem;
}

/* ===========================
   確認画面
=========================== */
.form-confirm-box {
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 8px;
  padding: 16px;
  margin-bottom: 16px;
}
.confirm-row {
  display: flex;
  gap: 12px;
  padding: 10px 0;
  border-bottom: 1px solid rgba(255,255,255,.08);
  font-size: .85rem;
}
.confirm-row:last-child { border-bottom: none; }
.confirm-label {
  flex-shrink: 0;
  width: 110px;
  color: rgba(255,255,255,.5);
  font-weight: 700;
}
.confirm-value { color: #fff; word-break: break-all; }

/* 送信中・完了・エラー */
.form-sending {
  text-align: center;
  color: rgba(255,255,255,.6);
  padding: 16px;
  font-size: .9rem;
}
.form-success {
  text-align: center;
  background: rgba(91,191,154,.15);
  border: 1px solid var(--green);
  border-radius: 8px;
  padding: 16px;
  color: var(--green);
  font-weight: 700;
  font-size: .95rem;
  margin-bottom: 8px;
}
.form-error-msg {
  text-align: center;
  background: rgba(232,51,109,.1);
  border: 1px solid var(--pink);
  border-radius: 8px;
  padding: 16px;
  color: var(--pink);
  font-size: .9rem;
  margin-bottom: 8px;
}
