@charset "utf-8";

/* style.css
 * **************************************************
 * おすすめプログラム
 * **************************************************
 */

:root {
    --color-black: #414141;
    --color-aqua: #004097;
    --color-dance: #fd6a2a;
    --color-medical: #004097;
    --color-beauty: #e280a8;
}

/* Font：基本サイズ（16 * 0.625 = 10px） */
html {
    font-size: 62.5%;
}

body {
    color: var(--color-black);
    font-family: "Noto Sans JP", "Yu Gothic Medium", "游ゴシック Medium",
        YuGothic, "游ゴシック体", "ヒラギノ角ゴ Pro W3",
        "Hiragino Kaku Gothic Pro", "メイリオ", sans-serif;
    font-feature-settings: "palt";
    font-optical-sizing: auto;
    overflow-x: hidden;
    word-break: keep-all;
}

.inner {
    margin: 0 auto;
    padding: 0;
    position: relative;
}

/* img */
img {
    height: auto;
    max-width: 100%;
}

/* link */
a {
    transition: 0.3s;
}

a:hover {
    opacity: 0.8;
}

main {
    display: block;
}

main::before,
main::after {
    background-color: rgba(0, 225, 225, 0.1);
    content: "";
    display: block;
    height: 100%;
    position: fixed;
    top: 0;
    width: calc(50% - 490px);
}

main::before {
    background-position: left center;
    left: 0;
}

main::after {
    background-position: right center;
    right: 0;
}

/* content */
#content {
    margin: 0 auto;
    width: min(100%, 980px);
}

/* イントロ */
.introSection {
    background: url(../images/bg_intro_01.jpg) no-repeat center top;
    background-size: 100% 100%;
    padding: 15% 0 10.81%;
}

@media only screen and (max-width: 980px) {
    .introSection {
        background-size: cover;
        padding: 16% 0 8%;
    }
}

.introSection > * {
    margin: 0 auto;
}

.mainvisual {
    position: relative;
}

.mainvisualTitle {
    margin-left: 21.93%;
    width: min(58%, 538px);
}

.newRelease {
    background-color: #ffffff;
    border-radius: 20px;
    filter: drop-shadow(0 2px 5px rgba(0, 0, 0, 0.1));
    margin-top: 14.28%;
    padding: 4.08% 0 5.91%;
    position: relative;
    z-index: 1;
    width: min(72%, 460px);
}

@media only screen and (max-width: 980px) {
    .newRelease {
        margin-top: 16%;
    }
}

.newReleaseTitle {
    margin: 0 auto;
    width: 53.43%;
}

.newReleaseListItem {
    color: #4d4d4d;
    font-size: clamp(
        15px,
        calc(8.696969696969697px + 1.9696969696969695vw),
        28px
    );
    letter-spacing: 0.1em;
    margin: 6.52% 0 0 0;
    text-align: center;
}

.newReleaseListItem span {
    display: block;
    font-size: clamp(
        10px,
        calc(6.121212121212121px + 1.2121212121212122vw),
        18px
    );
    font-weight: 300;
    margin: 0 0 0.55em;
}

.introText {
    color: #143282;
    font-size: clamp(
        13px,
        calc(8.636363636363637px + 1.3636363636363635vw),
        22px
    );
    font-weight: 500;
    letter-spacing: 0.08em;
    line-height: 2;
    margin-top: 11.12%;
    text-align: center;
}

/* プログラム */
.programWrap {
    position: relative;
}

.programBg {
    background-image: linear-gradient(
        -45deg,
        rgba(255, 255, 255, 0.2) 25%,
        transparent 25%,
        transparent 50%,
        rgba(255, 255, 255, 0.2) 50%,
        rgba(255, 255, 255, 0.2) 75%,
        transparent 75%,
        transparent
    );
    background-size: 30px 30px;
    height: 100%;
    position: absolute;
    width: 100%;
}

.programSection {
    padding: 10.2% 0;
    position: relative;
}

