.mobile-lp, .mobile-lp *{
  box-sizing: border-box;
}.mobile-lp{
  -webkit-text-size-adjust: 100%;
  scroll-behavior: smooth;
}.mobile-lp{
  margin: 0;
  padding: 0;
  min-height: 100%;
  background: #e9e9e9;
  color: #111;
  font-family: "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN W3", "Noto Sans JP", "Yu Gothic", Meiryo, sans-serif;
}

.mobile-lp .hero-headline,
.mobile-lp .lease-title,
.mobile-lp .lease-step-caption,
.mobile-lp .lease-reason-title,
.mobile-lp .lease-merit-title,
.mobile-lp .sec-title,
.mobile-lp .step-head h3,
.mobile-lp .form-title{
  text-wrap: balance;
  line-break: strict;
}.mobile-lp .hero-lead,
.mobile-lp .steps-lead,
.mobile-lp .step-desc,
.mobile-lp .faq-a-inner,
.mobile-lp .q-text,
.mobile-lp .lease-lead,
.mobile-lp .lease-worry-list li span,
.mobile-lp .lease-reason-body,
.mobile-lp .lease-merit-desc,
.mobile-lp .lease-worries-cta{
  text-wrap: pretty;
  line-break: strict;
}.mobile-lp .lp-shell{
  max-width: 420px;
  width: 100%;
  margin: 0 auto;
  background: #fff;
  box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.06);
  padding-left: env(safe-area-inset-left, 0px);
  padding-right: env(safe-area-inset-right, 0px);
}.mobile-lp .lp-section{
  margin: 0;
  padding: 0;
  line-height: 0;
}.mobile-lp .lp-section img{
  display: block;
  width: 100%;
  height: auto;
}.mobile-lp .hero{
  position: relative;
  background: linear-gradient(135deg, #fff2dc 0%, #fff6ea 35%, #e8f1fc 100%);
  padding: 22px 22px 28px;
  line-height: 1.6;
}.mobile-lp .hero-headline{
  margin-bottom: 18px;
  color: #1a1a1a;
  font-size: 32px;
  font-weight: 900;
  line-height: 1.35;
  letter-spacing: 0.01em;
  text-align: center;
}.mobile-lp .hero-headline .hl{
  display: inline-block;
  background: linear-gradient(transparent 58%, #ffee5c 58%, #ffee5c 95%, transparent 95%);
  padding: 0 4px;
}.mobile-lp .hero-lead{
  margin-bottom: 18px;
  color: #333;
  font-size: 15px;
  line-height: 1.9;
  text-align: center;
}.mobile-lp .hero-photo{
  position: relative;
  margin: 0 -22px 22px;
}.mobile-lp .hero-photo img{
  display: block;
  width: 100%;
  height: auto;
}.mobile-lp .hero-cta{
  display: flex;
  width: 100%;
  margin-bottom: 20px;
  align-items: center;
  justify-content: center;
  gap: 10px;
  border-radius: 50px;
  background: linear-gradient(180deg, #ffa24a 0%, #ff7a1c 100%);
  box-shadow: 0 5px 0 rgba(200, 85, 10, 0.4), 0 8px 18px rgba(255, 122, 28, 0.35);
  padding: 20px 12px;
  color: #fff;
  font-size: 20px;
  font-weight: 900;
  letter-spacing: 0.03em;
  text-decoration: none;
  transition: transform 0.1s, box-shadow 0.1s;
}.mobile-lp .hero-cta:active{
  transform: translateY(3px);
  box-shadow: 0 2px 0 rgba(200, 85, 10, 0.4);
}.mobile-lp .hero-cta .play{
  display: inline-flex;
  height: 22px;
  width: 22px;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.15);
  font-size: 11px;
}.mobile-lp .phone-box{
  display: flex;
  align-items: center;
  gap: 14px;
  border: 2px solid #1e6dd8;
  border-radius: 12px;
  background: #fff;
  padding: 16px 18px;
  color: inherit;
  text-decoration: none;
}.mobile-lp .phone-icon{
  height: 48px;
  width: 48px;
  flex-shrink: 0;
  color: #1e6dd8;
}.mobile-lp .phone-info{
  flex: 1;
}.mobile-lp .phone-num{
  color: #1e6dd8;
  font-size: 23px;
  font-weight: 900;
  letter-spacing: 0.01em;
  line-height: 1.1;
  white-space: nowrap;
}.mobile-lp .phone-hours{
  margin-top: 4px;
  color: #666;
  font-size: 12px;
}.mobile-lp .sec-title{
  text-align: center;
  font-size: 34px;
  font-weight: 900;
  line-height: 1.3;
  letter-spacing: 0.01em;
}.mobile-lp .faq-title-intro{
  display: block;
  color: #222;
}.mobile-lp .sec-title .blue{
  color: #1e6dd8;
  display: block;
}.mobile-lp .sec-title .orange{
  color: #ff8c3c;
  display: block;
}.mobile-lp .steps{
  background: linear-gradient(180deg, #dce9fb 0%, #c9ddf8 100%);
  padding: 50px 20px 55px;
}.mobile-lp .steps .sec-title{
  margin-bottom: 22px;
}.mobile-lp .steps-lead{
  margin-bottom: 32px;
  color: #333;
  font-size: 15px;
  line-height: 1.8;
  text-align: center;
}.mobile-lp .step-card{
  position: relative;
  display: flex;
  min-height: 110px;
  flex-direction: column;
  justify-content: center;
  border-radius: 18px;
  background: #fff;
  padding: 20px 20px 20px 100px;
  box-shadow: 0 2px 6px rgba(30, 80, 150, 0.06);
  line-height: 1.6;
}.mobile-lp .step-num{
  position: absolute;
  top: 50%;
  left: 14px;
  display: flex;
  height: 74px;
  width: 74px;
  transform: translateY(-50%);
  flex-direction: column;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: #1e6dd8;
  color: #fff;
  font-weight: 800;
  line-height: 1;
}.mobile-lp .step-num .n{
  font-size: 22px;
  letter-spacing: 0.05em;
}.mobile-lp .step-num .t{
  margin-top: 5px;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.02em;
}.mobile-lp .step-head{
  display: flex;
  margin-bottom: 6px;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}.mobile-lp .step-head h3{
  color: #222;
  font-size: 18px;
  font-weight: 800;
  line-height: 1.4;
}.mobile-lp .step-badge{
  border-radius: 20px;
  background: #ff8c3c;
  padding: 4px 12px;
  color: #fff;
  font-size: 12px;
  font-weight: 700;
  white-space: nowrap;
}.mobile-lp .step-desc{
  color: #555;
  font-size: 13px;
  line-height: 1.7;
}.mobile-lp .step-arrow{
  margin: 4px auto;
  height: 14px;
  width: 18px;
  background: #1e6dd8;
  clip-path: polygon(50% 100%, 0 0, 100% 0);
}.mobile-lp .faq{
  background: #fff;
  padding: 50px 20px 60px;
  line-height: 1.6;
}.mobile-lp .faq .sec-title{
  margin-bottom: 30px;
}.mobile-lp .faq-list{
  border-top: 1px solid #e2e2e2;
}.mobile-lp .faq-item{
  border-bottom: 1px solid #e2e2e2;
}.mobile-lp .faq-q{
  display: flex;
  width: 100%;
  align-items: center;
  gap: 14px;
  border: none;
  background: #fff;
  padding: 20px 4px;
  text-align: left;
  font-family: inherit;
  cursor: pointer;
}.mobile-lp .q-icon{
  display: flex;
  height: 34px;
  width: 34px;
  flex-shrink: 0;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: #1e6dd8;
  color: #fff;
  font-size: 15px;
  font-weight: 800;
}.mobile-lp .q-text{
  flex: 1;
  color: #222;
  font-size: 15px;
  font-weight: 800;
  line-height: 1.5;
}.mobile-lp .q-toggle{
  width: 20px;
  flex-shrink: 0;
  color: #1e6dd8;
  font-size: 24px;
  font-weight: 300;
  line-height: 1;
  text-align: center;
}.mobile-lp .faq-a{
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.3s ease;
}.mobile-lp .faq-a-inner{
  padding: 0 4px 20px 52px;
  color: #777;
  font-size: 13.5px;
  line-height: 1.9;
}.mobile-lp .faq-item.open .faq-a{
  max-height: 400px;
}.mobile-lp .faq-item.open .q-toggle::before{
  content: "−";
}.mobile-lp .faq-item:not(.open) .q-toggle::before{
  content: "+";
}.mobile-lp .form-sec{
  background: linear-gradient(180deg, #fff0de 0%, #ffdcb9 100%);
  padding: 45px 20px 55px;
  line-height: 1.6;
}.mobile-lp .form-badge-wrap{
  margin-bottom: 16px;
  text-align: center;
}.mobile-lp .form-badge{
  display: inline-block;
  border-radius: 30px;
  background: #ff8c3c;
  padding: 8px 26px;
  color: #fff;
  font-size: 15px;
  font-weight: 800;
  letter-spacing: 0.02em;
}.mobile-lp .form-title{
  margin-bottom: 24px;
  text-align: center;
  font-size: 30px;
  font-weight: 900;
  line-height: 1.35;
}.mobile-lp .form-title .orange{
  color: #ff8c3c;
}.mobile-lp .form-box{
  border: 2px solid #1e6dd8;
  border-radius: 14px;
  background: #fff;
  padding: 22px 18px 24px;
}.mobile-lp .fld{
  margin-bottom: 18px;
}.mobile-lp .fld-label{
  display: flex;
  margin-bottom: 10px;
  align-items: center;
  gap: 8px;
  font-size: 15px;
  font-weight: 800;
}.mobile-lp .req{
  border-radius: 4px;
  background: #e63946;
  padding: 2px 8px;
  color: #fff;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.02em;
}.mobile-lp .radios{
  display: flex;
  gap: 10px;
}.mobile-lp .radio-opt{
  display: flex;
  flex: 1;
  align-items: center;
  justify-content: center;
  gap: 8px;
  border: 1.5px solid #bbb;
  border-radius: 40px;
  background: #fff;
  padding: 12px 10px;
  font-size: 15px;
  cursor: pointer;
  transition: border-color 0.15s, background 0.15s;
}.mobile-lp .radio-opt input{
  height: 16px;
  width: 16px;
  accent-color: #1e6dd8;
}.mobile-lp .radio-opt:has(input:checked){
  border-color: #1e6dd8;
  background: #eef5ff;
}.mobile-lp .inp, .mobile-lp .sel{
  width: 100%;
  border: 1.5px solid #bbb;
  border-radius: 8px;
  background: #fff;
  padding: 13px 14px;
  color: #222;
  font-family: inherit;
  font-size: 15px;
}.mobile-lp .inp::placeholder{
  color: #b5b5b5;
}.mobile-lp .sel{
  appearance: none;
  -webkit-appearance: none;
  background-image: url("./select-arrow.svg");
  background-position: right 14px center;
  background-repeat: no-repeat;
  padding-right: 36px;
  color: #b5b5b5;
}.mobile-lp .sel.is-filled{
  color: #222;
}.mobile-lp .privacy{
  display: flex;
  margin: 18px 0 14px;
  align-items: center;
  gap: 10px;
  border-radius: 8px;
  background: #e8f0fe;
  padding: 14px;
  font-size: 13px;
}.mobile-lp .privacy input{
  height: 16px;
  width: 16px;
  flex-shrink: 0;
  accent-color: #1e6dd8;
}.mobile-lp .privacy a{
  color: #1e6dd8;
  font-weight: 600;
  text-decoration: underline;
}.mobile-lp .submit{
  width: 100%;
  border: none;
  border-radius: 40px;
  background: linear-gradient(180deg, #ffa24a 0%, #ff7a1c 100%);
  box-shadow: 0 4px 0 rgba(210, 90, 10, 0.35), 0 6px 14px rgba(255, 122, 28, 0.3);
  padding: 18px;
  color: #fff;
  font-size: 18px;
  font-weight: 900;
  letter-spacing: 0.03em;
  cursor: pointer;
  transition: transform 0.1s, box-shadow 0.1s;
}.mobile-lp .submit:active{
  transform: translateY(2px);
  box-shadow: 0 2px 0 rgba(210, 90, 10, 0.35);
}.mobile-lp .submit:disabled{
  cursor: wait;
  opacity: 0.72;
}.mobile-lp .form-status{
  min-height: 1.6em;
  margin: 14px 0 0;
  color: #1f2937;
  font-size: 14px;
  font-weight: 700;
  line-height: 1.6;
  text-align: center;
}.mobile-lp .form-status[data-status="success"]{
  color: #147a39;
}.mobile-lp .form-status[data-status="error"]{
  color: #c53030;
}.mobile-lp .lease-block{
  --lease-navy: #143b8a;
  --lease-orange: #ff7a1a;
  --lease-line: #cfe0ff;
  --lease-check: #1d4fd6;
  --lease-card-shadow: 0 6px 18px rgba(20, 59, 138, 0.08);
  padding: 48px 20px;
  line-height: 1.6;
}.mobile-lp .lease-title{
  margin: 0 0 16px;
  text-align: center;
  font-size: 26px;
  font-weight: 900;
  line-height: 1.35;
  letter-spacing: 0.02em;
}.mobile-lp .lease-title .orange{
  color: var(--lease-orange);
}.mobile-lp .lease-title .navy{
  color: var(--lease-navy);
}.mobile-lp .lease-lead{
  margin: 0 0 28px;
  color: #2b2b2b;
  font-size: 14px;
  line-height: 1.85;
  text-align: center;
}.mobile-lp .lease-worries{
  background: #fff;
}.mobile-lp .lease-worries-card{
  margin-top: 8px;
  border-radius: 18px;
  background: linear-gradient(180deg, #eef5ff, #e4efff);
  padding: 22px 20px;
}.mobile-lp .lease-worry-list{
  margin: 0;
  padding: 0;
  list-style: none;
}.mobile-lp .lease-worry-list li{
  display: flex;
  align-items: flex-start;
  gap: 14px;
  border-bottom: 1px dashed #b9d1f5;
  padding: 14px 2px;
  color: #222;
  font-size: 15px;
  font-weight: 500;
  line-height: 1.55;
}.mobile-lp .lease-worry-list li:last-child{
  border-bottom: 0;
}.mobile-lp .lease-check{
  display: inline-flex;
  height: 26px;
  width: 26px;
  flex: 0 0 auto;
  margin-top: 1px;
  align-items: center;
  justify-content: center;
  border: 2px solid var(--lease-check);
  border-radius: 5px;
  background: #fff;
}.mobile-lp .lease-check svg{
  width: 18px;
  height: 18px;
}.mobile-lp .lease-arrow{
  display: flex;
  justify-content: center;
  margin: 18px 0 6px;
}.mobile-lp .lease-arrow svg{
  width: 34px;
  height: 34px;
}.mobile-lp .lease-worries-cta{
  border-radius: 14px;
  background: #ffe9d6;
  padding: 20px 16px;
  color: #222;
  font-size: 16px;
  font-weight: 700;
  line-height: 1.7;
  text-align: center;
}.mobile-lp .lease-worries-cta .hl{
  color: var(--lease-orange);
  font-size: 19px;
  font-weight: 900;
}.mobile-lp .lease-steps{
  background: #daebff;
}.mobile-lp .lease-steps .lease-title{
  color: var(--lease-navy);
}.mobile-lp .lease-steps .lease-title .orange{
  background: linear-gradient(transparent 60%, rgba(255, 122, 26, 0.18) 60%);
  padding: 0 2px;
}.mobile-lp .lease-step-card{
  position: relative;
  border-radius: 18px;
  background: #fff;
  box-shadow: var(--lease-card-shadow);
  padding: 22px 18px 18px;
}.mobile-lp .lease-step-badge{
  display: inline-block;
  border-radius: 999px;
  background: var(--lease-navy);
  padding: 7px 16px;
  color: #fff;
  font-family: "Inter", sans-serif;
  font-size: 13px;
  font-weight: 800;
  letter-spacing: 0.08em;
}.mobile-lp .lease-step-illust{
  display: flex;
  height: 150px;
  margin: 4px 0 6px;
  align-items: center;
  justify-content: center;
}.mobile-lp .lease-step-illust svg{
  max-height: 100%;
  max-width: 80%;
}.mobile-lp .lease-step-caption{
  margin: 4px 0 0;
  color: var(--lease-navy);
  font-size: 17px;
  font-weight: 800;
  text-align: center;
}.mobile-lp .lease-step-sep{
  display: flex;
  justify-content: center;
  margin: 6px 0 2px;
}.mobile-lp .lease-step-sep svg{
  width: 28px;
  height: 28px;
}.mobile-lp .lease-reasons{
  background: linear-gradient(180deg, #f3f8ff, #eaf3ff);
}.mobile-lp .lease-reasons .lease-title{
  font-size: 24px;
}.mobile-lp .lease-reason-card{
  position: relative;
  overflow: hidden;
  border-radius: 18px;
  background: #edf4ff;
  box-shadow: 0 2px 8px rgba(20, 59, 138, 0.05);
  padding: 24px 22px;
}.mobile-lp .lease-reason-card + .lease-reason-card{
  margin-top: 18px;
}.mobile-lp .lease-reason-num{
  position: absolute;
  top: 14px;
  right: 18px;
  color: #cfdffb;
  font-family: "Inter", sans-serif;
  font-size: 58px;
  font-weight: 800;
  letter-spacing: -0.02em;
  line-height: 1;
}.mobile-lp .lease-reason-visual{
  display: flex;
  height: 170px;
  margin-bottom: 10px;
  align-items: center;
  justify-content: center;
}.mobile-lp .lease-reason-circle, .mobile-lp .lease-photo-circle{
  display: flex;
  height: 170px;
  width: 170px;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  border-radius: 50%;
}.mobile-lp .lease-reason-circle{
  background: #dfecff;
}.mobile-lp .lease-photo-circle{
  position: relative;
  align-items: flex-end;
  background: linear-gradient(135deg, #f5d8ba, #e9b98a);
}.mobile-lp .lease-reason-visual svg{
  width: 120px;
  height: 120px;
}.mobile-lp .lease-photo-circle svg{
  width: 170px;
  height: 170px;
}.mobile-lp .lease-reason-title{
  margin: 4px 0 12px;
  color: var(--lease-navy);
  font-size: 19px;
  font-weight: 900;
  line-height: 1.45;
  text-align: center;
}.mobile-lp .lease-reason-body{
  margin: 0;
  color: #303030;
  font-size: 13.5px;
  line-height: 1.85;
}.mobile-lp .lease-merits{
  background: linear-gradient(180deg, #e6f0ff, #dbe8ff);
}.mobile-lp .lease-merit-grid{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  margin-top: 6px;
}.mobile-lp .lease-merit-card{
  position: relative;
  border-radius: 16px;
  background: #fff;
  box-shadow: 0 4px 12px rgba(20, 59, 138, 0.07);
  padding: 16px 12px 18px;
  text-align: center;
}.mobile-lp .lease-merit-num{
  display: inline-block;
  margin-bottom: 8px;
  border-radius: 999px;
  background: var(--lease-orange);
  padding: 4px 14px;
  color: #fff;
  font-family: "Inter", sans-serif;
  font-size: 13px;
  font-weight: 800;
}.mobile-lp .lease-merit-icon{
  display: flex;
  height: 110px;
  width: 110px;
  margin: 4px auto 8px;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: #eaf2ff;
}.mobile-lp .lease-merit-icon svg{
  width: 72px;
  height: 72px;
}.mobile-lp .lease-merit-title{
  margin: 4px 0 8px;
  color: var(--lease-navy);
  font-size: 14.5px;
  font-weight: 900;
  line-height: 1.45;
}.mobile-lp .lease-merit-desc{
  margin: 0;
  color: #444;
  font-size: 11.5px;
  line-height: 1.7;
}

.mobile-lp .mobile-title-break{
  display: block;
}

.mobile-lp .hero-cta{
  gap: 8px;
  padding: 18px 10px;
  font-size: 18px;
  letter-spacing: 0;
  white-space: nowrap;
}

.mobile-lp .hero-cta .play{
  flex: 0 0 auto;
}

.mobile-lp .lease-title{
  font-size: clamp(22px, 6.4vw, 25px);
  line-height: 1.32;
  letter-spacing: 0;
  word-break: normal;
  overflow-wrap: normal;
  line-break: strict;
}

.mobile-lp .lease-steps .lease-title,
.mobile-lp .lease-reasons .lease-title{
  font-size: clamp(21px, 6.2vw, 24px);
}

.mobile-lp .lease-lead{
  font-size: 14px;
  line-height: 1.9;
  word-break: normal;
  overflow-wrap: normal;
  line-break: strict;
}

.mobile-lp .lease-worry-list li{
  gap: 12px;
}

.mobile-lp .lease-worry-list li span:last-child{
  min-width: 0;
  font-size: 15px;
  word-break: normal;
  overflow-wrap: normal;
  line-break: strict;
}

.mobile-lp .radio-opt{
  min-width: 0;
  gap: 6px;
  padding: 12px 8px;
  font-size: 14px;
  white-space: nowrap;
}

.mobile-lp .radio-opt input{
  flex: 0 0 auto;
}

.mobile-lp .submit{
  padding: 18px 10px;
  font-size: 17px;
  letter-spacing: 0;
  white-space: nowrap;
}

.mobile-lp .lease-step-illust img{
  display: block;
  width: 132px;
  height: 132px;
  border-radius: 999px;
  object-fit: cover;
  box-shadow: 0 8px 18px rgba(20, 59, 138, 0.12);
}

.mobile-lp .lease-reason-circle img,
.mobile-lp .lease-photo-circle img{
  display: block;
  width: 100%;
  height: 100%;
  border-radius: 50%;
  object-fit: cover;
}

.mobile-lp .lease-merit-icon img{
  display: block;
  width: 94px;
  height: 94px;
  border-radius: 999px;
  object-fit: cover;
  box-shadow: 0 6px 14px rgba(20, 59, 138, 0.12);
}

.mobile-lp .mobile-footer{
  background: #143b8a;
  padding: 24px 20px 40px;
  color: rgba(255, 255, 255, 0.86);
  text-align: center;
}

.mobile-lp .mobile-footer p{
  margin: 0;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.02em;
}

.mobile-lp .js-reveal{
  opacity: 0;
  transform: translateY(18px);
  transition:
    opacity 0.62s ease,
    transform 0.62s cubic-bezier(0.2, 0.75, 0.22, 1);
  transition-delay: var(--reveal-delay, 0ms);
  will-change: opacity, transform;
}

.mobile-lp .js-reveal.is-visible{
  opacity: 1;
  transform: translateY(0);
}

.mobile-lp .hero-photo img{
  animation: mobile-photo-breathe 12s ease-in-out infinite alternate;
}

.mobile-lp .hero-cta,
.mobile-lp .submit{
  animation: mobile-cta-breathe 3.6s ease-in-out infinite;
}

.mobile-lp .lease-step-illust img,
.mobile-lp .lease-merit-icon img,
.mobile-lp .step-img img{
  animation: mobile-icon-float 4.8s ease-in-out infinite;
}

.mobile-lp .lease-worry-list li,
.mobile-lp .radio-opt,
.mobile-lp .faq-q{
  transition:
    transform 0.2s ease,
    box-shadow 0.2s ease,
    background-color 0.2s ease;
}

.mobile-lp .lease-worry-list li:active,
.mobile-lp .radio-opt:active,
.mobile-lp .faq-q:active{
  transform: scale(0.985);
}

@keyframes mobile-photo-breathe{
  from{
    transform: scale(1);
  }
  to{
    transform: scale(1.025);
  }
}

@keyframes mobile-cta-breathe{
  0%, 100%{
    box-shadow: 0 5px 0 rgba(200, 85, 10, 0.4), 0 8px 18px rgba(255, 122, 28, 0.28);
  }
  50%{
    box-shadow: 0 5px 0 rgba(200, 85, 10, 0.4), 0 13px 28px rgba(255, 122, 28, 0.4);
  }
}

@keyframes mobile-icon-float{
  0%, 100%{
    transform: translateY(0);
  }
  50%{
    transform: translateY(-4px);
  }
}

.mobile-lp .hero-editorial-mobile{
  --mobile-ink: #061733;
  --mobile-orange: #c94a1b;
  --mobile-gold: #b88c3c;
  position: relative;
  isolation: isolate;
  overflow: hidden;
  min-height: 100svh;
  background:
    repeating-linear-gradient(135deg, rgba(6, 23, 51, 0.025) 0 1px, transparent 1px 8px),
    radial-gradient(circle at 82% 42%, rgba(184, 140, 60, 0.12), transparent 28%),
    #fffaf0;
  padding: 14px 12px 12px;
  color: var(--mobile-ink);
  line-height: 1.5;
}

.mobile-lp .hero-editorial-mobile::before{
  content: "";
  position: absolute;
  z-index: -1;
  pointer-events: none;
}

.mobile-lp .hero-editorial-mobile::before{
  top: 0;
  right: 0;
  width: 108px;
  height: 76px;
  border-radius: 0 0 0 16px;
  clip-path: none;
  background: linear-gradient(135deg, #09213b 0%, #04172d 100%);
}

.mobile-lp .hero-mobile-proof{
  position: absolute;
  z-index: 2;
  top: 8px;
  right: 7px;
  width: 98px;
  min-height: 55px;
  border-radius: 0 0 0 12px;
  background: transparent;
  padding: 5px 4px 6px 8px;
  color: #fff;
  font-family: "Noto Serif JP", "Yu Mincho", "Hiragino Mincho ProN", serif;
  text-align: center;
  text-shadow: 0 1px 1px rgba(0, 0, 0, 0.22);
}

.mobile-lp .hero-mobile-proof span,
.mobile-lp .hero-mobile-proof em{
  display: block;
  color: #fff;
  font-style: normal;
  font-size: 8.8px;
  font-weight: 800;
  letter-spacing: 0.06em;
  line-height: 1.1;
}

.mobile-lp .hero-mobile-proof strong{
  display: block;
  color: #d5a55d;
  font-size: 22px;
  font-weight: 900;
  line-height: 1.05;
  letter-spacing: 0;
}

.mobile-lp .hero-mobile-proof small{
  font-size: 0.42em;
}

.mobile-lp .hero-eyebrow{
  position: relative;
  z-index: 1;
  width: calc(100% - 106px);
  margin: 0 0 28px;
  border: 1.5px solid rgba(184, 140, 60, 0.72);
  border-radius: 5px;
  background: rgba(255, 253, 248, 0.72);
  padding: 7px 5px 8px;
  color: var(--mobile-ink);
  font-family: "Noto Serif JP", "Yu Mincho", "Hiragino Mincho ProN", serif;
  font-size: clamp(11px, 3vw, 13px);
  font-weight: 800;
  line-height: 1.25;
  letter-spacing: 0;
  text-align: center;
  white-space: nowrap;
}

.mobile-lp .hero-eyebrow span,
.mobile-lp .hero-headline .accent,
.mobile-lp .hero-free-note strong{
  color: var(--mobile-orange);
}

.mobile-lp .hero-editorial-mobile .hero-headline{
  position: relative;
  z-index: 1;
  margin: 0 0 8px;
  color: var(--mobile-ink);
  font-family: "Noto Serif JP", "Yu Mincho", "Hiragino Mincho ProN", serif;
  font-size: clamp(34px, 9.8vw, 40px);
  font-weight: 900;
  line-height: 1.12;
  letter-spacing: 0;
  text-align: left;
}

.mobile-lp .hero-editorial-mobile .hero-headline span{
  display: block;
}

.mobile-lp .hero-editorial-mobile .hero-headline .accent{
  display: inline;
  background: none;
  padding: 0;
}

.mobile-lp .hero-editorial-mobile .hero-lead{
  position: relative;
  z-index: 1;
  margin: 0 0 6px;
  padding-left: 10px;
  border-left: 3px solid var(--mobile-gold);
  color: var(--mobile-ink);
  font-family: "Noto Serif JP", "Yu Mincho", "Hiragino Mincho ProN", serif;
  font-size: 11.5px;
  font-weight: 700;
  line-height: 1.56;
  letter-spacing: 0.02em;
  text-align: left;
}

.mobile-lp .hero-editorial-mobile .hero-photo{
  position: relative;
  z-index: 1;
  height: clamp(246px, 65vw, 285px);
  margin: 0 -12px 6px;
}

.mobile-lp .hero-editorial-mobile .hero-photo::before{
  content: "";
  position: absolute;
  left: 10px;
  right: 44px;
  bottom: 0;
  height: 100%;
  border-radius: 999px 999px 0 0;
  background: #d7ebff;
  box-shadow: 0 10px 22px rgba(6, 23, 51, 0.08);
}

.mobile-lp .hero-editorial-mobile .hero-house-img{
  position: absolute;
  left: 10px;
  right: 44px;
  bottom: 0;
  width: calc(100% - 54px);
  height: 100%;
  border-radius: 999px 999px 0 0;
  object-fit: cover;
  object-position: 50% 52%;
}

.mobile-lp .hero-editorial-mobile .hero-couple-img{
  position: absolute;
  right: 12px;
  bottom: -4px;
  width: clamp(126px, 35vw, 148px);
  aspect-ratio: 1;
  height: auto;
  border: 6px solid #fff;
  border-radius: 50%;
  object-fit: cover;
  object-position: 52% 44%;
  box-shadow: 0 10px 20px rgba(6, 23, 51, 0.14);
}

.mobile-lp .hero-support{
  position: relative;
  margin: 0 0 6px;
  color: var(--mobile-ink);
  font-family: "Noto Serif JP", "Yu Mincho", "Hiragino Mincho ProN", serif;
  font-size: 11.5px;
  font-weight: 900;
  line-height: 1.5;
  letter-spacing: 0.03em;
  text-align: center;
}

.mobile-lp .hero-support::before,
.mobile-lp .hero-support::after{
  content: "";
  position: absolute;
  top: 50%;
  width: 28px;
  height: 1px;
  background: var(--mobile-gold);
}

.mobile-lp .hero-support::before{
  left: 0;
  transform: rotate(62deg);
}

.mobile-lp .hero-support::after{
  right: 0;
  transform: rotate(-62deg);
}

.mobile-lp .hero-points{
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: 1fr 1fr;
  border: 1px solid rgba(6, 23, 51, 0.24);
  border-radius: 4px;
  background: rgba(255, 253, 248, 0.9);
  overflow: hidden;
}

.mobile-lp .hero-point{
  display: grid;
  grid-template-columns: 38px minmax(0, 1fr);
  gap: 8px;
  align-items: center;
  min-height: 54px;
  padding: 6px 8px;
  border-right: 1px solid rgba(6, 23, 51, 0.18);
  border-bottom: 1px solid rgba(6, 23, 51, 0.18);
}

.mobile-lp .hero-point:nth-child(2n){
  border-right: 0;
}

.mobile-lp .hero-point:nth-last-child(-n+2){
  border-bottom: 0;
}

.mobile-lp .hero-point img{
  width: 34px;
  height: 34px;
  border-radius: 10px;
  object-fit: cover;
  box-shadow: 0 4px 10px rgba(6, 23, 51, 0.12);
}

.mobile-lp .hero-point strong{
  display: block;
  color: var(--mobile-ink);
  font-family: "Noto Serif JP", "Yu Mincho", "Hiragino Mincho ProN", serif;
  font-size: 12.5px;
  font-weight: 900;
  line-height: 1.15;
}

.mobile-lp .hero-point span{
  display: block;
  margin-top: 4px;
  color: #202435;
  font-size: 10px;
  font-weight: 800;
  line-height: 1.45;
}

.mobile-lp .hero-editorial-mobile .phone-box{
  display: none;
}

.mobile-lp .hero-editorial-mobile .phone-icon{
  width: 24px;
  height: 24px;
  color: #fff;
}

.mobile-lp .hero-editorial-mobile .phone-info{
  display: flex;
  align-items: baseline;
  gap: 10px;
  flex: initial;
}

.mobile-lp .hero-editorial-mobile .phone-num{
  color: #d7a556;
  font-size: 13px;
  font-weight: 900;
  letter-spacing: 0.02em;
  white-space: nowrap;
}

.mobile-lp .hero-editorial-mobile .phone-hours{
  color: #fff;
  font-size: 10px;
  font-weight: 900;
  white-space: nowrap;
}

.mobile-lp .hero-editorial-mobile .hero-cta{
  min-height: 62px;
  margin: 0 0 7px;
  gap: 12px;
  border: 3px solid #c2380b;
  border-radius: 13px;
  background: linear-gradient(180deg, #f45b16 0%, #d93b0b 100%);
  box-shadow: inset 0 0 0 2px rgba(255, 255, 255, 0.32), 0 5px 0 #8d2607, 0 13px 24px rgba(196, 65, 8, 0.18);
  padding: 9px 12px;
  font-family: "Noto Serif JP", "Yu Mincho", "Hiragino Mincho ProN", serif;
  font-size: clamp(18px, 5vw, 20px);
  letter-spacing: 0.03em;
}

.mobile-lp .hero-editorial-mobile .hero-cta .free{
  display: grid;
  place-items: center;
  width: 44px;
  height: 44px;
  flex: 0 0 auto;
  border-radius: 50%;
  background: #fff;
  color: var(--mobile-orange);
  font-size: 15px;
  font-weight: 900;
}

.mobile-lp .hero-editorial-mobile .hero-cta .arrow{
  margin-left: auto;
  font-family: Inter, sans-serif;
  font-size: 30px;
  line-height: 0.8;
}

.mobile-lp .hero-free-note{
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 32px;
  margin: 0;
  border: 1px solid rgba(184, 140, 60, 0.28);
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.76);
  color: var(--mobile-ink);
  font-family: "Noto Serif JP", "Yu Mincho", "Hiragino Mincho ProN", serif;
  font-size: 10.5px;
  font-weight: 800;
  line-height: 1.45;
  text-align: center;
}

@media (prefers-reduced-motion: reduce){
  .mobile-lp *,
  .mobile-lp *::before,
  .mobile-lp *::after{
    animation-duration: 0.001ms !important;
    animation-iteration-count: 1 !important;
    scroll-behavior: auto !important;
    transition-duration: 0.001ms !important;
  }

  .mobile-lp .js-reveal{
    opacity: 1;
    transform: none;
  }
}
