/***************************************
MV タイトル
****************************************/

.mv__title {
    grid-column: 1;
    grid-row: 1;
    display: flex;
    justify-content: center;
    align-items: center;
}

.mv__title__inner {
    display: flex;
    flex-direction: column;
    gap: clamp(25px, 3.286vw + 12.33px, 60px);
}

.mv__title__inner p {
    text-align: left;
}

.mv__title__inner p:first-child {
    line-height: 1;
    font-size: clamp(16px, 0.938vw + 12.48px, 26px);
}

.mv__title__inner p:nth-child(n+2) {
    line-height: 1.7;
    font-size: clamp(12px, 0.751vw + 9.1px, 20px);
}

.mv__title__inner p:nth-child(n+3) {
    font-size: clamp(10px, 0.751vw + 7.1px, 18px);
}

/***************************************
MV
****************************************/
.mv {
    display: grid;
    grid-template-columns: 350fr 740fr 350fr;
    grid-template-rows: 497fr 90fr 140fr;
    grid-column-gap: 0px;
    grid-row-gap: 0px;
    min-height: 88vh;
    margin: 0 auto;
}

/***************************************
MV アルファベット
 ****************************************/
.mv_en__outer {
    grid-column: 2 / 4;
    /* 2から３列目 */
    grid-row: 1;
    /* 1行目 */
    font-family: "futura-pt-bold", sans-serif;
    font-size: clamp(70px, 6.57vw + 45.36px, 140px);
    font-weight: 700;
    line-height: 1;
    letter-spacing: 0;
    color: #DDF5DD;
    -webkit-text-stroke: 1px #5F5C71;
}

.mv_en {
    display: grid;
    grid-template-columns: 7fr 9fr;
    grid-template-rows: 5fr 1fr 3fr;
    height: 100%;
}

.bar {
    width: clamp(10px, 1.389vw + 4.79px, 20px);
    height: clamp(50px, 6.944vw + 23.96px, 100px);
    background-color: #B5D1E2;
    border: 1px solid #5F5C71;
}

.en_group {
    position: relative;
}

.en__item {
    position: absolute;
}

@media screen and (max-width:700px) {
    .mv_en__outer {
        -webkit-text-stroke: .5px #5F5C71;
    }

    .bar {
        border: .6px solid #5F5C71;
    }
}

/* MV アルファベット左側（a/k/a/四角） */
.en_left {
    grid-column: 1;
    grid-row: 1;
    height: 72px;
    width: 49%;
    margin: 173px 0 0 71px;
}

.bar_left {
    transform: rotate(-58.3deg);
    top: 100%;
    left: 14%;
}


/* a */
.en_left01 {
    bottom: 29.1%;
    right: 100%;
}

/* k */
.en_left02 {
    top: -1em;
    right: 22.7%;
}

/* a */
.en_left03 {
    bottom: 0;
    left: 100%;
}

/* MV アルファベット右側（n/e/四角） */
.en_right {
    grid-column: 2;
    grid-row: 1;
    height: 92px;
    width: 58%;
    margin: 16px 0 0 101px;
}

.bar_right {
    transform: rotate(-125.65deg);
    top: 21.83%;
    left: 100%;
}


/* n */
.en_right01 {
    top: 0;
    right: 100%;
}

/* e */
.en_right02 {
    bottom: -1em;
    right: 22.7%;
}

/* a */
/* .en_left03 {
    bottom: 0;
    right: 24.64%;
} */

/* MV アルファベット下段左側（四角/h） */
.en_bottom-left {
    grid-column: 1;
    grid-row: 3;
    height: 22px;
    width: 73%;
    margin: 9px 0 0 71px;
}

.bar_bottom-left {
    transform: rotate(-125.75deg);
    top: 100%;
    right: 47.5%;
}

/* h */
.en_bottom-left01 {
    top: 0;
    left: 100%;
}

/* MV アルファベット下段右側（四角/a/r/a） */
.en_bottom-right {
    grid-column: 2;
    grid-row: 2 / 4;
    height: 33%;
    width: 39%;
    margin-left: 38%;
}

.bar_bottom-right {
    transform: rotate(-60deg);
    bottom: 65%;
    left: -22%;
}

