@charset "utf-8";
@media screen and (max-width: 960px) {
    /* 下層ページ */
    .div-lead {
        .lead-img {
            width: 100%;
            text-align: center;
            img {
                width: 640px;
            }
        }
        .lead-text {
            width: 100%;
            padding: 10px;
        }
    }
    .shorts-slide {
        flex-direction: column;
    }
    .super-heading {
        font-size: 2.8rem;
    }


    .beauty-list-container {
        ol {
            width: 50%;
            padding-inline: 20px;
        }
    }

    /* tabサイズで画像の回り込みを解消するクラス　br-tab */
    .alignleft.br-tab,
    .alignright.br-tab {
        float: none;
        display: block;
        max-width: 100%;
        margin: 0;
    }

    .alignleft.br-tab::after,
    .alignright.br-tab::after {
        content: "\A";
        white-space: pre;
    }

    /* tabサイズで中央配置にする　tab-center */
    .tab-center,
    img.alignleft.tab-center,
    img.alignright.tab-center {
        float: none;
        display: block;
        margin: 0 auto;
    }

    /* コンテナ */
    .container,
    .container-wide,
    .container-nallow {
        padding: 0 10px;
    }

    /* グリッド */
    .sp-1 {
        display: grid;
        grid-template-columns: 1fr;
    }

    .sp-2 {
        display: grid;
        grid-template-columns: 1fr 1fr;
    }

    .pc-6,
    .pc-5,
    .pc-4 {
        display: grid;
        grid-template-columns: 1fr 1fr 1fr;
    }

    .sp-2,
    .tab-2,
    .pc-3,
    .pc-2 {
        display: grid;
        grid-template-columns: 1fr 1fr;
    }

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

    .tab-1 {
        display: grid;
        grid-template-columns: 1fr;
    }

    .col-11, .col-10, .col-9 {
        width: 75%;
    }
    .col-8, .col-7 {
        width: 66.6666%;
    }
    .col-6 {
        width: 50%;
    }
    .col-5, .col-4 {
        width: 33.3333%;
    }
    .col-3, .col-2, .col-1 {
        width: 25%;
    }

    .col-6-7, .col-5-7 {
        width: 75%;
    }
    .col-4-7, .col-3-7 {
        width: 50%;
    }
    .col-2-7, .col-1-7 {
        width: 25%;
    }

    .col-4-5 {
        width: 80%;
    }
    .col-3-5 {
        width: 60%;
    }
    .col-2-5 {
        width: 40%;
    }
    .col-1-5 {
        width: 20%;
    }

    .col-tab-12 {
        width: 100%;
    }
    .col-tab-11 {
        width: 91.6666%;
    }
    .col-tab-10 {
        width: 83.3333%;
    }
    .col-tab-9 {
        width: 75%;
    }
    .col-tab-8 {
        width: 66.6666%;
    }
    .col-tab-7 {
        width: 58.3333%;
    }
    .col-tab-6 {
        width: 50%;
    }
    .col-tab-5 {
        width: 41.6666%;
    }
    .col-tab-4 {
        width: 33.3333%;
    }
    .col-tab-3 {
        width: 25%;
    }
    .col-tab-2 {
        width: 16.6666%;
    }
    .col-tab-1 {
        width: 8.3333%;
    }
    .col-tab-6-7 {
        width: 85.7142%;
    }
    .col-tab-5-7 {
        width: 71.4285%;
    }
    .col-tab-4-7 {
        width: 57.1428%;
    }
    .col-tab-3-7 {
        width: 42.8571%;
    }
    .col-tab-2-7 {
        width: 28.5714%;
    }
    .col-tab-1-7 {
        width: 14.2857%;
    }
    .col-tab-4-5 {
        width: 80%;
    }
    .col-tab-3-5 {
        width: 60%;
    }
    .col-tab-2-5 {
        width: 40%;
    }
    .col-tab-1-5 {
        width: 20%;
    }

    /* utility */
    
    .pd-tab-0 {
        padding: 0px;
    }
    .pd-tab-5 {
        padding: 5px;
    }
    .pd-tab-10 {
        padding: 10px;
    }
    .pd-tab-15 {
        padding: 15px;
    }
    .pd-tab-20 {
        padding: 20px;
    }
    .pi-tab-0 {
        padding-inline: 0px;
    }
    .pi-tab-5 {
        padding-inline: 5px;
    }
    .pi-tab-10 {
        padding-inline: 10px;
    }
    .pi-tab-15 {
        padding-inline: 15px;
    }
    .pi-tab-20 {
        padding-inline: 20px;
    }
    
    .gap-0 {
        gap: 0px;
    }

    .gap-pc-0 {
        gap: 0px;
    }

    .gap-10 {
        gap: 5px;
    }

    .gap-pc-10 {
        gap: 5px;
    }

    .gap-20 {
        gap: 10px;
    }

    .gap-pc-20 {
        gap: 10px;
    }

    .gap-30 {
        gap: 15px;
    }

    .gap-pc-30 {
        gap: 15px;
    }

    .gap-40 {
        gap: 20px;
    }

    .gap-pc-40 {
        gap: 20px;
    }

    .gap-50 {
        gap: 25px;
    }

    .gap-pc-50 {
        gap: 25px;
    }

    .gap-60 {
        gap: 30px;
    }

    .gap-pc-60 {
        gap: 30px;
    }

    .gap-tab-0 {
        gap: 0px;
    }

    .gap-tab-10 {
        gap: 10px;
    }

    .gap-tab-20 {
        gap: 20px;
    }

    .gap-tab-30 {
        gap: 30px;
    }

    /* ヘッダー     */

    .header-container {
        position: relative;
        z-index: 100;
        height: var(--burg-btn-size);
        display: block;
   }
    .toggle-menu {
        position: absolute;
        right: 0;
        background-color: #FFF;
        max-height: calc(100vh - var(--burg-btn-size));
        overflow-y: scroll;
        overflow-x: hidden;
        width: 0px;
        flex-direction: column;
        justify-content: flex-start;
        align-items: flex-start;
    }

    .toggle-menu .sub-menu {
        height: auto;
        overflow: hidden;
        position: static;
        width: 100%;
    }

    :where(nav) li {
        width: auto;
        margin-right: .6rem;
    }

    .toggle-menu a {
        display: block;
        padding: 1em 10px;
        width: 100%;
    }
    .toggle-menu a[href="#null"] {
        display: none;
    }
    .hamburger {
        display: block;
        width: var(--burg-btn-size);
        height: var(--burg-btn-size);
    }

    .js-open .toggle-menu {
        width: auto;
    }

    .header-logo {
        display: inline-block;
        height: 44px;
        background-color: rgb(255 255 255/0.75);
        border-radius: 3px;
    }

    /* セクションレイアウト */

    .sidebar {
        width: 100%;
        padding: 0;
    }

    .main,
    .top-main {
        width: 100%;
    }

    /* ユーティリティクラス */
    .pc,
    .pc-inline,
    .sp,
    .sp-inline {
        display: none;
    }

    .tab {
        display: block;
    }

    .tab-inline {
        display: inline;
    }
    /* オリジナル Tablet css */
    .top-btn {
        text-align: center;
    }
    /* header */

    .header-logo {
        width: 7.4rem;
        margin-top: .5rem;
        margin-left: 5%;
    }
    .header nav {
        background: none;
        width: auto;
        clip-path: none;
        padding-top: 0rem;
        border-bottom-left-radius: 0 0;
    }
    /* header end */
    .top-kv {
        padding-top: 0;
        margin-top: -3.8rem;
        margin-bottom: 0;
        position: relative;
    }
    .top-kv .kv-right,
    .top-kv .kv-center,
    .top-kv .kv-left {
        top: 12rem;
    }
    .top-kv .kv-right {
        right: 5%;
        width: 2.5rem;
        left: auto;
    }
    .top-kv .kv-center {
        left: 15%;
        width: 3.5rem;
    }
    .top-kv .kv-left {
        left: 8%;
        width: 3.5rem;
        top: 32rem;
    }
    /* infomation */
    .infomation {
        background: url(../images/pc/info_bg_img.png) top -15rem left no-repeat, #69acf7;
        background-size: cover;
        padding-top: 2.1rem;
        padding-bottom: 6rem;
        position: relative;
    }
    .infomation::before {
        width: 25%;
        height: 6rem;
        top: -4.5rem;
        right: 0.3%;
    }
    .infomation::after {
        width: 15%;
        height: 14%;
        top: -1.6rem;
        right: 21.5%;
    }
    .infomation .post-list-title {
        padding-top: 2.4rem;
        margin-top: 0;
        margin-bottom: 2rem;
        color: #fff;
        font-size: .9rem;
        text-align: center;
        letter-spacing: .2rem;
    }
    .infomation .container {
        height: 20rem;
        margin-left: 19%;
        padding: 2.3rem 0 2.3rem 11%;
        width: auto;
        background: rgba(10, 109, 217, .8);
        position: relative;
    }
    .infomation .post-list-item {
        padding-left: 0;
        margin-bottom: 1.3rem;
        padding-top: 0;
    }
    .infomation .post-date {
        color: rgba(222, 237, 23, 1);
        display: block;
    }
    .infomation .detail-btn {
        position: absolute;
        bottom: -4.2rem;
        right: 12%;
        margin-right: 0;
    }
    .infomation .detail-btn .button-link-accent {
        font-size: .9rem;
        position: relative;
        padding: 1rem 2.5rem;
        margin-right: 0.9rem;
        letter-spacing: .2rem;
        margin-top: 0px;
        width: 11.5rem;
    }
    /* infomation end */
    /* cont-1 */
    .cont-1 {
        background: #e3e8ed;
        padding-top: 3.2rem;
        padding-bottom: 2.9rem;
    }
    .cont-1::after {
        width: 45%;
        height: 13rem;
        bottom: 3.1rem;
        right: 2.3rem; 
    }
    .cont-1 h2 {
        background-size: 30%;
        padding-top: 5rem;
        font-size: 1rem;
        margin-bottom: 2rem;
        letter-spacing: .1rem;
    }
    .cont-1 .flex {
        flex-direction: column;
    }
    .cont-1 .cont-1-text p {
        margin: 0 0 2rem;
        font-size: 1.2rem;
        line-height: 1.5;
        letter-spacing: .08rem;
    }
    .cont-1 .cont-1-text {
        width: 87%;
        margin: 0 auto 2rem;
    }
    .cont-1 .cont-1-photo {
        width: 90%;
        margin: 0 auto;
    }
    .cont-1 .photo-1 {
        width: 100%;
    }
    .cont-1 .photo-2 {
        width: 50%;
    }
    /* cont-1 end */
    /* cont-2 */
    .cont-2 {
        padding-bottom: 3.4rem;
    }
    .cont-2::before {
        width: 20.5%;
        height: 8rem;
        top: 0.3rem;
        left: 80%;
    }
    .cont-2::after {
        width: 10.5%;
        height: 3rem;
        position: absolute;
        top: -2rem;
        left: 73%;
    }
    .cont-2 h2 {
        background-size: 35%;
        padding-top: 4.2rem;
        font-size: 1rem;
        letter-spacing: .1rem;
        margin-bottom: 1.5rem;
    }
    .cont-2 .flex {
        padding: 0 0rem;
        gap: 1rem .96rem;
    }
    .cont-2 .col-4 {
        width: 47%;
        height: 4.5rem;
        padding-left: 6.5rem;
    }
    /* cont-2 end */
    /* cont-3 */
    .cont-3 {
        background-color: rgba(199, 189, 177, 1);
        background-image: none;
        padding-bottom: 3rem;
        padding-top: 3rem;
        position: initial;
    }
    .cont-3 .cont-3-position {
        position: initial;
    }
    .cont-3 h2 {
        font-size: 1.55rem;
        background: url(../images/pc/shorts_icon_l.png) top -1rem center no-repeat;
        background-size: 19%;
        margin: 0 auto;
        padding-top: 6rem;
        padding-bottom: 0;
        letter-spacing: .18rem;
        line-height: 1;
    }
    .cont-3 .flex {
        padding-left: 10px;
        gap: 0rem;
    }
    .cont-3 .cont-3-1 {
        width: 100%;
    }
    .cont-3 .cont-3-1 h3 {
        font-size: 1.5rem;
        letter-spacing: .12rem;
        margin-bottom: .5rem;
        text-align: center;
    }
    .cont-3 .cont-3-1 p {
        font-size: 1.1rem;
        line-height: 1.8;
        margin: 0 5% 2.2rem;
    }
    .cont-3 .cont-3-1 .sp {
        margin: 0 5%;
    }
    .cont-3 .cont-3-1 a {
        font-size: 1.1rem;
        border-radius: 30px;
        padding: 1.2rem 3.8rem;
        letter-spacing: .2rem;
        margin: 1.5rem auto 0;
    }
    .cont-3 .cont-3-2 {
        width: 100%;
        margin: 0 4%;
    }
    /* cont-3 end */
    /* cont-4 */
    .cont-4 {
        padding-top: 11rem;
        padding-bottom: 3.5rem;
    }
    .cont-4 h2 {
        font-size: 1.55rem;
        letter-spacing: .2rem;
        margin: 0 auto .8rem;
    }
    .cont-4 h2::after {
        top: -9.8rem;
        right: 40%;
        width: 8.9rem;
        height: 10rem;
    }
    .cont-4 .flex {
        padding: 0 6.5%;
    }
    .cont-4 .cont-4-1 {
        width: 100%;
        margin-top: 2.6rem;
    }
    .cont-4 .cont-4-2 {
        width: auto;
        margin: 0 0;
    }
    .cont-4 .cont-4-2 h3 {
        text-align: center;
        font-size: 1.5rem;
        letter-spacing: .17rem;
        line-height: 1.45;
        margin: 0 5% 1.3rem;
    }
    .cont-4 .cont-4-2 p {
        font-size: 1.1rem;
        line-height: 1.8;
        margin-bottom: .0rem;
    }
    .cont-4 .cont-4-2 a {
        font-size: 1.1rem;
        border-radius: 30px;
        padding: 1.2rem 3.8rem;
        letter-spacing: .2rem;
        margin: 1.5rem auto 0;
    }
    /* cont-4 end*/
    /* cont-5 */
    .cont-5 {
    padding-top: 9.1rem;
        padding-bottom: 1.9rem;
    }
    .cont-5::before {
        width: 26%;
        height: 6.5rem;
        top: -2.2rem;
        left: 5%; 
    }
    .cont-5 h2 {
        font-size: 1.55rem;
        margin: 0 auto 1rem;
    }
    .cont-5 h2::after {
        top: -6.7rem;
        left: 44%;
        width: 14.5%;
        height: 5rem;
    }
    .cont-5 .flex {
        padding: 0;
        gap: 0;
    }
    .cont-5 .cont-5-1 {
        width: auto;
        padding-top: 0;
        margin: 0 6%;
    }
    .cont-5 .cont-5-1 h3 {
        text-align: center;
        font-size: 1.55rem;
        margin: 0 auto 1.7rem;
    }
    .cont-5 .cont-5-1 p {
        font-size: 1.1rem;
        line-height: 1.8;
    }
    .cont-5 .cont-5-2 {
        width: auto;
        margin-top: 1.7rem;
    }
    .cont-5 .cont-5-1 a {
        font-size: 1.1rem;
        border-radius: 30px;
        padding: 1.2rem 3.8rem;
        letter-spacing: .2rem;
        margin: 1.5rem auto 0;
    }
    /* cont-5 end*/
    /* cont-6 */
    .cont-6 {
        padding-top: 11.1rem;
        padding-bottom: 6.4rem;
    }
    .cont-6 h2 {
        font-size: 1.55rem;
        margin: 0px auto 1.3rem;
        letter-spacing: .2rem;
    }
    .cont-6 h2::after {
        top: -8rem;
        right: 32.3%;
        width: 35%;
        height: 6.5rem;
    }
    .cont-6 .flex {
        padding: 0;
        gap: 0rem;
        width: auto;
        margin: 0 5%;
    }
    .cont-6 .cont-6-1 {
        width: auto;
        margin-top: 2.4rem;
    }
    .cont-6 .cont-6-2 {
        width: auto;
        padding-top: 0;
    }
    .cont-6 .cont-6-2 h3 {
        font-size: 1.47rem;
        margin-bottom: 2rem;
        text-align: center;
    }
    .cont-6 .cont-6-2 p {
        font-size: 1.1rem;
        margin-bottom: .0rem;
        line-height: 1.7;
    }
    .cont-6 .cont-6-2 .sp-center {
        text-align: center;
    }
    .cont-6 .cont-6-2 a {
        font-size: 1.1rem;
        border-radius: 30px;
        padding: 1.2rem 3.8rem;
        letter-spacing: .2rem;
        margin: 1.5rem auto 0;
    }
    /* cont-6 end*/
    /* cont-7 */
    .cont-7 {
        padding-top: 4.8rem;
        padding-bottom: 2.8rem;
        overflow-x: clip;
    }
    .cont-7::before {
        width: 26%;
        height: 7rem;
        top: -4.5rem;
        right: -5.8%;
    }
    .cont-7::after {
        width: 15%;
        height: 4.5rem;
        top: -1.2rem;
        right: 14.5%;
    }
    .cont-7 h2 {
        font-size: 1.7rem;
        letter-spacing: .25rem;
        margin: 0 auto 2.2rem;
    }
    .cont-7 h2::after {
        top: -7.5rem;
        left: 39%;
        width: 19%;
        height: 7rem;
    }
    .cont-7 .flex {
        padding: 0;
        gap: 0;
    }
    .cont-7 .cont-7-1 {
        width: auto;
        margin: 0 5%;
    }
    .cont-7 .cont-7-1 h3 {
        text-align: center;
        font-size: 1.55rem;
        letter-spacing: .2rem;
        margin-bottom: 1rem;
    }
    .cont-7 .cont-7-1 p {
        font-size: 1.1rem;
        margin-bottom: 0;
        line-height: 1.55;
    }
    .cont-7 .cont-7-1 a {
        font-size: 1.1rem;
        border-radius: 30px;
        padding: 1.2rem 3.8rem;
        letter-spacing: .2rem;
        margin: 1.5rem auto 0;
    }
    .cont-7 .cont-7-2 {
        width: auto;
        margin-top: 4.4rem;
    }
    /* cont-7 end*/
    /* cont-8 */
    .cont-8 {
        padding-top: 11.3rem;
        padding-bottom: 4.8rem;
        overflow-x: clip;
    }
    .cont-8::before {
        width: 26%;
        height: 6.5rem;
        bottom: 2.8rem;
        left: 6.8%;
    }
    .cont-8::after {
        width: 13.5%;
        height: 4.5rem;
        bottom: 9.6rem;
        left: -1.3%;
    }
    .cont-8 h2 {
        font-size: 1.7rem;
        margin: 0 auto 1.3rem;
        letter-spacing: .1rem;
    }
    .cont-8 h2::after {
        top: -10.5rem;
        right: 40%;
        width: 18.9%;
        height: 9.5rem;
    }
    .cont-8 .flex {
        padding-left: 0;
        gap: 0;
    }
    .cont-8 .cont-8-1 {
        width: 43%;
        margin: 2.6rem auto 0;
    }
    .cont-8 .cont-8-2 {
        width: auto;
        margin: 0 5%;
    }
    .cont-8 .cont-8-2 h3 {
        font-size: 1.55rem;
        text-align: center;
        letter-spacing: .25rem;
        margin-bottom: 1.5rem;
    }
    .cont-8 .cont-8-2 p {
        font-size: 1.1rem;
        line-height: 1.8;
    }
    .cont-8 .cont-8-2 a {
        font-size: 1.1rem;
        border-radius: 30px;
        padding: 1.2rem 3.8rem;
        letter-spacing: .2rem;
        margin: 1.5rem auto 0;
    }
    /* cont-8 end*/
    /* footer */
    .footer {
        padding-top: 2.5rem;
    }
    .footer .flex {
        flex-direction: column-reverse;
        align-items: center;
        align-content: center;
    }
    .footer .flex div:first-child {
        padding: 0 26%;
    }
    .footer address {
        font-size: .71rem;
    }
    .footer .tel {
        font-size: 1.2rem;
        letter-spacing: .15rem;
    }
    .footer .fax {
        font-size: 1.2rem;
        letter-spacing: .14rem;
    }
    .footer .footer-logo {
        margin: auto;
        width: 50%;
    }
    .footer .footer-logo-txt {
        text-align: center;
        font-size: .9rem;
    }
    .footer .footer-nav,
    .footer .footer-nav2 {
        text-align: center;
    }
    .footer .fnav {
        gap: 1rem;
        justify-content: center;
        flex-direction: row;
        margin-bottom: 1.8rem;
    }
    .footer .fnav,
    .footer .fnav2 {
        display: flex;
        flex-wrap: wrap;
        justify-content: center;
        gap: 0 1.5rem;
        margin-bottom: 1rem;
    }
    .footer .fnav li,
    .footer .fnav2 li {
        margin-bottom: 1em;
    }
    .footer .copyright {
        text-align: center;
    }
    /* footer end*/
    /* corporate-profile */
    .corporate-profile .presi-phooto {
        text-align: center;
        width: 100%;
    }
    .corporate-profile .presi-text {
        width: 100%;
    }
    /* corporate-profile end */
    /* オリジナル Tablet css end */
    
}