.programSection::after {
    content: "";
    display: block;
    height: 100%;
    pointer-events: none;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    z-index: -1;
}

#aqua::after {
    background-color: #caedff;
}

#dance::after {
    background-color: #f6cc93;
}

#medical::after {
    background-color: #e0e8f3;
}

#beauty::after {
    background-color: #fcf2f6;
}

.programContainer {
    background-color: #ffffff;
    border: 4px solid;
    filter: drop-shadow(0 2px 5px rgba(0, 0, 0, 0.1));
    margin: 0 auto;
    padding: 0 4.18%;
    width: min(94%, 740px);
}

#aqua .programContainer {
    border-color: var(--color-aqua);
    color: var(--color-aqua);
}

#dance .programContainer {
    border-color: var(--color-dance);
    color: var(--color-dance);
}

#medical .programContainer {
    border-color: var(--color-medical);
    color: var(--color-medical);
}

#beauty .programContainer {
    border-color: var(--color-beauty);
    color: var(--color-beauty);
}

.programContainerTitle {
    padding: 7.69% 0 0 0;
    text-align: center;
}

.programSeriesHeader {
    text-align: center;
}

.programSeriesText {
    background-image: linear-gradient(
        to right,
        var(--color-black) 2.5px,
        transparent 2.5px
    );
    background-size: 5px min(0.93vw, 5px);
    background-repeat: repeat-x;
    background-position: center bottom;
    font-size: clamp(
        14px,
        calc(9.151515151515152px + 1.5151515151515151vw),
        24px
    );
    font-weight: 700;
    line-height: 1.4;
    margin: 0 0 2.3%;
    padding: 9.23% 0 3%;
}

#aqua .programSeriesText {
    background-image: linear-gradient(
        to right,
        var(--color-aqua) 2.5px,
        transparent 2.5px
    );
}

#dance .programSeriesText {
    background-image: linear-gradient(
        to right,
        var(--color-dance) 2.5px,
        transparent 2.5px
    );
}

#medical .programSeriesText {
    background-image: linear-gradient(
        to right,
        var(--color-medical) 2.5px,
        transparent 2.5px
    );
}

#beauty .programSeriesText {
    background-image: linear-gradient(
        to right,
        var(--color-beauty) 2.5px,
        transparent 2.5px
    );
}

.programSeriesTitle {
    font-size: clamp(
        26px,
        calc(14.363636363636363px + 3.6363636363636362vw),
        50px
    );
    font-weight: 800;
    letter-spacing: -0.03em;
}

.programSeriesImage {
    margin: 7.69% 0 0 0;
}

.program {
    padding: 7.69% 0;
}

.program:has(p) {
    padding-bottom: 6.3%;
}

.program + .program {
    background-image: linear-gradient(
        to right,
        var(--color-black) 4px,
        transparent 4px
    );
    background-size: 8px 1px;
    background-repeat: repeat-x;
    background-position: left top;
}

#beauty .program + .program {
    background-image: linear-gradient(
        to right,
        var(--color-beauty) 4px,
        transparent 4px
    );
}

#medical .program + .program {
    background-image: linear-gradient(
        to right,
        var(--color-medical) 4px,
        transparent 4px
    );
}

.programImage {
    position: relative;
}

#aqua .programLogo {
    position: absolute;
    bottom: max(-2.95vw, -29px);
    left: -9px;
    width: min(38.92%, 253px);
}

.programVideo {
    margin: 5.69% 0 0;
}

.programContent {
    padding: 5.69% 0 0 0;
    position: relative;
    text-align: center;
}

.programIconNew {
    position: absolute;
    top: min(2.44vw, 24px);
    left: 0;
    width: 17%;
}

.programTitle {
    font-size: clamp(
        25px,
        calc(19.18181818181818px + 1.8181818181818181vw),
        37px
    );
    font-weight: 700;
    padding: 0 2em;
}