/* a */
.en_bottom-right01 {
    top: 0;
    right: 100%;
}

/* r */
.en_bottom-right02 {
    top: 82%;
    left: 30%;
}

/* a */
.en_bottom-right03 {
    top: 100%;
    left: 100%;
}

/***************************************
 MV ドット・星背景
 ****************************************/
.mv__dot {
    grid-column: 1 / 3;
    /* 1から2列目 */
    grid-row: 2;
    /* 2行目 */
}

.mv__star {
    grid-column: 2;
    /* 2列目 */
    grid-row: 3;
    /* 3行目 */

}


/***************************************
 MV スクロール
 ****************************************/
.mv__scroll {
    grid-column: 3;
    /* 3列目 */
    grid-row: 2 / 4;
    /* 2から3行目 */
    padding-right: 3vw;
    display: flex;
    justify-content: flex-end;
}

.mv__scroll__inner {
    display: flex;
    flex-direction: column-reverse;
    align-items: center;
    justify-content: center;
    height: 100%;
    gap: 11%;
    width: fit-content
}

/* SCROLL文字 縦書き */
.mv__scroll__text {
    line-height: 1;
    margin-left: -2px;
    writing-mode: vertical-rl;
    font-size: clamp(12px, 0.938vw + 8.48px, 24px);
    letter-spacing: 0.03em;
    transform: rotate(180deg);
}

/* 線 */
.scroll__line__wrap {
    position: relative;
    width: 15px;
    height: 95px;
    display: flex;
    justify-content: center;
}

.scroll__line {
    display: block;
    width: 1px;
    height: 100%;
    background-color: #5F5C71;
}

/* 星を線の上端中央に配置 */
.scroll__star {
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 15px;
    height: 15px;
    /* 上下にふわふわ動かす */
    animation: starFloat 2.5s ease-in infinite;
}

@keyframes starFloat {
    0% {
        transform: translateX(-50%) translateY(0);
    }

    100% {
        transform: translateX(-50%) translateY(95px);
    }
}

@media screen and (min-width:700px) {
    .mv .wrapper-l {
        max-width: 100%;
        width: 100%;
    }
}

@media screen and (max-width:700px) {
    .mv {
        grid-template-columns: 17fr 8fr;
        grid-template-rows: 16fr 28fr 5fr 7fr;
    }

    .mv__title-line-bottom,
    .mv-en-sp__line-bottom {
        border-bottom: none;
    }

    .mv-title-sp__line-left,
    .mv-en-sp__line-left {
        border-left: .6px solid #5F5C71;
    }

    .mv-en-sp__line-right {
        border-right: .6px solid #5F5C71;
    }

    /* MV タイトル */
    .mv__title {
        grid-column: 1 / 3;
        grid-row: 1;
        justify-content: flex-start;
        padding: 35px 0 25px;
    }

    .mv__title__inner {
        margin-left: 5.5vw;
    }

    /* MV アルファベット */
    .mv_en__outer {
        grid-column: 1 / 3;
        grid-row: 2;
    }

    .mv_en {
        grid-template-columns: 13fr 14fr;
        grid-template-rows: 8fr 7fr;
        min-height: 351px;
    }

    .en_left {
        grid-column: 1;
        grid-row: 1;
    }

    .en_right {
        grid-column: 2;
        grid-row: 1;
    }

    .en_bottom-left {
        grid-column: 1;
        grid-row: 2;
    }

    .en_bottom-right {
        grid-column: 2;
        grid-row: 2;
    }

    /* 左側 */
    .en_left {
        height: 30%;
        width: 48%;
        margin: 0;
        margin: 70px 0 0 39px;
    }

    .bar_left {
        left: 28.5%;
    }

    /* a */
    .en_left01 {
        bottom: 33.8%;
    }

    /* k */
    .en_left02 {
        right: 0;
    }

    /* a */
    .en_left03 {
        top: 0;
    }

    /* 右側 */
    .en_right {
        height: 34%;
        width: 72%;
        margin: 0;
        margin: 62px 0 43px 0;
    }

    .bar_right {
        top: auto;
        bottom: 100%;
    }

    /* n */
    .en_right01 {
        top: -100%;
        right: 28.5%;
    }

    /* e */
    .en_right02 {
        bottom: auto;
        right: 22.7%;
        top: 0;
        left: 100%;
    }

    /* 下段左側 */
    .en_bottom-left {
        height: 22%;
        width: 37%;
        margin: 17px 0 0 40px;
    }

    .bar_bottom-left {
        top: 0;
        right: 100%;
    }

    /* h */
    .en_bottom-left01 {
        top: 100%;
    }

    /* 下段右側 */
    .en_bottom-right {
        height: 47%;
        width: 33%;
        margin: 0;
        margin: 0 0 0 45px;
    }

    .bar_bottom-right {
        bottom: 100%;
        left: 0;
    }

    /* r */
    .en_bottom-right02 {
        top: 100%;
        left: auto;
        right: 0;
    }

    /* a */
    .en_bottom-right03 {
        top: auto;
        left: 100%;
        bottom: 0;
    }

    /* ドット */
    .mv__dot {
        grid-column: 1;
        grid-row: 3;
    }

    /* 星 */
    .mv__star {
        grid-column: 1;
        grid-row: 4;
    }

    .star-sp__line-left {
        border-left: none;
    }

    /* スクロール */
    .mv__scroll {
        grid-column: 2;
        grid-row: 3 / 5;
        padding-right: 10.6vw;
    }

    .scroll__line__wrap {
        height: 48px;
    }

    @keyframes starFloat {
        100% {
            transform: translateX(-50%) translateY(45px);
        }
    }
}

