@charset "UTF-8";
/* CSS Document */

html, body{
	margin:0; padding:0; 
}

/* Webフォント */
@font-face {
  font-family: 'MazdaType-Regular';
  src: url("../fonts/mazda/0050_MazdaType-Regular.woff") format('woff');
  font-weight: normal;
}
@font-face {
  font-family: 'MazdaType-Medium';
  src: url('../fonts/mazda/0030_MazdaType-Medium.woff') format('woff');
  font-weight: normal;
}
@font-face {
  font-family: 'MazdaType-Bold';
  src: url('../fonts/mazda/0010_MazdaType-Bold.woff') format('woff');
  font-weight: bold;
}

.LP_wrap{
  overflow: hidden;
  font-family: 'MazdaType-Regular', "Helvetica Neue",Arial,"Hiragino Kaku Gothic ProN","Hiragino Sans",Meiryo,sans-serif;
  opacity: 0;
  animation: fadeIn 1s ease-in-out forwards;
}
@keyframes fadeIn { from{opacity:0;} to{opacity:1;} }

.LP_wrap div,
.LP_wrap img,
.LP_wrap section,
.LP_wrap h2,
.LP_wrap h3,
.LP_wrap h4,
.LP_wrap p,
.LP_wrap figure,
.LP_wrap ul,
.LP_wrap li { margin:0; padding:0; }

.LP_wrap img{
  width: 100%;
  height: auto;
  margin: auto;
  vertical-align: bottom;
  display: block;
}


/* =======================================
  共通スタイル
======================================= */

.LP_wrap .margin-T10 { margin-top: 10%; }
.LP_wrap .margin-T20 { margin-top: 20%; }
.LP_wrap .margin-B  { margin-bottom: 10%; }



/* =======================================
  中央コンテンツ幅
======================================= */

/* （PC/Tablet） */
.LP_wrap .LP_inner{
  width: 100%;
  max-width: 600px;
  margin-inline: auto;
}

/* SPは100% */
.is-sp .LP_wrap .LP_inner{
  max-width: none;
  width: 100%;
}


/* ===============================
  左右固定＋中央スクロール（JS判定前提）
  is-pc：左右あり（画像も表示）
  is-tablet：左右あり（画像は非表示＝グラデのみ）
  is-sp：左右なし（通常スクロール）
=============================== */

.LP_wrap .lp-shell{
  height: 100vh;
  overflow: hidden;
  display: grid;
  grid-template-columns: 1fr 600px 1fr;
}

