@charset "UTF-8";
/* ---------------------------------------------
    lp/net/20260304/life
--------------------------------------------- */
/* COMMON
--------------------------------------------- */
.container {
    background: #333;
    color: #333;
    font-family: "メイリオ", Meiryo, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", sans-serif;
    line-height: 1.8;
    margin: 0;
}
.container *,
.container *::before,
.container *::after {
    box-sizing: border-box;
}
.container img {
    height: auto;
    max-width: 100%;
}
.lpcont {
    background: #FFF;
    font-size: 16px;
    margin: 0 auto;
    max-width: 480px;
    padding: 0 15px;
}
.lpcont a:hover {
    opacity: .8;
}
.lpcont em {
    font-weight: bold;
}
.lpcont mark {
    background: linear-gradient(transparent 40%, #FFFF66 40%);
    font-weight: bold;
}
.lpcont .txt2 {
    font-size: 20px;
    margin: 20px auto;
}
.lpcont .att1 {
    color: #F00;
    font-weight: bold;
}
.lpcont .att2 {
    color: #C00;
    font-weight: bold;
}
.lpcont .deco1 {
    font-weight: bold;
    line-height: 1.2;
    text-shadow: 1px 1px 0 #FFF, -1px -1px 0 #FFF, 1px -1px 0 #FFF, -1px 1px 0 #FFF, 0 2px 5px rgba(0, 0, 0, 0.5);
}
.lpcont .deco2 {
    text-decoration: underline;
}
.lpcont .box1 {
    background: #FFF0F0;
    border: 2px solid #FCC;
    font-weight: bold;
}
.lpcont .f_blk {
    border: 2px solid #000;
    margin: 20px auto;
}
.lpcont .f_blk img {
    width: 100%;
}
.lpcont .f_blk p {
    background: #000;
    color: #FFF;
    font-size: 15px;
    font-weight: bold;
    padding: 10px 5px;
    text-align: center;
}
.lpcont .f_blk p::before {
    color: #FC0;
    content: "⚠️";
    margin-right: 4px;
}
/* TITLE */
.lpcont :is(h1, h2, h3) {
    font-weight: bold;
    text-align: center;
}
.lpcont .ttl1 {
    font-size: 24px;
    line-height: 1.4;
    padding-top: 30px;
}
.lpcont .ttl2 {
    background: #333;
    border: 2px solid #000;
    color: #FFF;
    font-size: 22px;
    margin-bottom: 15px;
    margin-top: 50px;
    padding: 10px;
}
.lpcont .ttl3 {
    background: #FFE;
    border: 2px solid #FC0;
    color: #F00;
    font-size: 19px;
    margin: 40px auto 15px;
    padding: 12px;
}
.lpcont .ttl1 .att1 {
    font-size: 28px;
}
.lpcont .ttl1 .deco1 {
    font-size: 38px;
}

/* CTA
--------------------------------------------- */
.lpcont .cta_blk .estimate {
    background: #FFC;
    border: 3px double #F00;
    margin: 10px 0;
    padding: 10px 10px;
    text-align: center;
}
.lpcont .cta_blk.last .estimate {
    background: #FCC;
    padding-top: 30px;
}
.lpcont .cta_blk .estimate .ani1 {
    background: #F00;
    border-radius: 20px;
    color: #FFF;
    display: inline-block;
    font-size: 14px;
    margin-bottom: 15px;
    padding: 3px 15px;
}
.lpcont .cta_blk .estimate .cta_ttl {
    font-size: 20px;
    margin-bottom: 6px;
}
.lpcont .cta_blk .estimation {
    margin: 18px auto 40px;
}
.lpcont .cta_blk .estimation p {
    font-size: 18px;
    font-weight: bold;
    text-align: center;
}
.lpcont .cta_blk .estimation a {
    border: 3px solid #F45F4B;
    border-radius: 50px;
    color: #F45F4B;
    display: block;
    font-size: 22px;
    font-weight: bold;
    line-height: 1;
    padding: 16px;
    text-align: center;
    text-decoration: none;
}
.lpcont .btn_blk {
    padding: 30px 0 50px;
}
.lpcont .btn_blk a {
    background: #FF66EB;
    border-radius: 50px;
    box-shadow: 0 4px 8px rgba(51, 51, 51, 0.2);
    color: #FFF;
    display: block;
    font-size: min(6vw, 22px);
    font-weight: bold;
    margin: 0 auto;
    max-width: 590px;
    padding: 14px 20px;
    text-align: center;
    text-decoration: none;
    width: 100%;
}

/* ANIMATION
--------------------------------------------- */
.lpcont .ani1 {
    animation: blink 0.8s infinite;
    color: #F00;
    font-weight: bold;
    text-align: center;
}
@keyframes blink {
    0% { opacity: 1; }
    50% { opacity: 0; }
    100% { opacity: 1; }
}

/* HEAD_NOTE
--------------------------------------------- */
.container .head_note {
    background: #C00;
    color: #FFF;
    font-size: 12px;
    font-weight: bold;
    letter-spacing: 1px;
    line-height: 1.8;
    margin: 0 auto;
    max-width: 480px;
    padding: 8px 14px;
    text-align: center;
}
.container .head_note span {
    background: #FFF;
    color: #C00;
    margin-right: 5px;
    padding: 1px 4px;
}
/* FV
--------------------------------------------- */
.lpcont .fv .ani1 {
    font-size: 18px;
    margin: 10px auto 20px;
}
.lpcont .fv .lead {
    font-size: 20px;
    line-height: 1.4;
    margin: 20px auto;
    text-align: center;
}
.lpcont .fv .speech {
    background: #FEE;
    border: 3px solid #FCC;
    border-radius: 10px;
    color: #C00;
    font-size: 16px;
    font-weight: bold;
    line-height: 1.6;
    margin: 20px 0 35px 0;
    padding: 15px;
    position: relative;
}
.lpcont .fv .speech::after {
    bottom: -15px;
    border-color: #FEE transparent transparent transparent;
    border-style: solid;
    border-width: 15px 15px 0 15px;
    content: "";
    left: 50%;
    margin-left: -15px;
    position: absolute;
}

/* CONT1
--------------------------------------------- */
.lpcont .cont1 .box1 {
    color: #C00;
    line-height: 1.8;
    margin: 20px 0;
    padding: 15px 15px 15px 40px;
}
.lpcont .cont1 .box1 li {
    list-style-type: disc;
    margin-bottom: 10px;
}

/* CONT2
--------------------------------------------- */
.lpcont .cont2 .example {
    background: #FFF;
    border: 3px solid #F00;
    margin: 25px 0;
    padding: 15px;
    position: relative;
}
.lpcont .cont2 .example .mini_ttl {
    background: #F00;
    color: #FFF;
    font-size: 14px;
    font-weight: bold;
    left: 10px;
    position: absolute;
    top: -15px;
    padding: 2px 10px;
}
.lpcont .cont2 .example .att2 {
    border-bottom: 2px dotted #FCC;
    color: #C00;
    font-size: 18px;
    font-weight: bold;
    padding-bottom: 10px;
    text-align: center;
}
.lpcont .cont2 .example table {
    border-collapse: collapse;
    font-weight: bold;
    margin-top: 15px;
    width: 100%;
}
.lpcont .cont2 .example th,
.lpcont .cont2 .example td {
    border: 1px solid #CCC;
    font-weight: bold;
    padding: 12px 5px;
    text-align: center;
}
.lpcont .cont2 .example th {
    background: #FFE0E0;
    color: #C00;
    font-size: 14px;
}
.lpcont .cont2 .example td {
    font-size: 18px;
}
.lpcont .cont2 .example .ani1 {
    font-size: 12px;
    margin-top: 10px;
}
.lpcont .cont2 .decision {
    border-width: 1px;
    font-weight: bold;
    margin: 16px auto;
    padding: 10px;
    text-align: center;
}

/* CONT3
--------------------------------------------- */
.lpcont .cont3 .video-container {
    padding-bottom: 56.25%;
    position: relative;
    height: 0;
    margin: 16px auto 8px;
    overflow: hidden;
    width: 100%;
}
.lpcont .cont3 .video-container iframe {
    height: 100%;
    left: 0;
    position: absolute;
    top: 0;
    width: 100%;
}
.lpcont .cont3 .box2 {
    background: #F5F5F5;
    border: 2px solid #CCC;
    color: #333;
    font-size: 13px;
    font-weight: bold;
    margin: 10px auto;
    padding: 15px;
}
.lpcont .cont3 .box2 dt {
    font-weight: bold;
}
.lpcont .cont3 .box1 {
    border: 2px solid #F00;
    padding: 44px 20px 56px;
    text-align: center;
}
.lpcont .cont3 .deco1 {
    font-size: 25px;
}
.lpcont .cont3 .deco1 .att1 {
    font-size: 35px;
}
.lpcont .cont3 .ani1 {
    font-size: 35px;
    margin-top: 15px;
}

@media screen and (min-width: 768px) {
    .container {
        padding-bottom: 20px;
    }
}