/***************************************
制作実績
****************************************/
/* 外側は幅いっぱい、はみ出し非表示 */
.ticker {
    overflow: hidden;
    white-space: nowrap;
    padding: .5em 0 .125em;
}

/* 内側を横に並べてアニメーション */
.ticker__inner {
    display: inline-flex;
    gap: 20px;
    animation: ticker 18s linear infinite;
}

.ticker__inner span {
    font-size: clamp(24px, 1.5vw + 18.37px, 40px);
    line-height: 1;
    color: #DDF5DD;
    -webkit-text-stroke: .4px #5F5C71;
}

/* 左に流れるアニメーション */
@keyframes ticker {
    0% {
        transform: translateX(0);
    }

    100% {
        transform: translateX(-50%);
    }

    /* 半分ずらすとシームレスに繰り返す */
}

.section__outer {
    background-color: #EBF2E5;
    padding: 4.86vw;
}

.section__inner {
    width: 100%;
    background-color: #ffffff;
}

.section__box {
    display: flex;
    justify-content: space-between;
    width: 90%;
    margin: 0 auto;
    padding: 3.4vw 2vw;
    border-bottom: .6px solid #A9A7A7;
}

.work__box {
    border-bottom: none;
}

.work__info {
    width: 45%;
}

/* 種類 */
.work__category {
    display: inline-block;
    font-size: clamp(10px, 0.37vw + 8.61px, 14px);
    font-weight: 400;
    line-height: 1;
    padding: 6px 8px;
    color: #4480A5;
    border: 1px solid #4E92BC;
}

.school-work__category {
    padding: 6px 1px 6px 8px;
}

/* タイトル */
.work__title {
    font-size: clamp(16px, 0.56vw + 13.9px, 22px);
    line-height: 1;
    padding: 3.47vw 0 3.81vw;
}

/* 担当範囲 */
.work__tag {
    display: flex;
    margin-top: 15px;
}

.work__tag p {
    font-size: clamp(10px, 0.28vw + 8.95px, 13px);
    font-weight: 400;
    line-height: 1;
    letter-spacing: .03em;
    padding-right: 10px;
    color: #737373;
}

.work__tag p:nth-child(n+2) {
    padding-left: 10px;
    border-left: .5px solid #737373;
}

/* 画像 */
.work__img {
    width: 47%;
    align-self: stretch;
    overflow: hidden;
}

.work__img img {
    height: 100%;
    object-fit: cover;
    object-position: center;
    transition: transform 0.4s ease;
}

.work__inner:hover .work__img {
    transform: scale(1.05);
    transition: 0.4s ease;
}

.work__inner:hover .work__img img {
    transform: scale(1.05);
}

