* {
    margin: 0;
    padding: 0;
}

.cms-public {
    overflow-x: hidden;

    @media screen and (max-width: 600px) {
        overflow-x: unset;
        width: 100%;
    }

    @media screen and (max-width: 1200px) {
        .page {
            width: 100% !important;
        }
    }

    @media screen and (max-width: 600px) {
        .page {
            width: 100% !important;
        }
    }



    /* ------共通設定------ */
    *,
    *::before,
    *::after {
        box-sizing: border-box;
    }

    * {
        margin: 0;
        padding: 0;
    }

    html {
        line-height: 1.5;
        -webkit-text-size-adjust: 100%;
        font-size: 16px;
    }

    body {
        min-height: 100vh;
        text-rendering: optimizeLegibility;
        -webkit-font-smoothing: antialiased;
        -moz-osx-font-smoothing: grayscale;
        font-optical-sizing: auto;
        color: #000000;
        background: #fff;
        overflow-x: hidden;
    }

    h1,
    h2,
    h3,
    h4,
    h5,
    h6 {
        font-weight: 700;
        line-height: 1.2;
    }

    p,
    ul,
    ol,
    dl {
        margin-block: 0;
    }

    small {
        font-size: 0.875em;
    }

    strong,
    b {
        font-weight: 700;
    }

    ul,
    ol {
        list-style: none;
        padding-left: 0;
    }

    a {
        color: inherit;
        text-decoration: none;
        text-decoration-skip-ink: auto;
    }

    a:hover {
        text-decoration: underline;
    }

    img,
    picture,
    video,
    canvas,
    svg {
        display: block;
        max-width: 100%;
        height: auto;
    }

    input,
    button,
    textarea,
    select {
        font: inherit;
        color: inherit;
    }

    button {
        cursor: pointer;
        background: none;
        border: none;
    }

    textarea {
        resize: vertical;
    }

    table {
        border-collapse: collapse;
        border-spacing: 0;
    }

    :focus-visible {
        outline: 2px solid currentColor;
        outline-offset: 2px;
    }

    @media (prefers-reduced-motion: reduce) {
        html:focus-within {
            scroll-behavior: auto;
        }

        *,
        *::before,
        *::after {
            animation-duration: 0.001ms !important;
            animation-iteration-count: 1 !important;
            transition-duration: 0.001ms !important;
            scroll-behavior: auto !important;
        }
    }

    .parenting-lp {
        position: relative;
        margin: 0 calc(50% - 50vw);
        width: 100vw;
        font-family: "Noto Sans JP", sans-serif;
    }

    .parenting-lp::before {
        /* width: 100%;
    height: 100%;
    content: '';
    display: inline-block;
    position: fixed;
    top: 0px;
    left: 0px;
    z-index: -1;
    opacity: 0.7;

    background: repeating-linear-gradient(45deg,
            #a0d7e5 0px,
            #a0d7e5 7px,
            #ffffff 7px,
            #ffffff 15px,
            #fcdf99 15px,
            #fcdf99 22px,
            #ffffff 22px,
            #ffffff 30px); */
    }


    .parenting-lp__sp-only {
        display: none;
    }

    @media screen and (max-width: 1000px) {
        .parenting-lp__pc-only {
            display: none;
        }

        .parenting-lp__sp-only {
            display: block;
        }
    }

    .parenting-lp__container {
        max-width: 960px;
        margin: 0 auto;
        background-color: #fff;
        position: relative;
    }

    .parenting-lp__content {
        max-width: 720px;
        margin: 0 auto;
        background-color: #fff;
    }

    @media screen and (max-width: 1000px) {
        .parenting-lp__container {
            margin: 0 50px;
            padding: 0 40px;
        }
    }

    @media screen and (max-width: 600px) {
        .parenting-lp {
            margin: 0;
            width: 100%;
        }

        .parenting-lp__container {
            margin: 0 16px;
            padding: 0 16px;
        }
    }


    .parenting-lp-ttl {
        font-size: 42px;
        font-weight: 700;
        color: #008d43;
        padding-left: 40px;
        border-left: 12px solid #008d43;
    }

    @media screen and (max-width: 1000px) {
        .parenting-lp-ttl {
            padding-left: 16px;
        }
    }

    @media screen and (max-width: 600px) {
        .parenting-lp-ttl {
            font-size: 32px;
        }
    }

    /* ------共通設定------ */

    /* ハンバーガーメニュー */
    /* ハンバーガーは前のまま */
    .parenting-lp__hamburger {
        position: absolute;
        top: 0px;
        right: 8px;
        width: 48px;
        height: 48px;
        border: 0;
        background: transparent;
        padding: 0;
        cursor: pointer;
        z-index: 1001;
    }

    .parenting-lp__hamburger span {
        position: absolute;
        left: 50%;
        width: 40px;
        height: 4px;
        background: #008d43;
        border-radius: 999px;
        transform: translateX(-50%);
        transition: transform .25s ease, opacity .25s ease, top .25s ease;
    }

    .parenting-lp__hamburger span:nth-child(1) {
        top: 16px;
    }

    .parenting-lp__hamburger span:nth-child(2) {
        top: 26px;
    }

    .parenting-lp__hamburger span:nth-child(3) {
        top: 36px;
    }

    .parenting-lp__hamburger.is-open span:nth-child(1) {
        top: 26px;
        transform: translateX(-50%) rotate(45deg);
    }

    .parenting-lp__hamburger.is-open span:nth-child(2) {
        opacity: 0;
    }

    .parenting-lp__hamburger.is-open span:nth-child(3) {
        top: 26px;
        transform: translateX(-50%) rotate(-45deg);
    }

    .parenting-lp__drawer {
        position: fixed;
        inset: 0;
        background: rgba(0, 0, 0, .35);
        opacity: 0;
        pointer-events: none;
        transition: opacity .25s ease;
        z-index: 1000;
    }

    .parenting-lp__drawer__inner {
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: auto;
        background: #fff;
    }

    .parenting-lp__drawer.is-open {
        opacity: 1;
        pointer-events: auto;
    }

    .parenting-lp__drawer__inner ul li {
        padding: 16px 0 16px 80px;
        border-bottom: 1px solid #000;
        color: #008d43;
        font-size: 48px;
        font-weight: 700;
        position: relative;
    }

    .parenting-lp__drawer__inner ul li::before {
        content: '';
        display: inline-block;
        width: 48px;
        height: 48px;
        background-image: url("/man/file/html/1042455.png");
        background-size: contain;
        background-repeat: no-repeat;
        position: absolute;
        top: 60%;
        left: 24px;
        transform: translateY(-60%);
    }

    @media screen and (max-width: 600px) {
        .parenting-lp__drawer__inner ul li {
            padding: 16px 0 16px 48px;
            font-size: 24px;
        }

        .parenting-lp__drawer__inner ul li::before {
            width: 24px;
            height: 24px;
            left: 16px;
        }
    }




    /* ------メニュー------ */
    .parenting-lp__menu {
        /* position: relative; */
        display: none;
    }

    .parenting-lp__menu ul {
        display: flex;
        justify-content: center;
        width: 100%;
        padding-top: 40px;
        gap: 40px;
    }

    .parenting-lp__menu ul li {
        font-size: 18px;
        color: #008d43;
        font-weight: 600;
        width: 25%;
        text-align: center;
        border-bottom: 10px solid #d0b0c2;
        padding-bottom: 8px;
    }

    .parenting-lp__menu ul li :hover {
        opacity: .5;
        transition: opacity .5s ease;
    }

    .parenting-lp__menu ul li.first {
        border-color: #008d43;
    }

    .parenting-lp__menu ul li.third {
        border-color: #008d43;
    }

    .parenting-lp__menu ul li a {
        position: relative;
        text-decoration: none;
    }

    .parenting-lp__menu ul li a::before {
        content: '';
        display: inline-block;
        width: 18px;
        height: 18px;
        background-image: url("img/onp-icon.png");
        background-size: contain;
        background-repeat: no-repeat;
        position: absolute;
        position: absolute;
        top: 70%;
        transform: translateY(-70%);
        left: -24px;

    }

    @media screen and (max-width: 1440px) {
        .parenting-lp__menu__btn {
            max-width: 120px;
            top: 120px;
            right: 0px;

        }
    }

    @media screen and (max-width: 1000px) {
        .parenting-lp__menu {
            display: none;
        }
    }

    /* ------メニュー------ */

    /* 動画 */
    .parenting-lp__movie {
        position: relative;
        width: 100%;
        height: 90vh;
        overflow: hidden;
    }

    .parenting-lp__movie__cp {
        width: 100%;
        text-align: center;
        position: absolute;
        top: 24px;
        font-size: 18px;
        font-weight: 900;
        z-index: 99;
    }

    /* 背景ぼかし動画 */
    .parenting-lp__movie__bg {
        position: absolute;
        inset: 0;
        width: 100%;
        height: 100%;
        object-fit: cover;
        filter: blur(60px);
        transform: scale(1.3);
    }

    /* メイン動画 */
    .parenting-lp__movie__video {
        position: relative;
        width: 100%;
        height: 100%;
        object-fit: contain;
        object-position: top center;
    }

    .parenting-lp__movie__soundToggle {
        position: absolute;
        left: 80px;
        bottom: 40px;
        width: 80px;
    }

    @media screen and (max-width: 1000px) {
        .parenting-lp__movie {
            height: auto;
        }

        .parenting-lp__movie__soundToggle {
            left: 40px;
        }


        .parenting-lp__movie__cp {
            font-size: 16px;
        }
    }

    /* ------最初の動画------ */
    .parenting-lp__cp {
        padding-top: 80px;
    }

    .parenting-lp__cp__img {
        max-width: 580px;
        margin: 0 auto;
    }

    .parenting-lp__cp__img02 {
        padding-top: 80px;
    }

    .parenting-lp__cp__text01 {
        padding-top: 36px;
        font-weight: 900;
        color: #000000;
        font-size: 34px;
        padding-bottom: 48px;
    }

    @media screen and (max-width: 1000px) {
        .parenting-lp__cp {
            padding-top: 48px;
        }

        .parenting-lp__cp__text01 {
            font-size: 18px;
        }
    }


    .parenting-lp__bg {
        position: relative;
        background-color: unset;
        overflow: hidden;
    }

    .parenting-lp__bg::before {
        width: 100%;
        height: 150%;
        content: '';
        top: -300px;
        position: absolute;
        z-index: -1;
        opacity: 0.7;
        background: repeating-linear-gradient(45deg,
                #a0d7e5 0px,
                #a0d7e5 7px,
                #ffffff 7px,
                #ffffff 15px,
                #fcdf99 15px,
                #fcdf99 22px,
                #ffffff 22px,
                #ffffff 30px);
    }


    /* ------キャンペーン概要------ */
    .parenting-lp__overview {
        padding-top: 16px;
    }

    .parenting-lp__overview__img {
        max-width: 580px;
        margin: 0 auto;
    }

    .parenting-lp__overview h2 {
        color: #008d43;
        margin-top: 88px;
        padding-left: 28px;
        border-left: 12px solid #008d43;
    }

    .parenting-lp__overview__sub {
        font-size: 24px;
        font-weight: bold;
        padding-top: 36px;
    }

    .parenting-lp__overview__text {
        font-size: 16px;
        font-weight: 600;
        margin-top: 40px;
        line-height: 2;
    }

    .parenting-lp__overview__text a {
        color: #0000ff;
    }


    @media (max-width: 1000px) {
        .parenting-lp__overview {
            padding-top: 0px;
        }

        .parenting-lp__overview h2 {
            font-size: 48px;
            padding-left: 16px;
        }

        .parenting-lp__overview__sub {
            font-size: 28px;
            padding-top: 40px;
        }

        .parenting-lp__overview__text {
            font-size: 24px;
            margin-top: 40px;
        }
    }

    @media screen and (max-width: 600px) {
        .parenting-lp__overview {}

        .parenting-lp__overview h2 {
            font-size: 32px;
            margin-top: 48px;
        }

        .parenting-lp__overview__sub {
            font-size: 22px;
        }

        .parenting-lp__overview__text {
            font-size: 18px;
            margin-top: 16px;
        }
    }


    /* ------応募条件------ */
    .parenting-lp__conditions {
        margin-top: 80px;
    }

    .parenting-lp__conditions ul {
        padding-top: 40px;
    }

    .parenting-lp__conditions ul li {
        font-size: 16px;
        padding-bottom: 8px;
    }

    .parenting-lp__conditions .policy {
        font-size: 16px;
        color: #0000ff;
        text-decoration: underline;
        font-weight: 700;
    }

    @media screen and (max-width: 1000px) {}

    @media screen and (max-width: 600px) {
        .parenting-lp__conditions ul {
            padding-top: 24px;
        }

        .parenting-lp__conditions ul li {
            font-size: 18px;
        }

        .parenting-lp__conditions .policy {
            font-size: 18px;
        }
    }



    /* ------応募期間------ */
    .parenting-lp__conditions__period {
        margin-top: 80px;
    }

    .parenting-lp__conditions__period .text {
        font-size: 28px;
        font-weight: bold;
        padding-top: 40px;
    }

    @media screen and (max-width: 600px) {
        .parenting-lp__conditions__period .text {
            font-size: 24px;
            padding-top: 24px;
            line-height: 2;
        }
    }

    /* 参加方法 */
    .parenting-lp__conditions__join {
        padding-top: 88px;
        line-height: 1.6;
    }

    .parenting-lp__conditions__join .step {
        display: block;
        width: fit-content;
        font-size: 28px;
        color: #008d43;
        padding-right: 40px;
        border-bottom: 2px solid #008d43;
        margin-bottom: 4px;
        padding-top: 40px;
    }

    .parenting-lp__conditions__join .step01 {
        padding-top: 40px;
    }

    .parenting-lp__conditions__join a {
        color: #0000ff;
    }

    .parenting-lp__conditions__join .folow,
    .parenting-lp__conditions__join .repost {
        font-size: 1.5em;
        font-weight: bold;
    }

    .parenting-lp__conditions__join .insta {
        max-width: 580px;
        margin: 0 auto;
        padding-top: 80px;
        text-align: center;
    }

    @media screen and (max-width: 1000px) {
        .parenting-lp__conditions__join .step {
            font-size: 24px;
        }

        .parenting-lp__conditions__join .folow,
        .parenting-lp__conditions__join .repost {
            font-size: 1.2em;
        }
    }

    /* 参加方法 */

    /* ------賞品------ */
    .parenting-lp__conditions__goods {
        margin-top: 80px;
    }

    .parenting-lp__conditions__goods .present {
        padding-top: 24px;
        font-size: 28px;
        font-weight: 700;
    }

    .parenting-lp__conditions__goods .present span {
        color: #ff888e;
    }

    .parenting-lp__conditions__goods .present span.num {
        color: #ff888e;
    }

    .parenting-lp__conditions__goods .text {
        font-size: 16px;
        line-height: 2;
        padding: 40px 0;
    }

    .parenting-lp__conditions__goods .img {
        padding-top: 16px;
    }

    .parenting-lp__conditions__goods .img02 {
        max-width: 580px;
        margin: 0 auto;
        padding-top: 80px;
    }

    .parenting-lp__episode {
        padding-top: 88px;
    }

    .parenting-lp__episode .img {
        max-width: 580px;
        margin: 0 auto;
    }

    .parenting-lp__episode .text {
        font-size: 18px;
        padding-top: 40px;
        padding-bottom: 40px;
    }

    .parenting-lp__episode .goods-box {
        width: 100%;
        margin: 0 auto;
        padding: 36px 24px;
        background: #fff8d8;
        border: 4px solid #f0d49c;
        border-radius: 8px;
        box-sizing: border-box;
        margin-top: 24px;
    }

    .parenting-lp__episode .goods-box h2 {
        margin: 0 0 30px;
        text-align: center;
        font-size: 24px;
        line-height: 1.25;
        font-weight: 900;
    }

    .parenting-lp__episode .goods-box p {
        margin: 0;
        font-size: 18px;
        line-height: 1.9;
    }


    .parenting-lp__episode .goods-box h2 span {
        box-shadow: inset 0 -0.55em 0 #f0d49c;
        -webkit-box-decoration-break: clone;
        box-decoration-break: clone;
    }

    .parenting-lp__episode .img02 {
        max-width: 400px;
        margin: 0 auto;
        padding-top: 40px;
    }

    .parenting-lp__episode .video {
        padding-top: 48px;
        max-width: 100%;
        aspect-ratio: 4 / 3;
    }

    .parenting-lp__episode .video iframe {
        width: 100%;
        height: 100%;
    }

    .parenting-lp__episode .video video {
        width: 100%;
        height: auto;
        aspect-ratio: 16 / 9;
    }


    @media screen and (max-width: 600px) {
        .parenting-lp__episode {
            padding-top: 40px;
        }

        .parenting-lp__conditions__goods .present {
            padding-top: 24px;
            font-size: 24px;
        }

        .parenting-lp__conditions__goods .text {
            font-size: 18px;
        }
    }

    .parenting-lp__external {
        padding-top: 88px;
    }

    .parenting-lp__external h2 {
        display: block;
        text-align: center;
        background-color: #d066a2;
        color: #fff;
        padding: 24px 8px;
    }

    .parenting-lp__external .parenting-lp__external__content {
        display: flex;
        align-items: center;
        justify-content: space-between;
        margin-top: 24px;
    }

    .parenting-lp__external .parenting-lp__external__content .box {
        width: 48%;
        text-align: center;

    }

    .parenting-lp__external .parenting-lp__external__content .box h3 {
        line-height: 1.6;
    }

    .parenting-lp__external .parenting-lp__external__content .box iframe {
        width: 100%;
        aspect-ratio: 16 / 9;
        height: auto;
    }

    @media screen and (max-width: 1000px) {
        .parenting-lp__external h2 {
            font-size: 20px;
            line-height: 1.6;
        }

        .parenting-lp__external .parenting-lp__external__content {
            display: block;
        }

        .parenting-lp__external .parenting-lp__external__content .box {
            width: 100%;
            margin-bottom: 24px;
        }
    }


    /* ------LINK------ */
    .parenting-lp__link {
        padding-top: 80px;
        padding-bottom: 80px;
    }

    .parenting-lp__link h2 {
        text-align: center;
        font-size: 40px;
    }

    .parenting-lp__link .main {
        max-width: 220px;
        margin: 0 auto;
        margin-top: 40px;
    }



    @media (max-width: 1000px) {
        .parenting-lp__link {
            padding-bottom: 40px;
        }
    }

    @media (max-width: 600px) {
        .parenting-lp__link h2 {
            font-size: 28px;
        }
    }


    /* ------フッター------ */
    .parenting-lp__footer {
        background: #eeeeee;
        padding-top: 48px;
        padding-bottom: 40px;
        margin-top: 0 !important;
    }

    .parenting-lp__footer__sns {
        display: flex;
        max-width: 580px;
        gap: 120px;
        margin: 0 auto;
        align-items: center;
    }

    .parenting-lp__footer__sns img {
        object-fit: contain;
    }

    .parenting-lp__footer__sns img:hover {
        transition: opacity .5s ease;
        opacity: .5;
    }

    .parenting-lp__footer__info {
        margin-top: 120px;
        text-align: center;
    }

    .parenting-lp__footer__info .img {
        max-width: 340px;
        margin: 0 auto;
    }

    .parenting-lp__footer__info .text {
        font-size: 18px;
        font-weight: 600;
        padding-top: 48px;

    }

    .parenting-lp__footer__btn {
        background-color: #008d43;
        padding: 8px;
        position: fixed;
        left: 0;
        bottom: 0;
        width: 100%;
    }

    .parenting-lp__footer__btn a {
        display: block;
        text-align: center;
        color: #fff;
        border: 1px solid #fff;
        font-size: 40px;
        font-weight: bold;
        letter-spacing: 8px;
    }

    @media screen and (max-width: 1000px) {
        .parenting-lp__footer {
            padding: 48px 16px 120px 16px;
        }

        .parenting-lp__footer__sns {
            gap: 40px;
        }

        .parenting-lp__footer__info {
            display: block;
            width: fit-content;
            margin: 0 auto;
            margin-top: 48px;
        }

        .parenting-lp__footer__info .img {
            margin: 0 auto;
        }

        .parenting-lp__footer__info .text {
            font-size: 24px;
            margin-top: 40px;
        }
    }

    @media screen and (max-width: 600px) {
        .parenting-lp__footer {
            padding: 48px 40px 80px 40px;
        }

        .parenting-lp__footer__info .text {
            font-size: 18px;
        }

        .parenting-lp__footer__btn a {
            font-size: 24px;
        }

        .parenting-lp__footer__sns {
            max-width: 320px;
            gap: 72px;
        }
    }
}