﻿@import url(sections.css);

#page.grid-container{
    max-width: 100%;
}
body{
    position: relative;
}
.txt-lead{
    font-weight: 600;
    line-height: 2.5;
    max-width: 100%;
    margin-block: clamp(25px, 4.1vw, 60px);
}
@media (min-width: 1024px) {
    .txt-lead{
        max-width: 804px;
    }
}
.ttl-en{
    color: var(--white);
    font-family: "Roboto", sans-serif;
    font-weight:700;
    font-size: clamp(44px, 8.8vw, 128px);
    text-shadow:
    1px  0   0 var(--text-primary),
    -1px  0   0 var(--text-primary),
     0    1px  0 var(--text-primary),
     0   -1px  0 var(--text-primary),
     1px  1px  0 var(--text-primary),
    -1px -1px  0 var(--text-primary),
     1px -1px  0 var(--text-primary),
    -1px  1px  0 var(--text-primary);
    text-align: center;
 }
 @media(min-width: 768px){
    .ttl-en{
        text-align: left;
    }
 }
/* =========================
   MV
========================= */


.mv-area {
    height: calc(63vh - 60px);
    height: calc(63lvh - 60px);
}
@media(min-width: 1024px){
    .mv-area{
        height: calc(100vh - 150px);
        height: calc(100lvh - 150px);
    }
}

@media(min-width: 768px){    
    .mv-area{
    height: calc(100vh - 135px);
    height: calc(100lvh - 135px);
    }
}
.mv-area:before{
    content: "";
    position: absolute;
    background-image: url(../images/front/mv_sp.jpg);
    background-size: cover;
    background-repeat: no-repeat;
    background-position: top;
    border-bottom-left-radius: 30px;
    border-bottom-right-radius: 30px;
    width: 100%;
    height: 63vh;
    aspect-ratio: 390 / 372;
    z-index: -1;
    top: 0;
}
@media(min-width : 1024px){
    .mv-area:before{
        background-image: url(../images/front/mv.jpg);
    }
}
@media(min-width : 768px){
    .mv-area:before{
        background-size: cover;
        background-position: center;
        border-radius: 0;
        height: 100vh;
        height: 100lvh;
    } 
}
.mv-area .mv_inner{
    position: relative;
    height: 100%;
}
.mv-area .mv_catchcopy{
    position: absolute;
    top: 30px;
    right: 50px;
    writing-mode: vertical-rl;
    text-orientation:upright;
}
.mv-area .mv_catchcopy p{
    color: var(--white);
    font-size: clamp(20px, 2.3vw, 34px);
    font-weight: 700;
    line-height: 2;
    letter-spacing: .3rem;
}
@media(min-width: 1024px){
    .mv-area .mv_catchcopy p{
        text-shadow: 0 3px 7px rgb(0 0 0 / 25%);
    }
}
.mv-area .mv_btn-circle{
    position: absolute;
    bottom: -108px;
    right: 15px;
}
@media(min-width:768px){
    .mv-area .mv_btn-circle{
        left: 20px;
        bottom:20px;
    }
}
.mv-area .mv_btn-circle a{
    background-color: var(--yellow);
    background-image: url(../images/common/arrow_circle.svg);
    background-size: 25px 25px;
    background-repeat: no-repeat;
    background-position: center calc(100% - 10px);
    border-radius: 300px;
    color: var(--white);
    display: flex;
    text-decoration: none;
    text-align: center;
    align-content: center;
    align-items: center;
    flex-wrap: wrap;
    width: 128px;
    height: 128px;
}

@media(min-width:768px){
    .mv-area .mv_btn-circle a{
        background-size: 55px 55px;
        background-position: center calc(100% - 20px);
        width: 250px;
        height: 250px;   
    }
}
.mv-area .mv_btn-circle a > span{
    font-size: 10px;
    font-weight:700;
    width: 100%;
}
@media(min-width:768px){
    .mv-area .mv_btn-circle a > span{
        font-size: 16px;
    }
}
.mv-area .mv_btn-circle a > p{
    font-size: 14px;
    font-weight:700;
    line-height: 1.5;
    width: 100%;
}
@media(min-width:768px){
    .mv-area .mv_btn-circle a > p{
        font-size: 24px;
    }
}
/*
 mv_spのみ
*/
.mv_catchcopy-sp{
    margin-top: 25px;
}
.mv_catchcopy-sp p{
    color:var(--blue);
    font-size:16px;
    font-weight:700;
    margin-bottom:0.1rem;
}

/* =========================
   bg
========================= */
.bg-note{
    background-image:url(../images/front/bg-note.png);
    background-size: 150px;
}
@media(min-width: 768px){
    background-size: 240px;
}

/* 
* 同居猫たち
*/
@media(min-width:768px){
    .section-profile .profile_wrap.profile-cat_other{
        margin-top: 135px;
    }
}
.section-profile .profile_wrap.profile-cat_other .profile_box{
    background-color: var(--blue-gray);
}
@media (min-width: 1024px) {
    .section-profile .profile_wrap.profile-cat_other{
        grid-template-columns: repeat(4, 1fr);
        gap: 2.1vw;
    }
}
.section-profile .profile_wrap.profile-cat_other .profile_box .prof_num{
    text-shadow:
    1px  0   0 var(--yellow),
    -1px  0   0 var(--yellow),
     0    1px  0 var(--yellow),
     0   -1px  0 var(--yellow),
     1px  1px  0 var(--yellow),
    -1px -1px  0 var(--yellow),
     1px -1px  0 var(--yellow),
    -1px  1px  0 var(--yellow);
}

