/* レイアウト */
*{
	margin:400px;
}
.features {
  width: min(95vw, 1360px);
  margin: 60px auto;
}
.features__inner {
  display: flex;
  gap: clamp(24px, 3vw, 56px);
  align-items: stretch;
}

/* カード */
.feature {
  position: relative;
  flex: 1 1 0;
  padding: clamp(18px, 2.5vw, 28px) clamp(12px, 2.2vw, 24px) clamp(28px, 3vw, 40px);
  overflow: hidden;
}

/* 背面の薄いアイコン（透かし） */
.feature::after {
  content: "";
  position: absolute;
  inset: auto 0 0 0;          /* 下寄せ中央配置 */
  margin: auto;
  width: clamp(220px, 32vw, 360px);
  height: clamp(220px, 32vw, 360px);
  background-image: var(--mark);
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  pointer-events: none;
  transform: translateY(10%); /* 少し下にずらす */
}

/* タイトルと下線 */
.feature__title {
  font-size: clamp(26px, 3.2vw, 40px);
  font-weight: 800;
  letter-spacing: .02em;
  margin: 0 0 18px;
  position: relative;
}
.feature__title::after {
  content: "";
  display: block;
  width: 100%;
  height: 2px;
  background: #2c2c2c;
  opacity: .35;
  margin-top: clamp(12px, 1.4vw, 16px);
}

/* 本文 */
.feature__text {
  font-size: clamp(15px, 1.4vw, 18px);
  font-weight: 700;           /* 画像に近い力強さ */
  line-height: 2.0;
  margin: clamp(18px, 2vw, 22px) 0 0;
  color: #1f2937;
}

/* レスポンシブ：SPで縦積み */
@media (max-width: 900px) {
  .features__inner { flex-direction: column; }
  .feature::after {
    width: clamp(200px, 70vw, 360px);
    height: clamp(200px, 70vw, 360px);
    transform: translateY(0);
  }
}


.table-scroll-headarea p span{
    font-size: 14px;
    font-weight: 500;
}

