/***********************************************************************
    「★PC版 CSS★」ブラウザの幅が751px以上ならここの記述が有効になる
  **********************************************************************/
@media all and (min-width: 751px) {

    /* =========================
    ベース
========================= */
    .tenbo_wrapper {
        background: url(../images/tenbo_bg_pc.png) no-repeat top;
        width: 1920px;
        position: relative;
        margin-top: 0;
        height: 4897px;
    }

    .tenbo_area {
        padding: 183px 0 0;
    }

    .tenbo_tit {
        background: url(../images/tenbo_tit.png) no-repeat center;
        background-size: cover;
        width: 760px;
        height: 190px;
        margin: 0 auto;
    }

    .tenbo_read p {
        font-size: 18px;
        width: 960px;
        line-height: 33px;
        margin: 16px auto;
        text-align: center;
        position: relative;
        font-weight: 600;
    }

    .tenbo_read::before {
        content: '';
        position: absolute;
        top: 371px;
        left: 50%;
        transform: translateX(-50%);
        width: 1030px;
        height: 200px;
        background-image: url(../images/tenbo_kazari_pc.svg);
        background-size: contain;
        background-repeat: no-repeat;
    }

    .tenbo_con {
        height: 3000px;
        position: relative;
        padding: 32px 235px;
    }

    /* 共通：コンテンツブロック（01〜03） */
    .tenbo_con01,
    .tenbo_con02,
    .tenbo_con03 {
        display: flex;
        width: 100%;
        justify-content: space-between;
    }

    /* 02だけ左右反転＋位置微調整 */
    .tenbo_con02 {
        flex-direction: row-reverse;
        margin-top: -17px;
    }

    /* 共通：画像ボックス */
    .tenbo_01pic,
    .tenbo_02pic,
    .tenbo_03pic {
        background-repeat: no-repeat;
        background-position: center;
        background-size: cover;
        position: relative;
    }

    /* 個別：画像ボックス */
    .tenbo_01pic {
        background-image: url(../images/tenbo_10_pc.png);
        width: 555px;
        height: 460px;
    }

    .tenbo_02pic {
        background-image: url(../images/tenbo_8_pc.png);
        width: 550px;
        height: 438px;
    }

    .tenbo_03pic {
        background-image: url(../images/tenbo_21_pc.png);
        width: 567px;
        height: 460px;
    }

    /* 共通：テキストコンテナ */
    .tenbo_01text,
    .tenbo_02text,
    .tenbo_03text {
        width: 848px;
        position: relative;
    }

    /* 共通：テキストボックス本体 */
    .tenbo_01text p,
    .tenbo_02text p,
    .tenbo_03text p {
        font-size: 18px;
        padding: 37px;
        border: solid 3px;
        margin: 80px 0;
        background: #fff;
        border-radius: 19px;
        line-height: 32.6px;
        font-weight: 600;
        z-index: 1;
        position: relative;
        text-decoration: underline;
        text-decoration-style: dashed;
        text-decoration-thickness: 2px;
        text-underline-offset: 7px;
    }

    /* 個別：テキストボックスの装飾色とマージン差分 */
    .tenbo_01text p {
        text-decoration-color: #FFB1C3;
    }

    .tenbo_02text p {
        text-decoration-color: #CA96FF;
        margin: 72px 0;
    }

    .tenbo_03text p {
        text-decoration-color: #B2E000;
        margin: 100px 0;
    }

    /* 共通：画像の下に引くピンクライン */
    .tenbo_01pic::before,
    .tenbo_02pic::before,
    .tenbo_03pic::before {
        content: "";
        position: absolute;
        background: url(../images/tenbo_pinkline.svg) no-repeat center / cover;
        width: 1575px;
        height: 28px;
    }

    /* 個別：ピンクラインの位置 */
    .tenbo_01pic::before {
        left: -1028px;
        top: 479px;
    }

    .tenbo_02pic::before {
        right: -1027px;
        top: 450px;
    }

    .tenbo_03pic::before {
        left: -1022px;
        top: 470px;
    }

    /* 共通：下側グラデボーダー（::after） */
    .tenbo_01text::after,
    .tenbo_02text::after,
    .tenbo_03text::after {
        content: "";
        position: absolute;
        border-radius: 19px;
        width: 845px;
        border: solid 3px;
        height: 4%;
        background-image: linear-gradient(90deg, #49fff3, #c8b8ff 44%, #ff5fbb);
    }

    /* 個別：下側グラデボーダーの位置と影 */
    .tenbo_01text::after {
        bottom: 65px;
        right: -1px;
        filter: drop-shadow(0px 10px 0px rgba(0, 0, 0, 0.2));
    }

    .tenbo_02text::after {
        bottom: 56px;
        right: -1px;
        filter: drop-shadow(0px 16px 0px rgba(0, 0, 0, 0.2));
    }

    .tenbo_03text::after {
        bottom: 85px;
        right: -1px;
        filter: drop-shadow(0px 15px 0px rgba(0, 0, 0, 0.2));
    }

    /* 共通：吹き出し系 ::before のベース */
    .tenbo_01text::before,
    .tenbo_02text::before,
    .tenbo_03text::before {
        content: "";
        position: absolute;
    }

    /* 個別：吹き出し画像と位置 */
    .tenbo_01text::before {
        top: 33px;
        background: url(../images/tenbo_huki_left.svg);
        width: 982px;
        height: 303px;
        left: -81px;
    }

    .tenbo_02text::before {
        top: 23px;
        background: url(../images/tenbo_huki_right.svg);
        width: 974px;
        height: 295px;
        left: -48px;
    }

    .tenbo_03text::before {
        top: 46px;
        background: url(../images/tenbo_huki_left.svg);
        width: 982px;
        height: 303px;
        left: -78px;
    }

    /* 強調用 span の色 */
    .tenbo_01text p span {
        color: #FF4E77;
    }

    .tenbo_02text p span {
        color: #6242FF;
    }

    .tenbo_03text p span {
        color: #71BC00;
    }
    
    .tenbo_line {
    position: relative;
}

}

/***********************************************************************
    「★SP版 CSS★」ブラウザの幅が750px以下ならここの記述が有効になる
  **********************************************************************/
@media only all and (max-width: 750px) {


    /* =========================
    ベース
========================= */
    .tenbo_wrapper {
        background: url(../images/tenbo_bg_sp.png) no-repeat top;
        width: 750px;
        position: relative;
        height: 13236px;
    }

    .tenbo_area {
        padding: 61px 0 0;
    }

    .tenbo_tit {
        background: url(../images/tenbo_tit.png) no-repeat center;
        background-size: cover;
        width: 771px;
        height: 230px;
        margin: 0 auto;
    }

    .tenbo_read p {
        font-size: 27px;
        width: 620px;
        line-height: 46px;
        margin: 17px auto -4px;
        text-align: center;
        position: relative;
        font-weight: 600;
    }

    .tenbo_read::before {
        content: '';
        position: absolute;
        top: 295px;
        left: 50%;
        transform: translateX(-50%);
        width: 667px;
        height: 548px;
        background-image: url(../images/tenbo_kazari_sp.svg);
        background-size: cover;
        background-repeat: no-repeat;
    }

    .tenbo_con {
        height: 3000px;
        position: relative;
        padding: 22px 21px;
    }

    /* 共通：コンテンツブロック（01〜03） */
    .tenbo_con01,
    .tenbo_con02,
    .tenbo_con03 {
        display: flex;
        width: 100%;
        justify-content: space-between;
        flex-direction: column;
        align-items: center;
    }

    /* 02だけ左右反転＋位置微調整 */
    .tenbo_con02 {
        margin-top: 22px;
    }

    .tenbo_con03 {
        margin-top: 30px;
    }

    /* 共通：画像ボックス */
    .tenbo_01pic,
    .tenbo_02pic,
    .tenbo_03pic {
        background-repeat: no-repeat;
        background-position: center;
        background-size: cover;
        z-index: 1;
    }

    /* 個別：画像ボックス */
    .tenbo_01pic {
        background-image: url(../images/tenbo_10_sp.png);
        width: 695px;
        height: 618px;
    }

    .tenbo_02pic {
        background-image: url(../images/tenbo_8_sp.png);
        width: 710px;
        height: 632px;
    }

    .tenbo_03pic {
        background-image: url(../images/tenbo_21_sp.png);
        width: 705px;
        height: 628px;
    }

    /* 共通：テキストコンテナ */
    .tenbo_01text,
    .tenbo_02text,
    .tenbo_03text {
        width: 705px;
        position: relative;
    }

    /* 共通：テキストボックス本体 */
    .tenbo_01text p,
    .tenbo_02text p,
    .tenbo_03text p {
        font-size: 28px;
        padding: 34px;
        border: solid 3px;
        margin: 58px 0;
        background: #fff;
        border-radius: 19px;
        line-height: 48.9px;
        font-weight: 600;
        z-index: 1;
        position: relative;
        text-decoration: underline;
        text-decoration-style: dashed;
        text-decoration-thickness: 2px;
        text-underline-offset: 7px;
    }

    /* 個別：テキストボックスの装飾色とマージン差分 */
    .tenbo_01text p {
        text-decoration-color: #FFB1C3;
    }

    .tenbo_02text p {
        text-decoration-color: #CA96FF;
        margin: 54px 0;
    }

    .tenbo_03text p {
        text-decoration-color: #B2E000;
        margin: 54px 0 50px 0;
    }

    .tenbo_line {
        position: relative;
    }

    /* 共通：画像の下に引くピンクライン */
    .tenbo_line::before,
    .tenbo_line::before,
    .tenbo_line::before {
        content: "";
        position: absolute;
        background: url(../images/tenbo_pinkline.svg) no-repeat center / cover;
        width: 1469px;
        height: 26px;
        top: -8px;
    }

    /* 個別：ピンクラインの位置 */
    .tenbo_01pic::before {
        left: -271px;
        top: 499px;
    }

    .tenbo_02pic::before {
        right: -278px;
        top: 2043px;
    }

    .tenbo_03pic::before {
        left: -271px;
        top: 3232px;
    }

    /* 共通：下側グラデボーダー（::after） */
    .tenbo_01text::after,
    .tenbo_02text::after,
    .tenbo_03text::after {
        content: "";
        position: absolute;
        border-radius: 19px;
        width: 699px;
        border: solid 3px;
        height: 4%;
        background-image: linear-gradient(90deg, #49fff3, #c8b8ff 44%, #ff5fbb);
    }

    /* 個別：下側グラデボーダーの位置と影 */
    .tenbo_01text::after {
        bottom: 37px;
        right: 1px;
        filter: drop-shadow(0px 10px 0px rgba(0, 0, 0, 0.2));
    }

    .tenbo_02text::after {
        bottom: 33px;
        filter: drop-shadow(0px 16px 0px rgba(0, 0, 0, 0.2));
    }

    .tenbo_03text::after {
        bottom: 29px;
        filter: drop-shadow(0px 15px 0px rgba(0, 0, 0, 0.2));
    }

    /* 共通：吹き出し系 ::before のベース */
    .tenbo_01text::before,
    .tenbo_02text::before,
    .tenbo_03text::before {
        content: "";
        position: absolute;
    }

    /* 個別：吹き出し画像と位置 */
    .tenbo_01text::before {
        top: -34px;
        background: url(../images/tenbo_huki_sp.svg);
        width: 769px;
        height: 179px;
        left: -59px;
    }

    .tenbo_02text::before {
        top: -40px;
        background: url(../images/tenbo_huki_sp.svg);
        width: 769px;
        height: 179px;
        left: -60px;
    }

    .tenbo_03text::before {
        top: -40px;
        background: url(../images/tenbo_huki_sp.svg);
        width: 769px;
        height: 179px;
        left: -57px;
    }


    /* 強調用 span の色 */
    .tenbo_01text p span {
        color: #FF4E77;
    }

    .tenbo_02text p span {
        color: #6242FF;
    }

    .tenbo_03text p span {
        color: #71BC00;
    }

}