.programTime {
    font-size: clamp(
        15px,
        calc(9.666666666666668px + 1.6666666666666667vw),
        26px
    );
    font-weight: 600;
    margin: 1.23% 0 0 0;
}

.programStrength {
    font-size: clamp(
        15px,
        calc(9.666666666666668px + 1.6666666666666667vw),
        26px
    );
    font-weight: 600;
    margin: 1.69% 0 0 0;
}

.programCsliveLimited {
    margin: 1.53% auto 0;
    width: min(60%, 284px);
}

.programDetail {
    font-size: clamp(
        13px,
        calc(8.636363636363637px + 1.3636363636363635vw),
        22px
    );
    letter-spacing: 0.04em;
    line-height: 1.8;
    margin: 3.07% 0 0 0;
}

.programButton {
    margin: 5.1% auto 0;
    width: min(70%, 380px);
}

.programButton a {
    border-radius: 34px;
    color: #ffffff;
    display: block;
    filter: drop-shadow(0 2px 5px rgba(0, 0, 0, 0.2));
    font-size: clamp(
        16px,
        calc(10.666666666666668px + 1.6666666666666667vw),
        27px
    );
    font-weight: 800;
    letter-spacing: 0.1em;
    padding: 0.66em 0;
    position: relative;
    text-align: center;
    width: 100%;
}

#aqua .programButton a {
    background-color: var(--color-aqua);
}

#dance .programButton a {
    background-color: var(--color-dance);
}

#medical .programButton a {
    background-color: var(--color-medical);
}

#beauty .programButton a {
    background-color: var(--color-beauty);
}

.programButton a::after {
    border-right: 4px solid #ffffff;
    border-bottom: 4px solid #ffffff;
    content: "";
    display: inline-block;
    height: 0.6em;
    margin-top: -0.3em;
    position: absolute;
    top: 50%;
    right: 7.89%;
    transform: rotate(-45deg);
    width: 0.6em;
}

.programButton a:hover {
    opacity: 1;
    scale: 1.05;
}

.buttonBack {
    margin: 10.2% auto 0;
    text-align: center;
    width: min(52%, 350px);
}

.buttonBack a {
    background-color: #ffffff;
    border: 2px solid #000000;
    border-radius: 10px;
    display: block;
    font-size: clamp(
        14px,
        calc(9.151515151515152px + 1.5151515151515151vw),
        24px
    );
    font-weight: 500;
    letter-spacing: 0.05em;
    padding: 0.66em 0;
    position: relative;
    text-align: center;
    width: 100%;
}

/* pageTop */
#pageTop {
    background: #3dbdf4;
    border-radius: 50%;
    height: 50px;
    opacity: 0.7;
    position: fixed;
    bottom: 20px;
    right: 20px;
    width: 50px;
    z-index: 99;
}

#pageTop a {
    display: block;
    position: relative;
    height: 50px;
    width: 50px;
}

#pageTop a::before {
    border-right: 2px solid #ffffff;
    border-bottom: 2px solid #ffffff;
    content: "";
    display: inline-block;
    height: 12px;
    position: absolute;
    top: 22px;
    left: 19px;
    transform: rotate(-135deg);
    width: 12px;
}

/* Footer
-------------------------------------------------- */

#footer {
    background-color: #ffffff;
    position: relative;
}

#footer .inner {
    padding: 25px 0 20px;
}

#footer .logo {
    align-items: center;
    display: flex;
    justify-content: center;
}

#footer .logo a {
    margin: 0 15px;
    width: 160px;
}

/* Media Queries
-------------------------------------------------- */

@media only screen and (max-width: 767px) {
    /* pageTop */
    #pageTop {
        height: 44px;
        bottom: 2%;
        right: 2.5%;
        width: 44px;
    }

    #pageTop a {
        height: 44px;
        width: 44px;
    }

    #pageTop a::before {
        top: 19px;
        left: 16px;
    }

    #footer .inner {
        padding: 5% 0;
    }

    #footer .logo a {
        width: 22.66%;
    }
}