@media screen and (max-width:900px) {
    .section__box {
        width: 100%;
        padding: 5.3vw 5.3vw 0 5.3vw;
        flex-direction: column-reverse;
        align-items: center;
        overflow: hidden;
        border-bottom: none;
    }

    .work__info {
        width: 100%;
        border-bottom: 1px solid #A9A7A7;
        padding-bottom: 5.3vw;
    }

    .work__img {
        width: 100%;
        max-width: none;
    }


    .work__inner:last-child .work__info {
        border-bottom: none;
    }

    .work__category {
        margin-top: 1.8em;
    }

    .work__title {
        padding: 1.06em 0 .75em;
    }

    .work__tag {
        margin-top: 1em;
    }
}


@media screen and (max-width:700px) {
    .work__info {
        border-bottom: .6px solid #A9A7A7;
    }

    .work__line-left,
    .work__line-right {
        border-left: none;
        border-right: none;
    }

    .work__category {
        margin-top: 1.8em;
        border: .8px solid #4E92BC;
    }
}

/***************************************
私について
 ****************************************/
.about-ticker__inner span {
    color: #B5D1E2;
}

.about__subtitle {
    font-size: clamp(20px, 1.87vw + 12.9px, 40px);
    line-height: 1;
    letter-spacing: .15em;
    color: #ffffff;
    -webkit-text-stroke: 1.5px #4480A5;
    background: #ffffff;
    text-align: center;
    padding-top: 5.3vw;
}

.about__box {
    gap: 4.16vw;
}

.about__outer {
    background-color: #C0D2DC;
}

.about__img {
    width: 22%;
    min-width: 215px;
}


.about__name {
    display: flex;
    align-items: center;
    gap: clamp(10px, 0.469vw + 8.24px, 15px);
    line-height: 1;
}

.about__name-jp {
    font-size: clamp(16px, 0.56vw + 13.9px, 22px);
    letter-spacing: .25em;
}

.about__name-en {
    font-size: clamp(14px, 0.37vw + 12.6px, 18px);
    color: #5F5C71;
}

.about__desc {
    margin-top: 1.87em;
}

.about__interests {
    margin-top: 1.25em;
    font-weight: 400;
    color: #737373;
    display: flex;
    align-items: center;
    gap: clamp(10px, 1.4vw + 4.75px, 25px);
    line-height: 1;
}

.about__interests-list {
    font-size: clamp(11px, 0.46vw + 9.27px, 16px);
    display: flex;
    gap: 1.04vw;
}

@media screen and (max-width:980px) {
    .about__box {
        width: 100%;
        padding: 5.3vw 5.3vw 0 5.3vw;
        flex-direction: column;
        align-items: center;
        overflow: hidden;
        border-bottom: none;
    }

    .about__text {
        border-bottom: .6px solid #A9A7A7;
        padding-bottom: 5.3vw;
    }

    .about__name {
        justify-content: center;
    }

    .about__desc {
        margin-top: 1.4em;
    }

    .about__interests {
        margin-top: .9em;
    }
}

@media screen and (max-width:700px) {
    .about__subtitle {
        -webkit-text-stroke: 1px #4480A5;
    }
}


/* スキル */
.skill__outer {
    background-color: #ffffff;
}

.skill {
    width: 90%;
    margin: 0 auto;
    padding: 3.4vw 2vw;
}

.skill__title__outer {
    display: flex;
    align-items: center;
    gap: .5em;
}

.skill__title {
    font-size: clamp(20px, 0.93vw + 16.5px, 30px);
    color: #4480A5;
    line-height: 1;
    margin-bottom: .5px;
}

.about__skill__logo {
    display: flex;
    align-items: center;
}

.skill__inner {
    display: flex;
    padding: 2vw 2vw 0;
    gap: 5.5vw;
}

.skill__item {
    width: 100%;
}

.skill__itemtitle {
    line-height: 1;
    padding: 0.25em 0.05em;
    border-bottom: 1px solid #A9A7A7;
    display: inline-block;
}

.skill__desc {
    padding-top: .8em;
}

.skill__tools {
    margin-top: 1.25vw;
}

.skill__tools p+p {
    margin-left: .9em;
}

@media screen and (max-width:980px) {
    .skill {
        padding: 5.3vw 2vw;
    }

    .skill__inner {
        flex-direction: column;
        padding: 2vw 0 0;
    }
}