.section-profile .profile_wrap.profile-cat_other .profile_box .prof_summary .prof_furigana{
    color: var(--blue);
}
/* =========================
   Chart
========================= */
.section-chart{
    margin-top: clamp(50px, 17.3vw, 250px);
    padding-bottom: clamp(50px, 17.3vw, 250px);
}
.section-chart figure > img{
    margin: auto;
}
/* =========================
   ABOUT
========================= */
.section-about{
    background-color: var(--blue);
    color: var(--white);
    border-radius: clamp(64px, 12.5vw, 180px);
    margin-bottom: 10vw;
    padding: clamp(65px, 12.5vw, 180px) 0 0;
}
.section-about .about_contents{
    display: block;
}
@media(min-width: 1024px){
    .section-about .about_contents{
        gap: 100px;
    }
}
@media(min-width: 768px){
    .section-about .about_contents{
        display: grid;
        grid-template-columns: repeat(2, 1fr);
        gap: 50px;
    }
}
.section-about .about_contents .ttl-en{
    color: var(--blue);
    text-shadow:
    1px  0   0 var(--white),
    -1px  0   0 var(--white),
     0    1px  0 var(--white),
     0   -1px  0 var(--white),
     1px  1px  0 var(--white),
    -1px -1px  0 var(--white),
     1px -1px  0 var(--white),
    -1px  1px  0 var(--white);
}

.section-about .about_heading{
    font-size: clamp(18px, 1.8vw, 26px);
    line-height: 2;
    font-weight: 700;
}
@media (min-width:768px) {
    .section-about .about_heading{
        font-size: 26px;
    }        
}
.section-about .about_contents .about_contents_inner{
    margin-bottom: clamp(30px, 4.1vw, 60px);
    text-align: center;
}
@media(min-width: 768px){
    .section-about .about_contents .about_contents_inner{
      text-align: left;
    }
}
.section-about .about_contents .txt-lead{
    margin-bottom: clamp(15px, 2vw, 30px);
    text-align: left;
}
.section-about .about_contents .btn-solid_white{
    margin-right: auto;
    margin-left: auto;
}
@media(min-width:768px){
    .section-about .about_contents .btn-solid_white{
        margin-left: 0;
    }
    
}
.section-about .about_contents .about_contents_img img, .section-about .about_btm_img img{
    border-radius: clamp(8px, 2.08vw, 16px);
}
.section-about .about_contents .about_contents_img img:nth-of-type(1){
    border-bottom-right-radius: 0;
    border-bottom-left-radius: 0;
}
.section-about .about_contents .about_contents_img img:nth-of-type(2){
    border-top-right-radius: 0;
    border-top-left-radius: 0;
}
.section-about .about_btm_img {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 4vw;
    background-image: url(../images/front/paws_40.svg);
    background-repeat: no-repeat;
    background-position: center top;
    background-size: contain;
}
.section-about .about_btm_img img:nth-of-type(1){
    width: clamp(145px, 30.2vw, 435px);
}
.section-about .about_btm_img img:nth-of-type(2){
    width: clamp(88px, 18.4vw, 265px);
    transform: translate3d(0, 25vw, 0px);
    margin-left: auto;
}
@media(min-width: 768px){
    .section-about .about_btm_img img:nth-of-type(2){
        transform: translate3d(-12vw, 10vw, 0px);
    }
}
.section-about .about_btm_img img:nth-of-type(3){
    width: clamp(145px, 30.2vw, 435px);
    transform: translate3d(15vw, 10vw, 0);
}
/* =========================
   Partners
========================= */
.section-partners{
    margin-top: 50px;
}
.section-partners .partners_wrap{
    margin: auto;
}
@media(min-width : 1024px){
    .section-partners .partners_wrap{
        display: flex;
        justify-content: space-between;
    }
}
.section-partners .partners-bnr {
    display: flex;
    justify-content: space-between;
    max-width:500px;
    margin: 30px auto 0;
}
@media(min-width: 1024px){
    .section-partners .partners-bnr {
        width: calc(50% - 20px);
    }
}
.section-partners .partners-bnr .partners-bnr_img{
    background-color: var(--white);
    border-top-left-radius: clamp(10px, 2.8vw, 30px);
    border-bottom-left-radius: clamp(10px, 2.8vw, 30px);
    text-align: center;
    max-width: 242px;
    padding: 0 10px;
    align-content: center;
    /* flex-shrink: 0; */
    width: 45%;
}
@media(min-width: 768px){
    padding: 0 30px;
}
.section-partners .partners-bnr .partners-bnr_img img{
    width: 100%;
}
.section-partners .partners-bnr .partners-bnr_txt{
    background-color: var(--gray-90);
    border-top-right-radius: clamp(10px, 2.8vw, 30px);
    border-bottom-right-radius: clamp(10px, 2.8vw, 30px);
    padding: 20px;
}

.section-partners .partners-bnr .partners-bnr_txt .partners-bnr_txt_name{
    font-size:14px;
    font-weight: 600;
    margin-bottom:5px;
    line-height: 1.5;
    background-image: url(../images/common/arrow_circle_blue.svg);
    background-size: contain;
    background-repeat: no-repeat;
    background-position: right center;
}
@media(min-width: 768px){
    .section-partners .partners-bnr .partners-bnr_txt .partners-bnr_txt_name{
        background-image:none;
        font-size: min(1.8vw, 20px);
        margin-bottom: 8px;
    }
}

.section-partners .partners-bnr .partners-bnr_txt p{
    font-size: 12px;
    margin-bottom: 0;
}
.section-partners .partners-bnr .partners-bnr_txt a{
    margin-top:15px;
}
@media(min-width : 769px){
    .section-partners .partners-bnr .partners-bnr_txt p{
        font-size: 14px;
    }
}