.sub_flex_wrapper{
    max-width: 1360px;
    width: 100%;
    margin: 0 auto;
    padding-top: 80px;
    padding-bottom: 80px;
}
.sub_flex_content{
    display: flex;
    justify-content: space-between;
    gap: 20px;
}
.sub_flex01{
    width: 60%;
}
.sub_flex02{
    width: 40%;
}
.sub_flex02 img{
    width: 100%;
    height: 100%;
    object-fit: cover;
  box-shadow:
    0 8px 20px rgba(0, 0, 0, 0.25),
    0 4px 10px rgba(0, 0, 0, 0.15);
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}
.sub_flex02 img:hover {
  transform: translateY(-4px);
  box-shadow:
    0 12px 24px rgba(0, 0, 0, 0.3),
    0 6px 12px rgba(0, 0, 0, 0.18);
}
.sub_flex01 h4{
    font-size: 25px;
    font-weight: 700;
    background: linear-gradient(90deg, #3ab0ff, #0078d7);
    display: inline-block;
    width: auto;
    color: #ffffff;
    padding: 10px;
    box-sizing: border-box;
}
.sub_flex01 p{
    font-size: 16px;
    line-height: 45px;
    margin-top: 20px;
}

.sub_user_box_head h6{
    font-size: 25px;
    font-weight: 700;
}

.sub_user_container{
    background-color: rgb(252, 252, 252);
}
.sub_user_wrapper{
    max-width: 1360px;
    width: 100%;
    margin: 0 auto;
    padding-top: 80px;
    padding-bottom: 80px;
}
.sub_user_head h6{
    font-size: 25px;
}

.sub_user_box_head{
    background: linear-gradient(90deg, #3ab0ff, #0078d7);
    width: auto;
    color: #ffffff;
    padding: 10px;
    box-sizing: border-box;
    margin-top: 40px;
}
.sub_user_box_text{
    background:#E7F1F5;
    height: 100%;
    padding: 20px;
}
.sub_user_box_text p{
    font-size: 16px;
}
.sub_user_box_img_contet{
    padding-top: 80px;
    padding-bottom: 80px;
    background-color: rgb(231 241 245);
}
.sub_user_box_img img{
    width: 100%;
}

.sub_user_box_text {
  display: flex;
  flex-wrap: wrap;
  gap: 30px;
  justify-content: center;
}

.pref_box {
  flex: 1 1 480px;
  background: #f8f8f8;
  border-radius: 10px;
  padding: 24px 28px;
  box-shadow: 0 6px 20px rgba(0, 0, 0, 0.12);
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.pref_box:hover {
  transform: translateY(-4px);
  box-shadow: 0 10px 24px rgba(0, 0, 0, 0.18);
}

.pref_box h3 {
  font-size: 1.4rem;
  color: #104FA1; /* 統一感のあるブルー系 */
  margin-bottom: 12px;
  border-left: 4px solid #104FA1;
  padding-left: 10px;
}

.pref_box p {
  line-height: 1.8;
  color: #333;
  font-size: 0.95rem;
}

.question_banner_container02{
  margin-top: 0;
}
@media(max-width:768px){
	.feature{
		flex:auto;
	}
}
@media (max-width: 900px) {
    .feature::after {
        width: clamp(200px, 70vw, 360px);
        height: clamp(200px, 70vw, 360px);
        transform: translateY(0);
        width: 200px;
        display: flex;
        align-items: center;
        justify-content: center;
        margin: 0 auto;
        vertical-align: middle;
        top: -44px;
    }
}
@media (max-width: 1050px){
  .table-scroll-wrapper{
    padding: 64px 4vw;
  }
  .table-scroll-headarea{
    margin-bottom: 22px;
  }
  .table-scroll-headarea p:first-child{
    font-size: 24px;
  }
  .table-scroll-headarea p span{
    font-size: 15px;
    line-height: 1.95;
  }

  .compare-table{
    min-width: 820px;
  }
  .compare-table th,
  .compare-table td{
    padding: 16px 16px;
    font-size: 15px;
  }
}

@media (max-width: 768px){
  .table-scroll-wrapper{
    padding: 56px 5vw;
	  padding-top:0;
  }
  .table-scroll-headarea p:first-child{
    font-size: 22px;
    line-height: 1.4;
    margin-bottom: 8px;
  }
  .table-scroll-headarea p span{
    font-size: 14px;
    line-height: 1.9;
  }

  .compare-table{
    min-width: 760px;
  }
  .compare-table th,
  .compare-table td{
    padding: 14px 14px;
    font-size: 14px;
    line-height: 1.75;
  }
}

@media (max-width: 500px){
  .table-scroll-wrapper{
    padding: 44px 6vw;
	  padding-top:0;
  }
  .table-scroll-headarea{
    margin-bottom: 16px;
  }
  .table-scroll-headarea p:first-child{
    font-size: 20px;
  }
  .table-scroll-headarea p span{
    font-size: 13px;
    line-height: 1.85;
  }

  .compare-table{
    min-width: 700px;
  }
  .compare-table th,
  .compare-table td{
    padding: 12px 12px;
    font-size: 13px;
  }
}
@media (max-width: 1050px){
  .sub_flex_wrapper{
    max-width: 1360px;
    width: 100%;
    margin: 0 auto;
    padding-top: 64px;
    padding-bottom: 64px;
    padding-left: 4vw;
    padding-right: 4vw;
    box-sizing: border-box;
  }

  .sub_flex_content{
    gap: 16px;
  }

  .sub_flex01{ width: 58%; }
  .sub_flex02{ width: 42%; }

  .sub_flex01 h4{
    font-size: 22px;
    padding: 10px 12px;
  }

  .sub_flex01 p{
    font-size: 15px;
    line-height: 2.0;
  }
}

@media (max-width: 768px){
  .sub_flex_wrapper{
    padding-top: 56px;
    padding-bottom: 56px;
    padding-left: 5vw;
    padding-right: 5vw;
  }

  .sub_flex_content{
    flex-direction: column;
    align-items: stretch;
    gap: 18px;
  }

  .sub_flex01,
  .sub_flex02{
    width: 100%;
  }

  .sub_flex02 img{
    width: 100%;
    height: auto;
    aspect-ratio: 16 / 10;
    object-fit: cover;
  }

  .sub_flex01 h4{
    font-size: 20px;
  }

  .sub_flex01 p{
    font-size: 14px;
    line-height: 1.95;
    margin-top: 14px;
  }
}

@media (max-width: 500px){
  .sub_flex_wrapper{
    padding-top: 44px;
    padding-bottom: 44px;
    padding-left: 6vw;
    padding-right: 6vw;
  }

  .sub_flex02 img{
    aspect-ratio: 4 / 3;
  }

  .sub_flex01 h4{
    font-size: 18px;
    padding: 9px 10px;
  }

  .sub_flex01 p{
    font-size: 13px;
    line-height: 1.9;
  }
}
@media (max-width: 1050px){
  .sub_user_wrapper{
    max-width: 1360px;
    width: 100%;
    margin: 0 auto;
    padding-top: 64px;
    padding-bottom: 64px;
    padding-left: 4vw;
    padding-right: 4vw;
    box-sizing: border-box;
  }

  .sub_user_head h6{
    font-size: 22px;
    line-height: 1.4;
  }

  .sub_user_box_head{
    margin-top: 32px;
    padding: 10px 12px;
  }
  .sub_user_box_head h6{
    font-size: 22px;
  }

  .sub_user_box_text{
    padding: 18px;
  }
  .sub_user_box_text p{
    font-size: 15px;
    line-height: 1.9;
  }

  .sub_user_box_text{
    gap: 22px;
  }
  .pref_box{
    flex: 1 1 420px;
    padding: 22px 24px;
  }
}

@media (max-width: 768px){
  .sub_user_wrapper{
    padding-top: 56px;
    padding-bottom: 56px;
    padding-left: 5vw;
    padding-right: 5vw;
  }

  .sub_user_head h6{
    font-size: 20px;
  }

  .sub_user_box_head{
    margin-top: 26px;
    padding: 10px 12px;
  }
  .sub_user_box_head h6{
    font-size: 20px;
  }

  .sub_user_box_text{
    padding: 16px;
    gap: 16px;
  }

  .sub_user_box_text p{
    font-size: 14px;
    line-height: 1.9;
  }

  .pref_box{
    flex: 1 1 100%;
    padding: 18px 18px;
  }
  .pref_box h3{
    font-size: 1.15rem;
  }
  .pref_box p{
    font-size: 0.95rem;
  }
}

@media (max-width: 500px){
  .sub_user_wrapper{
    padding-top: 44px;
    padding-bottom: 44px;
    padding-left: 6vw;
    padding-right: 6vw;
  }

  .sub_user_head h6{
    font-size: 18px;
    line-height: 1.45;
  }

  .sub_user_box_head{
    margin-top: 22px;
    padding: 9px 10px;
  }
  .sub_user_box_head h6{
    font-size: 18px;
  }

  .sub_user_box_text{
    padding: 14px;
    gap: 12px;
  }

  .sub_user_box_text p{
    font-size: 13px;
    line-height: 1.85;
  }

  .pref_box{
    padding: 16px 16px;
  }
  .pref_box h3{
    font-size: 1.05rem;
    border-left-width: 3px;
    padding-left: 9px;
  }
  .pref_box p{
    font-size: 0.92rem;
  }
}
@media(min-width:769px){
	.sub_user_box_img_img02{
		display:none;
	}
}
@media(max-width:768px){
	.sub_user_box_img_img01{
		display:none;
	}
}


@charset "UTF-8";

/* =========================================================
  Service LP (Floor Coating / Premium White & Blue)
  - HTML変更なし
  - PC: 1440基準 calc
  - SP(<=768): 375基準 calc
========================================================= */

/* -------------------------
  Root tokens
------------------------- */
.lp{
  --ink: #0B1B2B;
  --ink2:#18324A;
  --muted:#5D6B7A;

  --blue:#0E33A0;
  --blue2:#28476B;
  --blue3:#0A2A74;

  --bg:#F6F7FB;
  --panel:#FFFFFF;

  --line: rgba(40,71,107,0.14);
  --shadow: 0 calc(100vw * 18 / 1440) calc(100vw * 50 / 1440) rgba(11,27,43,0.10);
  --shadow2: 0 calc(100vw * 10 / 1440) calc(100vw * 26 / 1440) rgba(11,27,43,0.12);

  --radius: calc(100vw * 18 / 1440);
  --radius2: calc(100vw * 26 / 1440);

  --container: min(calc(100vw * 1120 / 1440), 100%);

  --grad-blue: linear-gradient(135deg, #0E33A0 0%, #082474 45%, #0B3BC1 100%);
  --grad-sky: linear-gradient(135deg, rgba(14,51,160,0.10) 0%, rgba(40,71,107,0.06) 45%, rgba(14,51,160,0.10) 100%);
  --grad-gloss: linear-gradient(180deg, rgba(255,255,255,0.78) 0%, rgba(255,255,255,0.12) 55%, rgba(255,255,255,0) 100%);
  --grad-floor: linear-gradient(90deg,
      rgba(255,255,255,0.00) 0%,
      rgba(255,255,255,0.10) 10%,
      rgba(255,255,255,0.00) 20%,
      rgba(255,255,255,0.12) 35%,
      rgba(255,255,255,0.00) 55%,
      rgba(255,255,255,0.08) 70%,
      rgba(255,255,255,0.00) 100%
  );

  font-family:
    "Zen Kaku Gothic New",
    -apple-system,
    BlinkMacSystemFont,
    "Segoe UI",
    "Hiragino Kaku Gothic ProN",
    "Hiragino Sans",
    "Noto Sans JP",
    Meiryo,
    Arial,
    sans-serif;

  color: var(--ink);
  background: var(--bg);
  line-height: 1.75;
}

.lp *{ box-sizing: border-box; }
.lp img{ max-width:100%; height:auto; display:block; }
.lp a{color: #ff7777; text-decoration:none; }

.lp-typeCard .lp a{
	color:black !important;
}
.lp-container{
  width: var(--container);
  margin: 0 auto;
  padding-left: calc(100vw * 24 / 1440);
  padding-right: calc(100vw * 24 / 1440);
}

/* ---------------------------------
  Common headings / text
--------------------------------- */
.lp-h2{
  font-size: calc(100vw * 34 / 1440);
  line-height: 1.25;
  letter-spacing: 0.02em;
  font-weight: 800;
  color: var(--ink2);
  margin: 0 0 calc(100vw * 22 / 1440);
  position: relative;
  padding-left: calc(100vw * 16 / 1440);
}

.lp-h2::before{
  content:"";
  position:absolute;
  left:0;
  top: 0.22em;
  width: calc(100vw * 6 / 1440);
  height: 1.15em;
  border-radius: calc(100vw * 6 / 1440);
  background: var(--grad-blue);
  box-shadow: 0 0 0 calc(100vw * 3 / 1440) rgba(14,51,160,0.10);
}

.lp-lead{
  font-size: calc(100vw * 16 / 1440);
  color: rgba(11,27,43,0.82);
  line-height: 1.9;
  margin: 0 0 calc(100vw * 26 / 1440);
}

/* ---------------------------------
  Section base
--------------------------------- */
.lp-section{
  padding-top: calc(100vw * 78 / 1440);
  padding-bottom: calc(100vw * 78 / 1440);
  position: relative;
}

.lp-section::before{
  content:"";
  position:absolute;
  inset: 0;
  pointer-events:none;
  background:
    radial-gradient(1200px 420px at 15% 0%, rgba(14,51,160,0.10), transparent 55%),
    radial-gradient(900px 380px at 90% 25%, rgba(40,71,107,0.08), transparent 60%);
  opacity: 0.85;
}

/* ---------------------------------
  Grid system
--------------------------------- */
.lp-grid{
  display:grid;
  gap: calc(100vw * 18 / 1440);
}

.lp-grid--3{
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

@media (max-width: 1100px){
  .lp-grid--3{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

@media (max-width: 880px){
  .lp-grid--3{ grid-template-columns: 1fr; }
}

/* ---------------------------------
  Card base (premium tile)
--------------------------------- */
.lp-card,
.lp-typeCard,
.lp-step,
.lp-case,
.lp-voice{
  background: rgba(255,255,255,0.92);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow2);
  position: relative;
  overflow: hidden;
  padding: calc(100vw * 22 / 1440);
  backdrop-filter: blur(6px);
}

.lp-card::before,
.lp-typeCard::before,
.lp-step::before,
.lp-case::before,
.lp-voice::before{
  content:"";
  position:absolute;
  inset:-2px;
  pointer-events:none;
  background:
    linear-gradient(180deg, rgba(255,255,255,0.65), rgba(255,255,255,0.05)),
    var(--grad-floor);
  opacity: 0.75;
}

.lp-card::after,
.lp-typeCard::after,
.lp-step::after,
.lp-case::after,
.lp-voice::after{
  content:"";
  position:absolute;
  top:-40%;
  left:-35%;
  width: 120%;
  height: 120%;
  background: radial-gradient(circle at 30% 35%, rgba(255,255,255,0.65), transparent 60%);
  transform: rotate(14deg);
  opacity: 0.35;
  pointer-events:none;
}

.lp-card__h,
.lp-typeCard__h,
.lp-step__h,
.lp-case__h,
.lp-voice__h{
  font-size: calc(100vw * 18 / 1440);
  line-height: 1.45;
  margin: 0 0 calc(100vw * 10 / 1440);
  font-weight: 800;
  color: var(--ink2);
  position: relative;
  z-index: 1;
}

.lp-card__p,
.lp-typeCard__p,
.lp-step__p,
.lp-case__p,
.lp-voice__p{
  margin: 0;
  font-size: calc(100vw * 15 / 1440);
  color: rgba(11,27,43,0.78);
  line-height: 1.85;
  position: relative;
  z-index: 1;
}

.lp-card--soft{
  background: linear-gradient(180deg, rgba(255,255,255,0.98), rgba(255,255,255,0.88));
  border-color: rgba(40,71,107,0.12);
}

/* Hover (luxury lift) */
.lp-card:hover,
.lp-typeCard:hover,
.lp-step:hover,
.lp-case:hover,
.lp-voice:hover{
  transform: translateY(calc(100vw * -3 / 1440));
  box-shadow: 0 calc(100vw * 22 / 1440) calc(100vw * 70 / 1440) rgba(11,27,43,0.14);
  transition: 0.22s ease;
}
.lp-card,
.lp-typeCard,
.lp-step,
.lp-case,
.lp-voice{
  transition: 0.22s ease;
}

/* ---------------------------------
  Buttons (premium)
--------------------------------- */
.lp-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap: calc(100vw * 10 / 1440);
  border-radius: calc(100vw * 999 / 1440);
  font-weight: 800;
  letter-spacing: 0.03em;
  padding: calc(100vw * 14 / 1440) calc(100vw * 22 / 1440);
  font-size: calc(100vw * 16 / 1440);
  border: 1px solid transparent;
  box-shadow: 0 calc(100vw * 10 / 1440) calc(100vw * 24 / 1440) rgba(11,27,43,0.12);
  position: relative;
  overflow: hidden;
  transform: translateZ(0);
}

.lp-btn::before{
  content:"";
  position:absolute;
  inset:0;
  background: var(--grad-gloss);
  opacity: 0.65;
  pointer-events:none;
}

.lp-btn--primary{
  background: var(--grad-blue);
  color: #fff;
  border-color: rgba(255,255,255,0.18);
}

.lp-btn--ghost{
  background: rgb(255 246 36 / 78%);
  color: #0014ff !important;
  border-color: rgba(40,71,107,0.28);
  box-shadow: 0 calc(100vw * 10 / 1440) calc(100vw * 26 / 1440) rgba(11,27,43,0.10);
}

.lp-btn--mini{
  font-size: calc(100vw * 14 / 1440);
  padding: calc(100vw * 10 / 1440) calc(100vw * 16 / 1440);
  box-shadow: none;
  border: 1px solid rgba(40,71,107,0.22);
  background:rgb(255 218 0 / 65%);
  color: var(--blue2);
}

.lp-btn--big{
  font-size: calc(100vw * 18 / 1440);
  padding: calc(100vw * 16 / 1440) calc(100vw * 26 / 1440);
}

.lp-btn:hover{
  transform: translateY(calc(100vw * -2 / 1440));
  box-shadow: 0 calc(100vw * 16 / 1440) calc(100vw * 40 / 1440) rgba(11,27,43,0.16);
}
.lp-btn:active{
  transform: translateY(0);
}

.lp-btn--ghost:hover{
  border-color: rgba(14,51,160,0.35);
}

/* ---------------------------------
  HERO (Floor + Gloss)
--------------------------------- */
.lp-hero{
  position: relative;
  padding-top: calc(100vw * 88 / 1440);
  padding-bottom: calc(100vw * 86 / 1440);
  overflow: hidden;
  background:
    radial-gradient(1200px 520px at 12% 0%, rgba(14,51,160,0.22), transparent 58%),
    radial-gradient(980px 480px at 90% 30%, rgba(40,71,107,0.18), transparent 62%),
    linear-gradient(180deg, #061835 0%, #071D42 45%, #0A2456 100%);
}

/* “床”の板目っぽい反射（画像なし） */
.lp-hero::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(90deg,
      rgba(255,255,255,0.00) 0%,
      rgba(255,255,255,0.06) 8%,
      rgba(255,255,255,0.00) 16%,
      rgba(255,255,255,0.08) 28%,
      rgba(255,255,255,0.00) 40%,
      rgba(255,255,255,0.07) 54%,
      rgba(255,255,255,0.00) 70%,
      rgba(255,255,255,0.05) 85%,
      rgba(255,255,255,0.00) 100%
    ),
    linear-gradient(180deg, rgba(255,255,255,0.10) 0%, rgba(255,255,255,0.00) 45%, rgba(255,255,255,0.05) 100%);
  opacity: 0.55;
  pointer-events:none;
}

/* 上からのツヤ（コーティング感） */
.lp-hero::after{
  content:"";
  position:absolute;
  inset:-20%;
  background: radial-gradient(circle at 30% 20%, rgba(255,255,255,0.25), transparent 55%);
  transform: rotate(10deg);
  pointer-events:none;
  opacity: 0.75;
}

.lp-hero__inner{
  width: var(--container);
  margin: 0 auto;
  padding-left: calc(100vw * 24 / 1440);
  padding-right: calc(100vw * 24 / 1440);
  display: grid;
  grid-template-columns: 1.25fr 0.95fr;
  gap: calc(100vw * 26 / 1440);
  align-items: center;
  position: relative;
  z-index: 1;
}

.lp-hero__copy{
  color: #fff;
}

.lp-hero__badge{
  display:inline-flex;
  align-items:center;
  gap: calc(100vw * 10 / 1440);
  font-weight: 800;
  letter-spacing: 0.06em;
  font-size: calc(100vw * 14 / 1440);
  padding: calc(100vw * 10 / 1440) calc(100vw * 14 / 1440);
  border-radius: calc(100vw * 999 / 1440);
  background: rgba(255,255,255,0.10);
  border: 1px solid rgba(255,255,255,0.18);
  box-shadow: 0 calc(100vw * 10 / 1440) calc(100vw * 26 / 1440) rgba(0,0,0,0.18);
  margin: 0 0 calc(100vw * 18 / 1440);
  position: relative;
}

.lp-hero__badge::before{
  content:"";
  width: calc(100vw * 10 / 1440);
  height: calc(100vw * 10 / 1440);
  border-radius: 999px;
  background: linear-gradient(180deg, #FFED24, #F7C84A);
  box-shadow: 0 0 0 calc(100vw * 3 / 1440) rgba(255,237,36,0.18);
  display:inline-block;
}

.lp-hero__title{
  margin: 0 0 calc(100vw * 18 / 1440);
  font-size: calc(100vw * 36 / 1440);
  line-height: 1.28;
  font-weight: 900;
  letter-spacing: 0.02em;
  text-shadow: 0 calc(100vw * 6 / 1440) calc(100vw * 18 / 1440) rgba(0,0,0,0.35);
}

.lp-hero__title span{
  color: #FFED24;
  text-shadow: 0 calc(100vw * 6 / 1440) calc(100vw * 18 / 1440) rgba(0,0,0,0.35);
}

.lp-hero__lead{
  margin: 0 0 calc(100vw * 24 / 1440);
  font-size: calc(100vw * 16 / 1440);
  line-height: 1.9;
  color: rgba(255,255,255,0.92);
}

.lp-hero__cta{
  display:flex;
  gap: calc(100vw * 12 / 1440);
  flex-wrap: wrap;
  margin: 0 0 calc(100vw * 22 / 1440);
}

.lp-hero__trust{
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: calc(100vw * 12 / 1440);
}

.lp-trust{
  background: rgba(255,255,255,0.10);
  border: 1px solid rgba(255,255,255,0.18);
  border-radius: calc(100vw * 16 / 1440);
  padding: calc(100vw * 14 / 1440) calc(100vw * 14 / 1440);
  box-shadow: 0 calc(100vw * 10 / 1440) calc(100vw * 26 / 1440) rgba(0,0,0,0.18);
}

.lp-trust__k{
  margin: 0 0 calc(100vw * 6 / 1440);
  font-size: calc(100vw * 12 / 1440);
  letter-spacing: 0.08em;
  font-weight: 800;
  color: rgba(255,255,255,0.85);
}

.lp-trust__v{
  margin: 0;
  font-size: calc(100vw * 13 / 1440);
  line-height: 1.5;
  font-weight: 700;
  color: #fff;
}

/* Hero right card */
.lp-hero__media{
  display:flex;
  justify-content:flex-end;
}

.lp-hero__card{
  width: min(calc(100vw * 420 / 1440), 100%);
  padding: calc(100vw * 24 / 1440);
  border-radius: var(--radius2);
  background:
    linear-gradient(180deg, rgba(255,255,255,0.96), rgba(255,255,255,0.86)),
    var(--grad-floor);
  border: 1px solid rgba(255,255,255,0.35);
  box-shadow: 0 calc(100vw * 22 / 1440) calc(100vw * 80 / 1440) rgba(0,0,0,0.26);
  position: relative;
  overflow:hidden;
}

.lp-hero__card::before{
  content:"";
  position:absolute;
  inset:-2px;
  background:
    radial-gradient(circle at 22% 18%, rgba(14,51,160,0.15), transparent 55%),
    radial-gradient(circle at 90% 10%, rgba(255,237,36,0.12), transparent 55%),
    linear-gradient(180deg, rgba(255,255,255,0.70), rgba(255,255,255,0.10));
  pointer-events:none;
}

.lp-hero__cardTitle{
  margin:0 0 calc(100vw * 10 / 1440);
  font-weight: 900;
  color: var(--ink2);
  font-size: calc(100vw * 18 / 1440);
  line-height: 1.45;
  position: relative;
  z-index: 1;
}

.lp-hero__cardMain{
  margin:0 0 calc(100vw * 14 / 1440);
  color: rgba(11,27,43,0.78);
  font-weight: 700;
  font-size: calc(100vw * 14 / 1440);
  position: relative;
  z-index: 1;
}

.lp-hero__check{
  margin: 0 0 calc(100vw * 16 / 1440);
  padding-left: 1.2em;
  color: rgba(11,27,43,0.82);
  font-weight: 700;
  font-size: calc(100vw * 14 / 1440);
  line-height: 1.8;
  position: relative;
  z-index: 1;
}

.lp-hero__check li{
  margin-bottom: calc(100vw * 6 / 1440);
}

.lp-hero__card .lp-btn--mini{
  position: relative;
  z-index: 1;
}

/* ---------------------------------
  Pain section
--------------------------------- */
.lp-pain{
  background: linear-gradient(180deg, rgba(255,255,255,0.0), rgba(14,51,160,0.04));
}

.lp-pain .lp-card{
  border-left: calc(100vw * 4 / 1440) solid rgba(14,51,160,0.55);
}

.lp-pain .lp-card__h{
  display:flex;
  align-items:center;
  gap: calc(100vw * 10 / 1440);
}

.lp-pain .lp-card__h::before{
  content:"";
  width: calc(100vw * 10 / 1440);
  height: calc(100vw * 10 / 1440);
  border-radius: 999px;
  background: linear-gradient(180deg, rgba(14,51,160,1), rgba(8,36,116,1));
  box-shadow: 0 0 0 calc(100vw * 3 / 1440) rgba(14,51,160,0.10);
}

/* ---------------------------------
  Benefit split
--------------------------------- */
.lp-benefit{
  background:
    radial-gradient(900px 420px at 30% 0%, rgba(14,51,160,0.10), transparent 60%),
    radial-gradient(840px 420px at 90% 60%, rgba(40,71,107,0.08), transparent 62%);
}

.lp-split{
  display:grid;
  grid-template-columns: 1.15fr 0.85fr;
  gap: calc(100vw * 22 / 1440);
  align-items: start;
}

.lp-list{
  display:flex;
  flex-direction:column;
  gap: calc(100vw * 12 / 1440);
  margin: 0 0 calc(100vw * 18 / 1440);
}

.lp-list__item{
  background: rgba(255,255,255,0.90);
  border: 1px solid rgba(40,71,107,0.12);
  border-radius: calc(100vw * 16 / 1440);
  padding: calc(100vw * 14 / 1440) calc(100vw * 16 / 1440);
  box-shadow: 0 calc(100vw * 10 / 1440) calc(100vw * 24 / 1440) rgba(11,27,43,0.08);
  position: relative;
  overflow:hidden;
}

.lp-list__item::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(circle at 18% 0%, rgba(255,237,36,0.16), transparent 55%),
    radial-gradient(circle at 95% 10%, rgba(14,51,160,0.12), transparent 60%),
    var(--grad-floor);
  opacity: 0.55;
  pointer-events:none;
}

.lp-list__k{
  margin: 0 0 calc(100vw * 4 / 1440);
  font-weight: 900;
  color: var(--ink2);
  font-size: calc(100vw * 16 / 1440);
  position: relative;
  z-index:1;
}

.lp-list__v{
  margin:0;
  color: rgba(11,27,43,0.78);
  font-size: calc(100vw * 14 / 1440);
  position: relative;
  z-index:1;
}

.lp-inlineCta{
  display:flex;
  gap: calc(100vw * 12 / 1440);
  flex-wrap: wrap;
}

.lp-split__right{
  display:flex;
  flex-direction: column;
  gap: calc(100vw * 14 / 1440);
}

.lp-stat{
  background: var(--grad-blue);
  color: #fff;
  border-radius: calc(100vw * 18 / 1440);
  padding: calc(100vw * 18 / 1440) calc(100vw * 18 / 1440);
  box-shadow: 0 calc(100vw * 18 / 1440) calc(100vw * 60 / 1440) rgba(0,0,0,0.18);
  border: 1px solid rgba(255,255,255,0.18);
  position: relative;
  overflow:hidden;
}

.lp-stat::before{
  content:"";
  position:absolute;
  inset:-40%;
  background: radial-gradient(circle at 30% 30%, rgba(255,255,255,0.22), transparent 58%);
  transform: rotate(12deg);
  opacity: 0.9;
  pointer-events:none;
}

.lp-stat__num{
  margin: 0 0 calc(100vw * 6 / 1440);
  font-weight: 900;
  font-size: calc(100vw * 26 / 1440);
  letter-spacing: 0.02em;
  position: relative;
  z-index:1;
}

.lp-stat__txt{
  margin:0;
  font-weight: 700;
  color: rgba(255,255,255,0.92);
  font-size: calc(100vw * 14 / 1440);
  position: relative;
  z-index:1;
}

/* ---------------------------------
  Types cards (3 variants)
--------------------------------- */
.lp-types .lp-typeCard{
  padding-top: calc(100vw * 22 / 1440);
    display: flex;
    flex-direction: column;
}

.lp-typeCard__tag{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  height: calc(100vw * 28 / 1440);
  padding: 0 calc(100vw * 12 / 1440);
  border-radius: calc(100vw * 999 / 1440);
  font-size: calc(100vw * 20 / 1440);
  font-weight: 900;
  letter-spacing: 0.08em;
  border: 1px solid rgba(40,71,107,0.18);
  background: rgba(255,255,255,0.72);
  color: var(--blue2);
  position: relative;
  z-index: 1;
  margin: 0 0 calc(100vw * 12 / 1440);
}
.lp-hero__inner a.lp-btn{
	color:#ffffff !important;
}

.lp-typeCard__ul{
  margin: calc(100vw * 12 / 1440) 0 calc(100vw * 14 / 1440);
  padding-left: 1.1em;
  color: rgba(11,27,43,0.78);
  font-weight: 700;
  font-size: calc(100vw * 14 / 1440);
  line-height: 1.75;
  position: relative;
  z-index: 1;
}

.lp-typeCard--glass{
  border-top: calc(100vw * 6 / 1440) solid rgba(14,51,160,0.65);
}
.lp-typeCard--silicon{
  border-top: calc(100vw * 6 / 1440) solid rgba(255,237,36,0.85);
}
.lp-typeCard--uv{
  border-top: calc(100vw * 6 / 1440) solid rgba(40,71,107,0.55);
}

.lp-typeCard--glass .lp-typeCard__tag{
  background: rgba(14,51,160,0.10);
  border-color: rgba(14,51,160,0.20);
  color: #0E33A0;
}

.lp-typeCard--silicon .lp-typeCard__tag{
  background: rgba(255,237,36,0.20);
  border-color: rgba(255,237,36,0.30);
  color: #6A5B00;
}

.lp-typeCard--uv .lp-typeCard__tag{
  background: rgba(40,71,107,0.10);
  border-color: rgba(40,71,107,0.18);
  color: #28476B;
}

/* ---------------------------------
  Guide steps
--------------------------------- */
.lp-guide .lp-step{
  text-align: left;
}

.lp-step__n{
  margin: 0 0 calc(100vw * 10 / 1440);
  font-weight: 900;
  letter-spacing: 0.10em;
  font-size: calc(100vw * 12 / 1440);
  color: rgba(40,71,107,0.82);
  display:inline-flex;
  align-items:center;
  gap: calc(100vw * 10 / 1440);
  position: relative;
  z-index:1;
}

.lp-step__n::before{
  content:"";
  width: calc(100vw * 34 / 1440);
  height: calc(100vw * 34 / 1440);
  border-radius: 999px;
  background: var(--grad-blue);
  box-shadow: 0 calc(100vw * 8 / 1440) calc(100vw * 18 / 1440) rgba(11,27,43,0.16);
}

.lp-step__n{
  padding-left: 0;
}

.lp-step__n{
  color: rgba(40,71,107,0.82);
}
.lp-step__n{
  position: relative;
}
.lp-step__n{
  display:flex;
}
.lp-step__n{
  align-items:center;
}
.lp-step__n{
  gap: calc(100vw * 10 / 1440);
}
.lp-step__n{
  font-weight: 900;
}
.lp-step__n{
  line-height: 1;
}
.lp-step__n{
  letter-spacing: 0.12em;
}

/* number text inside */
.lp-step__n{
  /* keep as-is */
}
.lp-step__n::after{
  content: "";
  display:none;
}

/* ---------------------------------
  Center CTAs
--------------------------------- */
.lp-centerCta{
  display:flex;
  justify-content:center;
  margin-top: calc(100vw * 22 / 1440);
}

.lp-centerCta .lp-btn{
  min-width: calc(100vw * 260 / 1440);
}

/* ---------------------------------
  Flow timeline
--------------------------------- */
.lp-flow{
  background: linear-gradient(180deg, rgba(14,51,160,0.04), rgba(255,255,255,0));
}

.lp-timeline{
  display:flex;
  flex-direction: column;
  gap: calc(100vw * 12 / 1440);
  position: relative;
}

.lp-timeline__item{
  background: rgba(255,255,255,0.92);
  border: 1px solid rgba(40,71,107,0.14);
  border-radius: calc(100vw * 18 / 1440);
  padding: calc(100vw * 16 / 1440) calc(100vw * 18 / 1440);
  box-shadow: 0 calc(100vw * 12 / 1440) calc(100vw * 30 / 1440) rgba(11,27,43,0.10);
  position: relative;
  overflow:hidden;
}

.lp-timeline__item::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(circle at 12% 0%, rgba(14,51,160,0.12), transparent 60%),
    var(--grad-floor);
  opacity: 0.55;
  pointer-events:none;
}

.lp-timeline__k{
  margin: 0 0 calc(100vw * 6 / 1440);
  font-weight: 900;
  font-size: calc(100vw * 16 / 1440);
  color: var(--ink2);
  position: relative;
  z-index:1;
}

.lp-timeline__v{
  margin:0;
  font-size: calc(100vw * 14 / 1440);
  color: rgba(11,27,43,0.78);
  position: relative;
  z-index:1;
}

/* ---------------------------------
  Cases / Voices tags
--------------------------------- */
.lp-case__tag{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  height: calc(100vw * 26 / 1440);
  padding: 0 calc(100vw * 12 / 1440);
  border-radius: calc(100vw * 999 / 1440);
  background: rgba(14,51,160,0.10);
  border: 1px solid rgba(14,51,160,0.18);
  color: #0E33A0;
  font-size: calc(100vw * 12 / 1440);
  font-weight: 900;
  letter-spacing: 0.08em;
  margin: 0 0 calc(100vw * 12 / 1440);
  position: relative;
  z-index:1;
}

.lp-voice__meta{
  margin: 0 0 calc(100vw * 10 / 1440);
  font-size: calc(100vw * 12 / 1440);
  font-weight: 900;
  letter-spacing: 0.08em;
  color: rgba(40,71,107,0.78);
  position: relative;
  z-index:1;
}

/* ---------------------------------
  Area box
--------------------------------- */
.lp-area__box{
  margin-top: calc(100vw * 18 / 1440);
  background: rgba(255,255,255,0.92);
  border: 1px solid rgba(40,71,107,0.14);
  border-radius: var(--radius);
  padding: calc(100vw * 22 / 1440);
  box-shadow: var(--shadow2);
  position: relative;
  overflow:hidden;
}

.lp-area__box::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(circle at 10% 0%, rgba(255,237,36,0.12), transparent 60%),
    radial-gradient(circle at 90% 10%, rgba(14,51,160,0.10), transparent 60%),
    var(--grad-floor);
  opacity: 0.55;
  pointer-events:none;
}

.lp-area__ttl{
  margin: 0 0 calc(100vw * 10 / 1440);
  font-weight: 900;
  font-size: calc(100vw * 16 / 1440);
  color: var(--ink2);
  position: relative;
  z-index:1;
}

.lp-area__ul{
  margin: 0;
  padding-left: 1.1em;
  color: rgba(11,27,43,0.78);
  font-size: calc(100vw * 14 / 1440);
  line-height: 1.9;
  font-weight: 700;
  position: relative;
  z-index:1;
}

/* ---------------------------------
  Company section
--------------------------------- */
.lp-company .lp-h2{
  margin-bottom: calc(100vw * 10 / 1440);
}

.lp-company .lp-lead{
  margin-bottom: calc(100vw * 24 / 1440);
}

/* ---------------------------------
  FAQ accordion (CSS only)
--------------------------------- */
/* =========================
   FAQ (Always Open Design)
   1440px calc / SP 375px calc
========================= */

.lp-accordion{
    display: flex;
    flex-direction: column;
    gap: calc(100vw * 18 / 1440);
}

.lp-acc__item{
    background: rgba(255,255,255,0.92);
    border: 1px solid rgba(40,71,107,0.16);
    border-radius: calc(100vw * 16 / 1440);
    box-shadow: 0 calc(100vw * 12 / 1440) calc(100vw * 28 / 1440) rgba(11,27,43,0.10);
    overflow: hidden;
    position: relative;
}

.lp-acc__item::before{
    content: "";
    position: absolute;
    inset: 0;
    background:
        radial-gradient(circle at 12% 0%, rgba(14,51,160,0.10), transparent 60%),
        var(--grad-floor);
    opacity: 0.50;
    pointer-events: none;
}

.lp-acc__q{
    width: 100%;
    text-align: left;
    font-weight: 900;
    color: var(--ink2);
    font-size: calc(100vw * 16 / 1440);
    line-height: 1.65;
    padding: calc(100vw * 18 / 1440) calc(100vw * 20 / 1440);
    position: relative;
    z-index: 1;
}

.lp-acc__q::after{
    content: "";
    position: absolute;
    left: calc(100vw * 20 / 1440);
    right: calc(100vw * 20 / 1440);
    bottom: 0;
    height: 1px;
    background: rgba(40,71,107,0.12);
}

.lp-acc__a{
    position: relative;
    z-index: 1;
    padding: calc(100vw * 16 / 1440) calc(100vw * 20 / 1440) calc(100vw * 18 / 1440);
}

.lp-acc__a p{
    margin: 0;
    color: rgba(11,27,43,0.78);
    font-size: calc(100vw * 14 / 1440);
    line-height: 1.95;
    font-weight: 700;
}

.lp-acc__a p + p{
    margin-top: calc(100vw * 10 / 1440);
}

/* Optional: 強調したい一文がある場合に使える */
.lp-acc__a strong{
    font-weight: 900;
    color: rgba(11,27,43,0.88);
}

/* =========================
   SP (<=768) 375px calc
========================= */
@media (max-width: 768px){
    .lp-accordion{
        gap: calc(100vw * 14 / 375);
    }

    .lp-acc__item{
        border-radius: calc(100vw * 14 / 375);
        box-shadow: 0 calc(100vw * 10 / 375) calc(100vw * 24 / 375) rgba(11,27,43,0.10);
    }

    .lp-acc__q{
        font-size: calc(100vw * 15 / 375);
        line-height: 1.7;
        padding: calc(100vw * 16 / 375) calc(100vw * 16 / 375);
    }

    .lp-acc__q::after{
        left: calc(100vw * 16 / 375);
        right: calc(100vw * 16 / 375);
    }

    .lp-acc__a{
        padding: calc(100vw * 14 / 375) calc(100vw * 16 / 375) calc(100vw * 16 / 375);
    }

    .lp-acc__a p{
        font-size: calc(100vw * 13 / 375);
        line-height: 2.0;
    }

    .lp-acc__a p + p{
        margin-top: calc(100vw * 9 / 375);
    }
}

.lp-faq{
    position: relative;
    overflow: hidden;
    background: #eaf3ff;
}

.lp-faq::before{
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    z-index: 0;

    background:
        repeating-linear-gradient(
            120deg,
            rgba(0, 80, 200, 0.18) 0px,
            rgba(0, 80, 200, 0.18) 2px,
            transparent 2px,
            transparent 14px
        ),
        repeating-linear-gradient(
            120deg,
            rgba(0, 80, 200, 0.30) 0px,
            rgba(0, 80, 200, 0.30) 8px,
            transparent 8px,
            transparent 120px
        );
}

.lp-faq .lp-container{
    position: relative;
    z-index: 1;
}
/* ---------------------------------
  Final CTA (premium)
--------------------------------- */
.lp-final{
  position: relative;
  padding-top: calc(100vw * 90 / 1440);
  padding-bottom: calc(100vw * 90 / 1440);
  background:
    radial-gradient(1200px 520px at 15% 0%, rgba(14,51,160,0.22), transparent 58%),
    radial-gradient(980px 480px at 90% 30%, rgba(40,71,107,0.18), transparent 62%),
    linear-gradient(180deg, #061835 0%, #071D42 45%, #0A2456 100%);
  overflow:hidden;
}

.lp-final::before{
  content:"";
  position:absolute;
  inset:0;
  background: var(--grad-floor);
  opacity: 0.45;
  pointer-events:none;
}

.lp-final__inner{
  width: var(--container);
  margin: 0 auto;
  padding-left: calc(100vw * 24 / 1440);
  padding-right: calc(100vw * 24 / 1440);
  text-align: center;
  position: relative;
  z-index:1;
}

.lp-final__h{
  margin: 0 0 calc(100vw * 14 / 1440);
  font-size: calc(100vw * 30 / 1440);
  line-height: 1.35;
  font-weight: 900;
  color: #fff;
  text-shadow: 0 calc(100vw * 6 / 1440) calc(100vw * 18 / 1440) rgba(0,0,0,0.35);
}

.lp-final__p{
  margin: 0 0 calc(100vw * 22 / 1440);
  font-size: calc(100vw * 16 / 1440);
  line-height: 1.9;
  color: rgba(255,255,255,0.92);
}

.lp-final__cta{
  display:flex;
  justify-content:center;
  gap: calc(100vw * 12 / 1440);
  flex-wrap: wrap;
  margin-bottom: calc(100vw * 18 / 1440);
}

.lp-final__top{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-weight: 900;
  letter-spacing: 0.08em;
  color: rgba(255,255,255,0.88);
  font-size: calc(100vw * 12 / 1440);
  text-decoration:none;
  padding: calc(100vw * 10 / 1440) calc(100vw * 14 / 1440);
  border-radius: calc(100vw * 999 / 1440);
  background: rgba(255,255,255,0.10);
  border: 1px solid rgba(255,255,255,0.18);
}

.lp-final__top:hover{
  background: rgba(255,255,255,0.14);
}

/* ---------------------------------
  Responsive (SP 375-based calc)
--------------------------------- */
@media (max-width: 768px){

  .lp{
    --shadow: 0 calc(100vw * 16 / 375) calc(100vw * 40 / 375) rgba(11,27,43,0.12);
    --shadow2: 0 calc(100vw * 10 / 375) calc(100vw * 24 / 375) rgba(11,27,43,0.12);
    --radius: calc(100vw * 16 / 375);
    --radius2: calc(100vw * 22 / 375);
    --container: min(calc(100vw * 339 / 375), 100%);
  }

  .lp-container{
    padding-left: calc(100vw * 18 / 375);
    padding-right: calc(100vw * 18 / 375);
  }

  .lp-section{
    padding-top: calc(100vw * 52 / 375);
    padding-bottom: calc(100vw * 52 / 375);
  }

  .lp-h2{
    font-size: calc(100vw * 22 / 375);
    margin-bottom: calc(100vw * 16 / 375);
    padding-left: calc(100vw * 14 / 375);
  }

  .lp-h2::before{
    width: calc(100vw * 5 / 375);
    border-radius: calc(100vw * 5 / 375);
    box-shadow: 0 0 0 calc(100vw * 3 / 375) rgba(14,51,160,0.10);
  }

  .lp-lead{
    font-size: calc(100vw * 14 / 375);
    margin-bottom: calc(100vw * 18 / 375);
  }

  .lp-grid{
    gap: calc(100vw * 14 / 375);
  }

  .lp-grid--3{
    grid-template-columns: 1fr;
  }

  .lp-card,
  .lp-typeCard,
  .lp-step,
  .lp-case,
  .lp-voice{
    padding: calc(100vw * 18 / 375);
    box-shadow: var(--shadow2);
  }

  .lp-card__h,
  .lp-typeCard__h,
  .lp-step__h,
  .lp-case__h,
  .lp-voice__h{
    font-size: calc(100vw * 16 / 375);
    margin-bottom: calc(100vw * 8 / 375);
  }

  .lp-card__p,
  .lp-typeCard__p,
  .lp-step__p,
  .lp-case__p,
  .lp-voice__p{
    font-size: calc(100vw * 14 / 375);
  }

  .lp-btn{
    font-size: calc(100vw * 15 / 375);
    padding: calc(100vw * 12 / 375) calc(100vw * 16 / 375);
    box-shadow: 0 calc(100vw * 10 / 375) calc(100vw * 22 / 375) rgba(11,27,43,0.12);
  }

  .lp-btn--mini{
    font-size: calc(100vw * 13 / 375);
    padding: calc(100vw * 10 / 375) calc(100vw * 14 / 375);
  }

  .lp-btn--big{
    font-size: calc(100vw * 16 / 375);
    padding: calc(100vw * 14 / 375) calc(100vw * 18 / 375);
  }

  .lp-hero{
    padding-top: calc(100vw * 56 / 375);
    padding-bottom: calc(100vw * 52 / 375);
  }

  .lp-hero__inner{
    grid-template-columns: 1fr;
    gap: calc(100vw * 16 / 375);
  }

  .lp-hero__badge{
    font-size: calc(100vw * 12 / 375);
    padding: calc(100vw * 10 / 375) calc(100vw * 12 / 375);
    margin-bottom: calc(100vw * 14 / 375);
  }

  .lp-hero__badge::before{
    width: calc(100vw * 10 / 375);
    height: calc(100vw * 10 / 375);
    box-shadow: 0 0 0 calc(100vw * 3 / 375) rgba(255,237,36,0.16);
  }

  .lp-hero__title{
    font-size: calc(100vw * 24 / 375);
    margin-bottom: calc(100vw * 12 / 375);
  }

  .lp-hero__lead{
    font-size: calc(100vw * 14 / 375);
    margin-bottom: calc(100vw * 16 / 375);
  }

  .lp-hero__cta{
    gap: calc(100vw * 10 / 375);
    margin-bottom: calc(100vw * 16 / 375);
  }

  .lp-hero__trust{
    grid-template-columns: 1fr;
    gap: calc(100vw * 10 / 375);
  }

  .lp-trust{
    border-radius: calc(100vw * 16 / 375);
    padding: calc(100vw * 12 / 375);
  }

  .lp-trust__k{
    font-size: calc(100vw * 12 / 375);
  }

  .lp-trust__v{
    font-size: calc(100vw * 13 / 375);
  }

  .lp-hero__media{
    justify-content: center;
  }

  .lp-hero__card{
    width: 100%;
    padding: calc(100vw * 18 / 375);
    border-radius: calc(100vw * 22 / 375);
  }

  .lp-hero__cardTitle{
    font-size: calc(100vw * 16 / 375);
  }

  .lp-hero__cardMain{
    font-size: calc(100vw * 13 / 375);
  }

  .lp-hero__check{
    font-size: calc(100vw * 13 / 375);
  }

  .lp-split{
    grid-template-columns: 1fr;
    gap: calc(100vw * 14 / 375);
  }

  .lp-list{
    gap: calc(100vw * 10 / 375);
    margin-bottom: calc(100vw * 14 / 375);
  }

  .lp-list__item{
    border-radius: calc(100vw * 16 / 375);
    padding: calc(100vw * 12 / 375) calc(100vw * 14 / 375);
  }

  .lp-list__k{
    font-size: calc(100vw * 15 / 375);
  }

  .lp-list__v{
    font-size: calc(100vw * 13 / 375);
  }

  .lp-inlineCta{
    gap: calc(100vw * 10 / 375);
  }

  .lp-stat{
    border-radius: calc(100vw * 18 / 375);
    padding: calc(100vw * 16 / 375);
    box-shadow: 0 calc(100vw * 16 / 375) calc(100vw * 46 / 375) rgba(0,0,0,0.18);
  }

  .lp-stat__num{
    font-size: calc(100vw * 22 / 375);
  }

  .lp-stat__txt{
    font-size: calc(100vw * 13 / 375);
  }

  .lp-typeCard__tag{
    height: calc(100vw * 26 / 375);
    padding: 0 calc(100vw * 12 / 375);
    font-size: calc(100vw * 12 / 375);
    margin-bottom: calc(100vw * 10 / 375);
  }

  .lp-typeCard__ul{
    font-size: calc(100vw * 13 / 375);
  }

  .lp-step__n{
    font-size: calc(100vw * 12 / 375);
    margin-bottom: calc(100vw * 10 / 375);
    gap: calc(100vw * 10 / 375);
  }

  .lp-step__n::before{
    width: calc(100vw * 32 / 375);
    height: calc(100vw * 32 / 375);
  }

  .lp-centerCta{
    margin-top: calc(100vw * 16 / 375);
  }

  .lp-centerCta .lp-btn{
    min-width: 100%;
  }

  .lp-timeline{
    gap: calc(100vw * 10 / 375);
  }

  .lp-timeline__item{
    border-radius: calc(100vw * 18 / 375);
    padding: calc(100vw * 14 / 375) calc(100vw * 14 / 375);
  }

  .lp-timeline__k{
    font-size: calc(100vw * 15 / 375);
  }

  .lp-timeline__v{
    font-size: calc(100vw * 13 / 375);
  }

  .lp-case__tag{
    height: calc(100vw * 26 / 375);
    padding: 0 calc(100vw * 12 / 375);
    font-size: calc(100vw * 12 / 375);
  }

  .lp-voice__meta{
    font-size: calc(100vw * 12 / 375);
  }

  .lp-area__box{
    padding: calc(100vw * 18 / 375);
  }

  .lp-area__ttl{
    font-size: calc(100vw * 15 / 375);
  }

  .lp-area__ul{
    font-size: calc(100vw * 13 / 375);
  }

  .lp-accordion{
    gap: calc(100vw * 10 / 375);
  }

  .lp-acc__q{
    border-radius: calc(100vw * 16 / 375);
    padding: calc(100vw * 14 / 375) calc(100vw * 44 / 375) calc(100vw * 14 / 375) calc(100vw * 14 / 375);
    font-size: calc(100vw * 14 / 375);
  }

  .lp-acc__icon{
    right: calc(100vw * 14 / 375);
    width: calc(100vw * 28 / 375);
    height: calc(100vw * 28 / 375);
  }

  .lp-acc__icon::before,
  .lp-acc__icon::after{
    width: calc(100vw * 12 / 375);
  }

  .lp-acc__a{
    border-radius: calc(100vw * 16 / 375);
    padding: calc(100vw * 14 / 375);
  }

  .lp-acc__a p{
    font-size: calc(100vw * 13 / 375);
  }

  .lp-final{
    padding-top: calc(100vw * 62 / 375);
    padding-bottom: calc(100vw * 62 / 375);
  }

  .lp-final__h{
    font-size: calc(100vw * 22 / 375);
    margin-bottom: calc(100vw * 12 / 375);
  }

  .lp-final__p{
    font-size: calc(100vw * 14 / 375);
    margin-bottom: calc(100vw * 16 / 375);
  }

  .lp-final__cta{
    gap: calc(100vw * 10 / 375);
  }

  .lp-final__top{
    font-size: calc(100vw * 12 / 375);
    padding: calc(100vw * 10 / 375) calc(100vw * 12 / 375);
  }
}

/* ---------------------------------
  Reduce motion
--------------------------------- */
@media (prefers-reduced-motion: reduce){
  .lp-card,
  .lp-typeCard,
  .lp-step,
  .lp-case,
  .lp-voice,
  .lp-btn{
    transition: none !important;
    transform: none !important;
  }
}


.area_tables_container{
	padding-bottom:calc(100vw * 40 / 1440);
}
.area_tables_container{
    position: relative;
    overflow: hidden;
    background: linear-gradient(135deg, #003f9e 0%, #0052cc 50%, #0066ff 100%);
}

.area_tables_container::before{
    content: "";
    position: absolute;
    inset: -30%;
    pointer-events: none;
    z-index: 0;

    background:
        repeating-linear-gradient(
            -60deg,
            rgba(255,255,255,0.08) 0px,
            rgba(255,255,255,0.08) 2px,
            transparent 2px,
            transparent 16px
        ),
        radial-gradient(circle at 20% 30%, rgba(255,255,255,0.25), transparent 55%),
        radial-gradient(circle at 85% 70%, rgba(255,255,255,0.18), transparent 50%);
}

.area_tables_container::after{
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    z-index: 0;

    background:
        linear-gradient(180deg, rgba(0,0,0,0.15), transparent 30%, transparent 70%, rgba(0,0,0,0.2));
}

.area_tables_container > *{
    position: relative;
    z-index: 1;
}
.area_tables_text p{
	color:#ffffff;
}
.area_tables_add_area{
	margin-top:10px;
}
@media(max-width:768px){
	.area_tables_container{
		padding-bottom:calc(100vw * 40 / 375);
	}
}

.voice-section{
    padding: calc(100vw * 80 / 1440) 0;
    background: linear-gradient(180deg, #ffffff 0%, rgba(244, 248, 250, 1) 100%);
    width: 90%;
    margin: 0 auto;
    margin-top: -50px;
    position: relative;
}

.voice-inner{
    width: 100%;
    max-width: calc(100vw * 1200 / 1440);
    margin: 0 auto;
    padding: 0 calc(100vw * 24 / 1440);
}

.voice-heading{
    font-size: calc(100vw * 40 / 1440);
    letter-spacing: 0.08em;
    line-height: 1.2;
    margin: 0 0 calc(100vw * 28 / 1440) 0;
    text-align: center;
    color: #28476B;
}

.voice-grid{
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: calc(100vw * 24 / 1440);
}

.voice-card{
    background: #ffffff;
    border: 1px solid rgba(40, 71, 107, 0.12);
    border-radius: calc(100vw * 18 / 1440);
    padding: calc(100vw * 22 / 1440);
    display: grid;
    grid-template-columns: calc(100vw * 80 / 1440) 1fr;
    gap: calc(100vw * 18 / 1440);
    box-shadow: 0 calc(100vw * 10 / 1440) calc(100vw * 26 / 1440) rgba(0,0,0,0.06);
}

.voice-left{
    display: flex;
    flex-direction: column;
    align-items: center;
    padding-top: calc(100vw * 6 / 1440);
}

.voice-avatar{
    width: calc(100vw * 84 / 1440);
    height: calc(100vw * 84 / 1440);
    object-fit: contain;
    border-radius: 999px;
    background: rgba(244, 248, 250, 1);
    border: 1px solid rgba(40, 71, 107, 0.10);
}

.voice-meta{
    margin: calc(100vw * 10 / 1440) 0 0 0;
    font-size: calc(100vw * 14 / 1440);
    letter-spacing: 0.06em;
    color: rgba(40, 71, 107, 0.8);
}

.voice-stars{
    margin-top: calc(100vw * 10 / 1440);
    line-height: 1;
}

.voice-star{
    font-size: calc(100vw * 18 / 1440);
    letter-spacing: 0.08em;
    color: #F2B01E;
    text-shadow: 0 calc(100vw * 2 / 1440) calc(100vw * 6 / 1440) rgba(0,0,0,0.12);
}

.voice-right{
    min-width: 0;
}

.voice-title{
    font-size: calc(100vw * 18 / 1440);
    line-height: 1.45;
    margin: 0 0 calc(100vw * 12 / 1440) 0;
    color: #28476B;
    letter-spacing: 0.06em;
}

.voice-points{
    margin-top: calc(100vw * 10 / 1440);
    padding: calc(100vw * 14 / 1440);
    border-radius: calc(100vw * 14 / 1440);
    background: rgba(52, 124, 156, 0.06);
    border: 1px solid rgba(52, 124, 156, 0.12);
}

.voice-points-title{
    font-size: calc(100vw * 14 / 1440);
    font-weight: 700;
    margin: 0 0 calc(100vw * 8 / 1440) 0;
    color: rgba(40, 71, 107, 0.95);
    letter-spacing: 0.06em;
}

.voice-points-list{
    margin: 0;
    padding-left: 1.2em;
    font-size: calc(100vw * 14 / 1440);
    line-height: 1.7;
    color: rgba(40, 71, 107, 0.85);
}

.voice-message{
    margin-top: calc(100vw * 12 / 1440);
}

.voice-message-title{
    font-size: calc(100vw * 14 / 1440);
    font-weight: 700;
    margin: 0 0 calc(100vw * 8 / 1440) 0;
    color: rgba(40, 71, 107, 0.95);
    letter-spacing: 0.06em;
}

.voice-message-text{
    margin: 0;
    font-size: calc(100vw * 14 / 1440);
    line-height: 1.8;
    color: rgba(40, 71, 107, 0.85);
}

@media (max-width: 1100px){
    .voice-grid{
        grid-template-columns: repeat(2, 1fr);
    }
    .voice-card{
        grid-template-columns: calc(100vw * 190 / 1440) 1fr;
    }
}

@media (max-width: 768px){
    .voice-section{
        padding: calc(100vw * 56 / 375) 0;
    }

    .voice-inner{
        max-width: 100%;
        padding: 0 calc(100vw * 18 / 375);
    }

    .voice-heading{
        font-size: calc(100vw * 22 / 375);
        margin-bottom: calc(100vw * 18 / 375);
    }

    .voice-grid{
        grid-template-columns: 1fr;
        gap: calc(100vw * 14 / 375);
    }

    .voice-card{
        border-radius: calc(100vw * 16 / 375);
        padding: calc(100vw * 16 / 375);
        grid-template-columns: calc(100vw * 108 / 375) 1fr;
        gap: calc(100vw * 12 / 375);
        box-shadow: 0 calc(100vw * 8 / 375) calc(100vw * 18 / 375) rgba(0,0,0,0.06);
    }

    .voice-avatar{
        width: calc(100vw * 72 / 375);
        height: calc(100vw * 72 / 375);
    }

    .voice-meta{
        font-size: calc(100vw * 12 / 375);
        margin-top: calc(100vw * 8 / 375);
    }

    .voice-star{
        font-size: calc(100vw * 16 / 375);
    }

    .voice-title{
        font-size: calc(100vw * 16 / 375);
        margin-bottom: calc(100vw * 10 / 375);
    }

    .voice-points{
        padding: calc(100vw * 12 / 375);
        border-radius: calc(100vw * 12 / 375);
    }

    .voice-points-title,
    .voice-message-title{
        font-size: calc(100vw * 13 / 375);
        margin-bottom: calc(100vw * 6 / 375);
    }

    .voice-points-list,
    .voice-message-text{
        font-size: calc(100vw * 13 / 375);
    }
}
.lp-cases{
    background: #a5d5d5 !important;
    padding-bottom: 100px;
}
.lp-cases .lp-h2{
	color:#ffffff;
}

.lp-cases{
    padding: calc(100vw * 80 / 1440) 0 calc(100vw * 70 / 1440);
    background:
        radial-gradient(circle at 15% 10%, rgba(92,178,175,0.18) 0%, rgba(92,178,175,0) 55%),
        radial-gradient(circle at 85% 30%, rgba(52,124,156,0.12) 0%, rgba(52,124,156,0) 55%),
        linear-gradient(180deg, rgba(246,249,251,1) 0%, #ffffff 75%);
    overflow: hidden;
}

.lp-cases .lp-container{
    width: 100%;
    max-width: calc(100vw * 1120 / 1440);
    margin: 0 auto;
    padding: 0 calc(100vw * 24 / 1440);
}

.lp-cases-feature{
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: calc(100vw * 46 / 1440);
    padding: calc(100vw * 26 / 1440);
    border-radius: calc(100vw * 22 / 1440);
    background: rgba(255,255,255,0.75);
    border: 1px solid rgba(40,71,107,0.12);
    box-shadow: 0 calc(100vw * 18 / 1440) calc(100vw * 46 / 1440) rgba(0,0,0,0.10);
    backdrop-filter: blur(calc(100vw * 8 / 1440));
    -webkit-backdrop-filter: blur(calc(100vw * 8 / 1440));
}

.lp-cases-feature__content{
    flex: 1.1;
    min-width: 0;
}

.lp-cases-feature__sub{
    margin: 0 0 calc(100vw * 10 / 1440) 0;
    font-size: calc(100vw * 13 / 1440);
    letter-spacing: 0.22em;
    color: #5CB2AF;
    font-weight: 700;
}

.lp-cases-feature__title{
    margin: 0 0 calc(100vw * 14 / 1440) 0;
    font-size: calc(100vw * 38 / 1440);
    line-height: 1.25;
    letter-spacing: 0.06em;
    color: #28476B;
}

.lp-cases-feature__lead{
    margin: 0 0 calc(100vw * 18 / 1440) 0;
    font-size: calc(100vw * 15 / 1440);
    line-height: 1.95;
    color: rgba(40,71,107,0.86);
}

.lp-cases-feature__tags{
    display: flex;
    flex-wrap: wrap;
    gap: calc(100vw * 10 / 1440);
    margin: 0 0 calc(100vw * 22 / 1440) 0;
}

.lp-cases-feature__tag{
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: calc(100vw * 7 / 1440) calc(100vw * 12 / 1440);
    border-radius: 999px;
    background: rgba(52,124,156,0.08);
    border: 1px solid rgba(52,124,156,0.14);
    color: #28476B;
    font-weight: 700;
    font-size: calc(100vw * 12.5 / 1440);
    letter-spacing: 0.06em;
}

.lp-cases-feature__btn{
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: calc(100vw * 14 / 1440) calc(100vw * 28 / 1440);
    border-radius: 999px;
    background: linear-gradient(90deg, #347C9C 0%, #5CB2AF 100%);
    color: #ffffff;
    font-size: calc(100vw * 14.5 / 1440);
    font-weight: 700;
    letter-spacing: 0.08em;
    text-decoration: none;
    transition: transform .35s ease, box-shadow .35s ease, filter .35s ease;
    box-shadow: 0 calc(100vw * 10 / 1440) calc(100vw * 26 / 1440) rgba(0,0,0,0.16);
}

.lp-cases-feature__btn:hover{
    transform: translateY(calc(100vw * -2 / 1440));
    filter: brightness(1.02);
    box-shadow: 0 calc(100vw * 14 / 1440) calc(100vw * 30 / 1440) rgba(0,0,0,0.20);
}

.lp-cases-feature__image{
    flex: 0.9;
    min-width: 0;
    position: relative;
}

.lp-cases-feature__image img{
    width: 100%;
    height: calc(100vw * 320 / 1440);
    object-fit: cover;
    border-radius: calc(100vw * 18 / 1440);
    box-shadow: 0 calc(100vw * 18 / 1440) calc(100vw * 52 / 1440) rgba(0,0,0,0.20);
}

.lp-cases-grid{
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: calc(100vw * 18 / 1440);
    margin-top: calc(100vw * 22 / 1440);
    align-items: stretch;
}

.lp-case{
    position: relative;
    background: #ffffff;
    border: 1px solid rgba(40,71,107,0.12);
    border-radius: calc(100vw * 18 / 1440);
    padding: calc(100vw * 20 / 1440) calc(100vw * 20 / 1440) calc(100vw * 18 / 1440);
    box-shadow: 0 calc(100vw * 10 / 1440) calc(100vw * 28 / 1440) rgba(0,0,0,0.08);
    overflow: hidden;
    min-width: 0;
    transition: transform .35s ease, box-shadow .35s ease;
}

.lp-case::before{
    content: "";
    position: absolute;
    top: calc(100vw * -40 / 1440);
    right: calc(100vw * -50 / 1440);
    width: calc(100vw * 160 / 1440);
    height: calc(100vw * 160 / 1440);
    background: radial-gradient(circle, rgba(92,178,175,0.22) 0%, rgba(92,178,175,0) 62%);
    pointer-events: none;
}

.lp-case::after{
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    height: calc(100vw * 6 / 1440);
    background: linear-gradient(90deg, rgba(52,124,156,1) 0%, rgba(92,178,175,1) 60%, rgba(116,210,226,1) 100%);
    opacity: 0.9;
}

.lp-case:hover{
    transform: translateY(calc(100vw * -4 / 1440));
    box-shadow: 0 calc(100vw * 16 / 1440) calc(100vw * 34 / 1440) rgba(0,0,0,0.12);
}

.lp-case__tag{
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin: 0 0 calc(100vw * 12 / 1440) 0;
    padding: calc(100vw * 6 / 1440) calc(100vw * 12 / 1440);
    border-radius: 999px;
    background: rgba(52,124,156,0.10);
    border: 1px solid rgba(52,124,156,0.18);
    color: #28476B;
    font-weight: 700;
    font-size: calc(100vw * 13 / 1440);
    letter-spacing: 0.06em;
}

.lp-case__h{
    margin: 0 0 calc(100vw * 10 / 1440) 0;
    font-size: calc(100vw * 18 / 1440);
    line-height: 1.45;
    color: #28476B;
    letter-spacing: 0.04em;
}

.lp-case__p{
    margin: 0;
    font-size: calc(100vw * 14 / 1440);
    line-height: 1.9;
    color: rgba(40,71,107,0.86);
}

@media (max-width: 1100px){
    .lp-cases-feature{
        gap: calc(100vw * 28 / 1440);
    }

    .lp-cases-feature__image img{
        height: calc(100vw * 360 / 1440);
    }

    .lp-cases-grid{
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 900px){
    .lp-cases-feature{
        flex-direction: column;
        align-items: stretch;
    }

    .lp-cases-feature__image img{
        height: calc(100vw * 420 / 1440);
    }
}

@media (max-width: 768px){
    .lp-cases{
        padding: calc(100vw * 56 / 375) 0 calc(100vw * 52 / 375);
        background: linear-gradient(180deg, rgba(246,249,251,1) 0%, #ffffff 78%);
    }

    .lp-cases .lp-container{
        max-width: 100%;
        padding: 0 calc(100vw * 18 / 375);
    }

    .lp-cases-feature{
        padding: calc(100vw * 18 / 375);
        border-radius: calc(100vw * 16 / 375);
        box-shadow: 0 calc(100vw * 16 / 375) calc(100vw * 34 / 375) rgba(0,0,0,0.10);
        backdrop-filter: none;
        -webkit-backdrop-filter: none;
        gap: calc(100vw * 16 / 375);
    }

    .lp-cases-feature__sub{
        font-size: calc(100vw * 12 / 375);
        margin-bottom: calc(100vw * 8 / 375);
    }

    .lp-cases-feature__title{
        font-size: calc(100vw * 24 / 375);
        margin-bottom: calc(100vw * 10 / 375);
    }

    .lp-cases-feature__lead{
        font-size: calc(100vw * 14 / 375);
        line-height: 1.85;
        margin-bottom: calc(100vw * 14 / 375);
    }

    .lp-cases-feature__tags{
        gap: calc(100vw * 8 / 375);
        margin-bottom: calc(100vw * 16 / 375);
    }

    .lp-cases-feature__tag{
        padding: calc(100vw * 7 / 375) calc(100vw * 12 / 375);
        font-size: calc(100vw * 12 / 375);
    }

    .lp-cases-feature__btn{
        width: 100%;
        padding: calc(100vw * 12 / 375) calc(100vw * 20 / 375);
        font-size: calc(100vw * 14 / 375);
    }

    .lp-cases-feature__image img{
        height: calc(100vw * 210 / 375);
        border-radius: calc(100vw * 14 / 375);
        box-shadow: 0 calc(100vw * 14 / 375) calc(100vw * 28 / 375) rgba(0,0,0,0.16);
    }

    .lp-cases-grid{
        grid-template-columns: 1fr;
        gap: calc(100vw * 14 / 375);
        margin-top: calc(100vw * 16 / 375);
    }

    .lp-case{
        border-radius: calc(100vw * 16 / 375);
        padding: calc(100vw * 18 / 375) calc(100vw * 16 / 375) calc(100vw * 16 / 375);
        box-shadow: 0 calc(100vw * 10 / 375) calc(100vw * 22 / 375) rgba(0,0,0,0.08);
    }

    .lp-case:hover{
        transform: none;
    }

    .lp-case::before{
        top: calc(100vw * -34 / 375);
        right: calc(100vw * -44 / 375);
        width: calc(100vw * 140 / 375);
        height: calc(100vw * 140 / 375);
    }

    .lp-case::after{
        height: calc(100vw * 6 / 375);
    }

    .lp-case__tag{
        margin-bottom: calc(100vw * 10 / 375);
        padding: calc(100vw * 6 / 375) calc(100vw * 12 / 375);
        font-size: calc(100vw * 12 / 375);
    }

    .lp-case__h{
        font-size: calc(100vw * 16 / 375);
        margin-bottom: calc(100vw * 8 / 375);
    }

    .lp-case__p{
        font-size: calc(100vw * 13 / 375);
        line-height: 1.85;
    }
}

.lp-flow{
    padding: calc(100vw * 80 / 1440) 0;
    background:
        radial-gradient(circle at 18% 15%, rgba(92,178,175,0.16) 0%, rgba(92,178,175,0) 56%),
        radial-gradient(circle at 82% 35%, rgba(52,124,156,0.12) 0%, rgba(52,124,156,0) 58%),
        linear-gradient(180deg, #ffffff 0%, rgba(246,249,251,1) 100%);
    overflow: hidden;
}

.lp-flow .lp-container{
    width: 100%;
    max-width: calc(100vw * 1220 / 1440);
    margin: 0 auto;
    padding: 0 calc(100vw * 24 / 1440);
}

.lp-flow-steps{
    margin-top: calc(100vw * 28 / 1440);
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: calc(100vw * 18 / 1440);
    position: relative;
}

.lp-flow-step{
    position: relative;
    display: flex;
    gap: calc(100vw * 16 / 1440);
    align-items: flex-start;
    padding: calc(100vw * 22 / 1440);
    border-radius: calc(100vw * 18 / 1440);
    background: rgba(255,255,255,0.82);
    border: 1px solid rgba(40,71,107,0.12);
    box-shadow: 0 calc(100vw * 12 / 1440) calc(100vw * 34 / 1440) rgba(0,0,0,0.08);
    min-width: 0;
}

.lp-flow-step::before{
    content: "";
    position: absolute;
    top: calc(100vw * -40 / 1440);
    right: calc(100vw * -55 / 1440);
    width: calc(100vw * 160 / 1440);
    height: calc(100vw * 160 / 1440);
    background: radial-gradient(circle, rgba(116,210,226,0.22) 0%, rgba(116,210,226,0) 62%);
    pointer-events: none;
}

.lp-flow-step__num{
    flex: 0 0 calc(100vw * 72 / 1440);
    width: calc(100vw * 72 / 1440);
    height: calc(100vw * 72 / 1440);
    border-radius: calc(100vw * 16 / 1440);
    background: rgba(246,249,251,1);
    border: 1px solid rgba(40,71,107,0.10);
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: inset 0 calc(100vw * 1 / 1440) 0 rgba(255,255,255,0.8);
    overflow: hidden;
}

.lp-flow-step__num img{
    width: 70%;
    height: 70%;
    object-fit: contain;
    display: block;
}

.lp-flow-step__body{
    flex: 1;
    min-width: 0;
}

.lp-flow-step__k{
    margin: 0 0 calc(100vw * 8 / 1440) 0;
    font-size: calc(100vw * 20 / 1440);
    font-weight: 800;
    color: #28476B;
    letter-spacing: 0.04em;
    line-height: 1.4;
}

.lp-flow-step__v{
    margin: 0;
    font-size: calc(100vw * 16 / 1440);
    line-height: 1.9;
    color: black;
}
.lp-flow{
    position: relative;
    overflow: hidden;

    background:
        /* 大きめストライプ（太め・低コントラスト） */
        repeating-linear-gradient(
            115deg,
            rgba(255,255,255,0.06) 0,
            rgba(255,255,255,0.06) 26px,
            rgba(255,255,255,0.00) 26px,
            rgba(255,255,255,0.00) 92px
        ),

        /* ベース：深いネイビー */
        linear-gradient(
            180deg,
            #071628 0%,
            #0B2340 45%,
            #071A2F 100%
        );
}

.lp-flow::before{
    content: "";
    position: absolute;
    inset: 0;
    background:
        /* 斜めの光沢（ホテル壁面っぽい反射） */
        linear-gradient(
            120deg,
            rgba(255,255,255,0.10) 0%,
            rgba(255,255,255,0.04) 22%,
            rgba(255,255,255,0.00) 45%,
            rgba(255,255,255,0.03) 72%,
            rgba(255,255,255,0.00) 100%
        );
    opacity: 0.55;
    pointer-events: none;
}

.lp-flow::after{
    content: "";
    position: absolute;
    inset: -30%;
    background:
        radial-gradient(
            circle at 20% 15%,
            rgba(92,178,175,0.22) 0%,
            rgba(92,178,175,0.00) 55%
        ),
        radial-gradient(
            circle at 85% 70%,
            rgba(116,210,226,0.18) 0%,
            rgba(116,210,226,0.00) 60%
        );
    pointer-events: none;
}
.lp-flow .lp-h2{
	color:#ffffff;
}
@media (max-width: 1100px){
    .lp-flow-steps{
        grid-template-columns: 1fr;
    }
}

@media (max-width: 768px){
    .lp-flow{
        padding: calc(100vw * 56 / 375) 0;
        background: linear-gradient(180deg, #ffffff 0%, rgba(246,249,251,1) 100%);
    }

    .lp-flow .lp-container{
        max-width: 100%;
        padding: 0 calc(100vw * 18 / 375);
    }

    .lp-flow-steps{
        margin-top: calc(100vw * 18 / 375);
        gap: calc(100vw * 14 / 375);
    }

    .lp-flow-step{
        padding: calc(100vw * 18 / 375);
        border-radius: calc(100vw * 16 / 375);
        gap: calc(100vw * 12 / 375);
        box-shadow: 0 calc(100vw * 12 / 375) calc(100vw * 26 / 375) rgba(0,0,0,0.08);
    }

    .lp-flow-step::before{
        top: calc(100vw * -34 / 375);
        right: calc(100vw * -44 / 375);
        width: calc(100vw * 140 / 375);
        height: calc(100vw * 140 / 375);
    }

    .lp-flow-step__num{
        flex: 0 0 calc(100vw * 62 / 375);
        width: calc(100vw * 62 / 375);
        height: calc(100vw * 62 / 375);
        border-radius: calc(100vw * 14 / 375);
    }

    .lp-flow-step__k{
        font-size: calc(100vw * 16 / 375);
        margin-bottom: calc(100vw * 6 / 375);
    }

    .lp-flow-step__v{
        font-size: calc(100vw * 13 / 375);
        line-height: 1.85;
    }
}

.lp-guide{
    position: relative;
    overflow: hidden;
    padding: 72px 0;
    background:
        radial-gradient(900px 480px at 10% 0%, rgba(0,125,201,.22), rgba(0,125,201,0) 60%),
        radial-gradient(900px 520px at 100% 35%, rgba(12,64,168,.22), rgba(12,64,168,0) 62%),
        linear-gradient(180deg, #F6FAFF 0%, #EEF6FF 100%);
}

.lp-guide::before{
    content: "";
    position: absolute;
    inset: -120px -120px;
    background:
        repeating-linear-gradient(
            135deg,
            rgba(0,125,201,.08) 0px,
            rgba(0,125,201,.08) 8px,
            rgba(255,255,255,0) 8px,
            rgba(255,255,255,0) 22px
        );
    transform: rotate(-2deg);
    pointer-events: none;
}

.lp-guide .lp-container{
    position: relative;
    z-index: 1;
}

.lp-guide__lead{
    max-width:calc(100vw * 1120 / 1440);
    margin: 16px auto 34px;
    padding: 16px 18px;
    background: rgba(255,255,255,.72);
    border: 1px solid rgba(0,125,201,.18);
    border-radius: 14px;
    backdrop-filter: blur(6px);
}

.lp-guide__lead p{
    margin: 0;
    font-size: 16px;
    line-height: 1.9;
    color: #163B63;
    letter-spacing: .02em;
}

.lp-guide__steps{
    display: flex;
    gap: 22px;
    align-items: stretch;
    justify-content: center;
}

.lp-guide__card{
    flex: 1 1 0;
    min-width: 0;
    background: rgba(255,255,255,.90);
    border: 1px solid rgba(0,125,201,.18);
    border-radius: 18px;
    overflow: hidden;
    box-shadow: 0 18px 40px rgba(0, 33, 90, .10);
    transform: translateY(0);
    transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}

.lp-guide__card:hover{
    transform: translateY(-4px);
    box-shadow: 0 22px 52px rgba(0, 33, 90, .16);
    border-color: rgba(0,125,201,.30);
}

.lp-guide__imgWrap{
    position: relative;
    padding: 16px 16px 0 16px;
}

.lp-guide__img{
    width: 100%;
    height: 190px;
    object-fit: cover;
    border-radius: 14px;
    box-shadow: 0 10px 26px rgba(0, 33, 90, .12);
}

.lp-guide__no{
    position: absolute;
    top: 10px;
    left: 10px;
    width: 44px;
    height: 44px;
    display: grid;
    place-items: center;
    border-radius: 999px;
    background: linear-gradient(135deg, #007DC9 0%, #0B55D5 100%);
    color: #ffffff;
    font-weight: 800;
    letter-spacing: .06em;
    box-shadow: 0 12px 26px rgba(0, 33, 90, .22);
}

.lp-guide__body{
    padding: 18px 18px 20px;
}

.lp-guide__h{
    margin: 0 0 10px 0;
    font-size: 18px;
    font-weight: 800;
    color: #0B2D55;
    letter-spacing: .06em;
}

.lp-guide__p{
    margin: 0;
    font-size: 14px;
    line-height: 1.95;
    color: #22486E;
    letter-spacing: .02em;
}

.lp-guide__list{
    margin: 14px 0 0 0;
    padding: 0;
    list-style: none;
    display: grid;
    gap: 10px;
}

.lp-guide__list li{
    position: relative;
    padding: 10px 12px 10px 38px;
    background: rgba(0,125,201,.06);
    border: 1px solid rgba(0,125,201,.14);
    border-radius: 12px;
    color: #163B63;
    line-height: 1.7;
}

.lp-guide__list li::before{
    content: "";
    position: absolute;
    top: 12px;
    left: 12px;
    width: 18px;
    height: 18px;
    border-radius: 999px;
    background: linear-gradient(135deg, #007DC9 0%, #0B55D5 100%);
    box-shadow: 0 10px 18px rgba(0, 33, 90, .18);
}

.lp-guide .lp-centerCta{
    margin-top: 28px;
}

@media (max-width: 1024px){
    .lp-guide__steps{
        flex-wrap: wrap;
        gap: 18px;
    }
    .lp-guide__card{
        flex: 0 0 calc((100% - 18px) / 2);
    }
}

@media (max-width: 768px){
    .lp-guide{
        padding: 52px 0;
    }

    .lp-guide__lead{
        margin: 14px auto 22px;
        padding: 14px 14px;
        border-radius: 12px;
    }

    .lp-guide__lead p{
        font-size: 14px;
        line-height: 1.95;
    }

    .lp-guide__steps{
        flex-direction: column;
        gap: 14px;
    }

    .lp-guide__card{
        flex: 1 1 auto;
        border-radius: 16px;
    }

    .lp-guide__imgWrap{
        padding: 14px 14px 0 14px;
    }

    .lp-guide__img{
        height: 170px;
        border-radius: 12px;
    }

    .lp-guide__no{
        width: 40px;
        height: 40px;
        top: 8px;
        left: 8px;
    }

    .lp-guide__body{
        padding: 14px 14px 16px;
    }

    .lp-guide__h{
        font-size: 17px;
    }

    .lp-guide__p{
        font-size: 13.5px;
    }
}


.lp-pain3 {
    position: relative;
    padding: 0;
	padding-top:40px;
	padding-bottom:40px;
}

.lp-pain3 .lp-container {
    max-width: calc(100vw * 1220 / 1440);
	width:100%;
}

.lp-pain3 .lp-h2 {
    text-align: center;
    letter-spacing: 0.06em;
    margin-bottom: 18px;
}
.lp-h2::before{
	display:none;
}
.lp-pain3__lead {
    max-width: calc(100vw * 1120 / 1440);
    margin: 0 auto 34px auto;
    padding: 18px 20px;
    border-radius: 14px;
    background: linear-gradient(180deg, rgba(0, 125, 201, 0.10), rgba(0, 125, 201, 0.04));
    border: 1px solid rgba(0, 125, 201, 0.18);
}

.lp-pain3__lead p {
    margin: 0;
    line-height: 1.9;
    color: rgba(0, 0, 0, 0.72);
    font-weight: 500;
	font-size:20px;
}
.lp-pain3 .lp-container{
    position: relative;
    background: #ffffff;
    border-radius: 18px;
    padding: 36px 20px;
    border: 1px solid rgba(0, 125, 201, 0.12);
    box-shadow: 0 18px 46px rgba(0, 0, 0, 0.06);
    overflow: hidden;
}

.lp-pain3 .lp-container::before{
    content: "";
    position: absolute;
    inset: -60px;
    background:
        repeating-linear-gradient(
            135deg,
            rgba(0, 125, 201, 0.10) 0px,
            rgba(0, 125, 201, 0.10) 6px,
            rgba(255, 255, 255, 0.00) 6px,
            rgba(255, 255, 255, 0.00) 18px
        );
    opacity: 0.55;
    pointer-events: none;
    z-index: 0;
}

.lp-pain3 .lp-container::after{
    content: "";
    position: absolute;
    inset: 0;
    background:
        radial-gradient(circle at 20% 10%, rgba(255, 255, 255, 0.92), rgba(255, 255, 255, 0.00) 52%),
        radial-gradient(circle at 80% 18%, rgba(255, 255, 255, 0.78), rgba(255, 255, 255, 0.00) 55%),
        linear-gradient(180deg, rgba(255, 255, 255, 0.92), rgba(255, 255, 255, 0.72));
    mix-blend-mode: multiply;
    opacity: 0.85;
    pointer-events: none;
    z-index: 0;
}

.lp-pain3 .lp-container > *{
    position: relative;
    z-index: 1;
}

@media (max-width: 768px){
    .lp-pain3 .lp-container{
        border-radius: 16px;
        padding: 26px 14px;
    }
    .lp-pain3 .lp-container::before{
        inset: -40px;
        opacity: 0.6;
    }
}
.lp-pain3__grid {
    display: flex;
    flex-wrap: wrap;
    gap: 22px;
    justify-content: center;
    align-items: stretch;
}

.lp-pain3__card {
    flex: 0 0 calc((100% - 22px) / 2);
    max-width: calc((100% - 22px) / 2);
    display: flex;
    gap: 18px;
    align-items: stretch;
    border-radius: 18px;
    background: #ffffff;
    border: 1px solid rgba(0, 125, 201, 0.14);
    box-shadow: 0 14px 34px rgba(0, 0, 0, 0.08);
    overflow: hidden;
    position: relative;
    transform: translateZ(0);
}

.lp-pain3__card::before {
    content: "";
    position: absolute;
    left: -80px;
    top: -80px;
    width: 210px;
    height: 210px;
    border-radius: 999px;
    background: radial-gradient(circle at 30% 30%, rgba(0, 125, 201, 0.18), rgba(0, 125, 201, 0.00) 60%);
    pointer-events: none;
}

.lp-pain3__card::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(90deg, rgba(167, 221, 255, 0.00) 20%, rgba(167, 221, 255, 0.38) 50%, rgba(167, 221, 255, 0.00) 80%);
    transform: translateX(-110%);
    transition: transform 520ms ease;
    pointer-events: none;
}

.lp-pain3__card:hover::after {
    transform: translateX(110%);
}

.lp-pain3__card:hover {
    transform: translateY(1px);
    box-shadow: inset 0 10px 22px rgba(0, 0, 0, 0.10), 0 10px 22px rgba(0, 0, 0, 0.08);
}

.lp-pain3__media {
    flex: 0 0 180px;
    max-width: 180px;
    position: relative;
    background: linear-gradient(180deg, rgba(0, 125, 201, 0.12), rgba(0, 125, 201, 0.02));
    border-right: 1px solid rgba(0, 125, 201, 0.12);
}

.lp-pain3__media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    filter: saturate(1.02) contrast(1.02);
}

.lp-pain3__body {
    flex: 1 1 auto;
    padding: 18px 18px 18px 0;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.lp-pain3__kicker {
    margin: 0 0 8px 0;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: rgba(0, 125, 201, 1);
    font-weight: 800;
    letter-spacing: 0.10em;
    font-size: 12px;
}

.lp-pain3__kicker::before {
    content: "";
    width: 10px;
    height: 10px;
    border-radius: 999px;
    background: rgba(0, 125, 201, 1);
    box-shadow: 0 0 0 4px rgba(0, 125, 201, 0.14);
}

.lp-pain3__h {
    margin: 0 0 10px 0;
    font-size: 18px;
    line-height: 1.45;
    letter-spacing: 0.03em;
    color: rgba(0, 0, 0, 0.86);
    font-weight: 800;
}

.lp-pain3__p {
    margin: 0;
    line-height: 1.85;
    color: rgba(0, 0, 0, 0.70);
    font-size: 14px;
}

@media (max-width: 900px) {
    .lp-pain3__card {
        flex: 0 0 100%;
        max-width: 100%;
    }

    .lp-pain3__media {
        flex: 0 0 170px;
        max-width: 170px;
    }
}

@media (max-width: 768px) {
    .lp-pain3 .lp-h2 {
        margin-bottom: 14px;
    }

    .lp-pain3__lead {
        margin: 0 auto 22px auto;
        padding: 14px 14px;
        border-radius: 14px;
    }

    .lp-pain3__grid {
        gap: 14px;
    }

    .lp-pain3__card {
        flex-direction: column;
        gap: 0;
        border-radius: 16px;
    }

    .lp-pain3__media {
        flex: 0 0 auto;
        max-width: 100%;
        height: 190px;
        border-right: 0;
        border-bottom: 1px solid rgba(0, 125, 201, 0.12);
    }

    .lp-pain3__body {
        padding: 14px 14px 16px 14px;
    }

    .lp-pain3__h {
        font-size: 17px;
    }

    .lp-pain3__p {
        font-size: 13px;
    }
}

.lp-pain3{
    position: relative;
    overflow: hidden;
    background-color: #ffffff;
}

.lp-pain3::before{
    content: "";
    position: absolute;
    inset: -140px;
    background:
        repeating-linear-gradient(
            135deg,
            rgba(0, 125, 201, 0.18) 0px,
            rgba(0, 125, 201, 0.18) 2px,
            rgba(255, 255, 255, 0.00) 2px,
            rgba(255, 255, 255, 0.00) 12px
        ),
        repeating-linear-gradient(
            135deg,
            rgba(0, 125, 201, 0.08) 0px,
            rgba(0, 125, 201, 0.08) 10px,
            rgba(255, 255, 255, 0.00) 10px,
            rgba(255, 255, 255, 0.00) 44px
        );
    opacity: 0.9;
    pointer-events: none;
    z-index: 0;
}

.lp-pain3::after{
    content: "";
    position: absolute;
    inset: 0;
    background:
        radial-gradient(circle at 18% 12%, rgba(255, 255, 255, 0.92), rgba(255, 255, 255, 0.00) 56%),
        radial-gradient(circle at 82% 18%, rgba(255, 255, 255, 0.82), rgba(255, 255, 255, 0.00) 58%),
        linear-gradient(180deg, rgba(255, 255, 255, 0.96), rgba(255, 255, 255, 0.74));
    pointer-events: none;
    z-index: 0;
}

.lp-pain3 .lp-container{
    position: relative;
    z-index: 1;
}

.lp-benefit{
  scroll-margin-top: 200px; /* ヘッダー高さに合わせて調整 */
}