.LP_wrap .lp-side{
  position: sticky;
  top: 0;
  height: 100vh;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(180deg, #830611 0%, #bb1224 100%);
}

.LP_wrap .lp-side img{
  width: 100%;
  max-width: 1015px;
  display: block;
  margin-inline: auto;
}

.LP_wrap .lp-center{
  height: 100vh;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  position: relative;
  z-index: 2;
  width: 100%;
  max-width: 600px;
  margin-inline: auto;
  box-shadow:
    8px 0 20px rgba(0, 0, 0, 0.35),
    16px 0 40px rgba(0, 0, 0, 0.2);
}

.is-pc .LP_wrap .lp-side img{ display:block !important; }

/* tablet：サイド画像なし（グラデのみ） */
.is-tablet .LP_wrap .lp-side img{ display:none; }

/* sp：サイドなし＋通常スクロール */
.is-sp .LP_wrap .lp-shell{
  grid-template-columns: 1fr;
  height: auto;
  overflow: visible;
}
.is-sp .LP_wrap .lp-side{ display:none; }
.is-sp .LP_wrap .lp-center{
  height: auto;
  overflow: visible;
  -webkit-overflow-scrolling: auto;
  box-shadow: none;

  max-width: none;
  width: 100%;
  margin-inline: 0;
}

/* 左サイド：重ね配置 */
.LP_wrap .lp-left{
  position: relative;
  overflow: hidden;
}
.LP_wrap .lp-left .lp-side-bg{
  position: absolute;
  inset: 0;
  object-fit: cover;
  z-index: 2;
}
.LP_wrap .lp-left .lp-side-car{
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  height: auto;
  object-fit: contain;
  pointer-events: none;
  z-index: 1;
  filter: drop-shadow(0 -10px 20px rgba(0,0,0,0.4));
}

/* hero */
.LP_wrap .LP_hero{
  background: #a30f1e;
  padding-bottom: 5%;
}

/* Shine Effect */
.LP_wrap .shine-effect{
  position: relative;
  display: block;
  overflow: hidden;
  max-width: 750px;
  width: 90%;
  margin-inline: auto;
}
.LP_wrap .shine-effect img{ display:block; width:100%; height:auto; }
.LP_wrap .shine-effect::after{
  content:'';
  position:absolute;
  top:0;
  left:-80%;
  width:70%;
  height:100%;
  background: linear-gradient(120deg,
    transparent 0%,
    transparent 25%,
    rgba(255,255,255,0) 30%,
    rgba(255,255,255,0.15) 40%,
    rgba(255,255,255,0.6) 50%,
    rgba(255,255,255,0.15) 60%,
    rgba(255,255,255,0) 70%,
    transparent 75%,
    transparent 100%);
  animation: shine-sweep 4s ease-in-out infinite;
}
@keyframes shine-sweep{
  0%{ left:-80%; }
  40%{ left:120%; }
  100%{ left:120%; }
}

/* =======================================
  体感ポイント！今すぐチェックボタン
======================================= */

.LP_wrap .cta-wrapper{
  display:flex;
  flex-direction:column;
  align-items:center;
  width:100%;
  margin-top:5%;
}
.is-sp .LP_wrap .cta-wrapper{ margin-top:8%; }

/* balloon */
.LP_wrap .cta-balloon{
  background-color:#fbe7e9;
  color:#bc1224;
  font-weight:bold;
  position:relative;
  border:1px solid #f5cfd3;
  font-size: clamp(16px, 4.2vw, 25px);
  padding: clamp(6px, 1.6vw, 10px) clamp(12px, 3.2vw, 18px);
  margin-bottom: clamp(8px, 2vw, 14px);
  border-radius: clamp(6px, 1.2vw, 10px);
}
.is-sp .LP_wrap .cta-balloon{
  font-size:32px;
  padding:16px 28px;
  margin-bottom:20px;
  border-radius:16px;
}

.LP_wrap .cta-balloon-arrow{
  position:absolute;
  bottom: calc(-1 * clamp(4px, 1.2vw, 6px));
  left:50%;
  transform: translateX(-50%) rotate(45deg);
  width: clamp(8px, 1.8vw, 10px);
  height: clamp(8px, 1.8vw, 10px);
  background-color:#fbe7e9;
  border-right:1px solid #f5cfd3;
  border-bottom:1px solid #f5cfd3;
}
.is-sp .LP_wrap .cta-balloon-arrow{
  bottom:-8px;
  width:16px;
  height:16px;
}

/* button */
.LP_wrap .ripple-container{
  position:relative;
  display:inline-block;
  z-index:1;
}
.LP_wrap .cta-button{
  position:relative;
  background-color:#bc1224;
  color:#fff;
  font-weight:bold;
  border-radius:9999px;
  border:none;
  box-shadow:0 10px 15px -3px rgba(0,0,0,0.1);
  display:flex;
  align-items:center;
  justify-content:center;
  padding: clamp(16px, 4.5vw, 26px) clamp(32px, 8vw, 64px);
  min-width: clamp(220px, 70vw, 360px);
  cursor:pointer;
}
.is-sp .LP_wrap .cta-button{
  padding:35px 60px;
  min-width:500px;
}

.LP_wrap .cta-button-text{
  font-size: clamp(16px, 4.0vw, 20px);
  letter-spacing:0.05em;
  line-height:1;
}
.is-sp .LP_wrap .cta-button-text{ font-size:30px; }

.LP_wrap .cta-button-icon{
  width: clamp(14px, 3.8vw, 18px);
  height: clamp(14px, 3.8vw, 18px);
  margin-left: clamp(6px, 1.8vw, 10px);
}
.is-sp .LP_wrap .cta-button-icon{
  width:26px;
  height:26px;
  margin-left:16px;
}

/* animation */
.LP_wrap .animate-bounce-subtle{ animation:bounce-minimal 3s infinite; }
@keyframes bounce-minimal{
  0%,100%{ transform:translateY(0); }
  50%{ transform:translateY(-3px); }
}
.LP_wrap .active-press:active{
  transform:scale(0.97);
  transition:transform 0.1s;
}

/* ripple */
.LP_wrap .ripple-effect{
  position:absolute;
  top:50%;
  left:50%;
  width:100%;
  height:100%;
  transform: translate(-50%, -50%);
  border-radius:9999px;
  background-color:#bc1224;
  z-index:-1;
  opacity:0;
  pointer-events:none;
}
.LP_wrap .ripple-1{ animation:ripple-spread-subtle 4s ease-out infinite; }
.LP_wrap .ripple-2{ animation:ripple-spread-subtle 4s ease-out infinite 2s; }

@keyframes ripple-spread-subtle{
  0%{
    transform: translate(-50%, -50%) scale(1);
    opacity:0.3;
  }
  100%{
    transform: translate(-50%, -50%) scale(1.3);
    opacity:0;
  }
}

/* =======================================
   ポップアップ（モーダル）
======================================= */

.LP_wrap .popup-overlay{
  position:fixed;
  top:0;
  left:0;
  width:100%;
  height:100%;
  background-color: rgba(0,0,0,0.6);
  display:flex;
  justify-content:center;
  align-items:center;
  z-index:9999;
  opacity:0;
  pointer-events:none;
  transition:opacity 0.3s ease;
}
.LP_wrap .popup-overlay.is-active{
  opacity:1;
  pointer-events:auto;
}

.LP_wrap .popup-modal{
  background-color:#fff;
  width:90%;
  max-width:520px;
  border-radius:16px;
  padding:40px 32px 40px;
  position:relative;
  box-sizing:border-box;
  display:flex;
  flex-direction:column;
  align-items:center;
  transform:translateY(20px);
  transition:transform 0.3s ease;
}
.LP_wrap .popup-overlay.is-active .popup-modal{
  transform:translateY(0);
}

.LP_wrap .popup-close-btn{
  position:absolute;
  bottom:-24px;
  left:50%;
  transform: translateX(-50%);
  width:48px;
  height:48px;
  border-radius:50%;
  background-color:#bc1224;
  color:#fff;
  border:3px solid #fff;
  display:flex;
  justify-content:center;
  align-items:center;
  cursor:pointer;
  box-shadow:0 4px 6px rgba(0,0,0,0.1);
  padding:0;
}
.LP_wrap .popup-close-btn svg{ width:28px; height:28px; }
.LP_wrap .popup-close-btn:active{
  transform: translateX(-50%) scale(0.95);
  transition: transform 0.1s;
}

/* SP popup */
.is-sp .LP_wrap .popup-modal{
  width:90%;
  max-width:none;
  padding:50px 30px 100px;
  border-radius:20px;
}
.is-sp .LP_wrap .taikan-fukidashi{ width:80%; }
.is-sp .LP_wrap .popup-close-btn{
  width:100px;
  height:100px;
}
.is-sp .LP_wrap .popup-close-btn svg{
  width:80px;
  height:80px;
}

/* =======================================
  ボタン
======================================= */

.LP_wrap a:hover{ opacity:0.8; }

.LP_wrap a.btn_base{
  opacity:1;
  text-decoration:none;
  display:block;
  background:#fff;
  width:90%;
  max-width:420px;
  height:55px;
  line-height:55px;
  margin:8% auto 0;
  border-radius:8px;
  text-align:center;
  transition:ease .4s;
  color:#000;
  font-size:22px;
  border:2px solid #000;
  font-weight:500;
}

.is-sp .LP_wrap a.btn_base{
  height:75px;
  line-height:75px;
  font-size:30px;
  max-width:800px;
}

@media (hover: hover) and (pointer: fine) {
  .LP_wrap a.btn_base:hover{
    background:#323232;
    color:#fff;
    border:2px solid #323232;
  }
}