@charset "UTF-8";

/*****************
common 
*****************/
body {
    width: 100% !important;
    margin: 0 auto;
    padding: 0;
    background: var(--white);
    font-family: "M PLUS 2", sans-serif;
}

html {
    font-size: 62.5%;
    font-weight: 500;
    font-style: normal;
    line-height: 1.5;
    color: #514136;
    text-align: center;
    letter-spacing: 0.05em;
    scroll-behavior: smooth;
}

img {
    border: 0 none;
    outline: 0 none;
    margin: 0;
    padding: 0;
    width: 100%;
    height: auto;
}

a:hover {
    opacity: 0.7;
    transition:  all 0.4s;
}

ul {
    list-style: none;
}

.btn {
    display: block;
    margin: 0 auto;
}

.pc {
    display: none;
}


/*****************
main
*****************/
.main-content {
    max-width: 750px;
    background-color: #FFF;
    margin: 0 auto;
}

.top {
    position: relative;
}

.parts {
    position: absolute;
    left: 0;
    right: 0;
    margin: 0 auto;
    opacity: 0;
}

.star {
    width: 92%;
    top: 0;
}

.ribbon {
    width: 71.1%;
    top: 6.5%;
}

.txt01 {
    width: 39.5%;
    top: 24%;
}

.txt02 {
    width: 59%;
    top: 33%;
}

.btn-recommend {
    display: block;
    width: 88%;
    margin: 0 auto;
}

.link-btn {
    margin: 20px 80px;
}

.anm {
    opacity: 0;
    visibility: hidden;
    transition: all 1s;
}

.sec {
    display: grid;
    grid: "section";
    overflow: hidden;
}

.sec img,
.sec .text,
.sec .list {
    grid-area: section;
}

.sec p {
    width: 100%;
}

.sec span {
    font-size: clamp(1.54rem, 4.8vw, 3.6rem);
    color: #E8390D;
    line-height: 1.9;
}

.selection p:first-of-type {
    font-size: clamp(1rem, 3vw, 2.2rem);
    line-height: 1.6;
    margin-top: 46%;
}

.selection p:last-of-type {
    font-size: clamp(0.9rem, 2.6vw, 1.9rem);
    margin-top: 3%;
}

.point .item01 p {
    font-size: clamp(0.9rem, 2.7vw, 2.05rem);
    line-height: 1.4;
    margin-top: 56%;
}

.point .item01 span:nth-last-child(2){
    margin: 0 4%;
}

.point .item02 p:first-of-type {
    font-size: clamp(0.77rem, 2.4vw, 1.8rem);
    text-align: left;
    margin: 24% 0 0 17%;
}

.point .item02 span {
    line-height: 1.2;
}

.point span.mini {
    font-size: clamp(1.3rem, 3.9vw, 2.9rem);
    margin: 0 1%;
}

.point .caution {
    font-size: clamp(0.77rem, 2.4vw, 1.8rem);
    color: #606060;
    margin:3% 0 0 6%;
}

.point .item03 p {
    font-size: clamp(0.86rem, 2.7vw, 2.1rem);
    text-align: left;
    margin: 10% 0 0 15%;
}

.point .item03 span {
    display: block;
    line-height: 1.2;
    margin-top: 1%;
}

.parking p {
    font-size: clamp(1.2rem, 3.5vw, 2.6rem);
    margin-top: 44.5%;
}

.wrapping {
    align-items: center;
}

.wrapping .text {
    width: 57.5%;
    margin: 40% auto 0;
    /* top: 0; */
}

.wrapping .text div {
    width: 100%;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    margin-top: 7%;
}

.wrapping dt,
.wrapping dd {
    text-align: left;
    font-weight: 500;
}

.wrapping div:first-of-type dt {
    width: 25%;
    background-color: #E8390D;
    color: #FFF;
    font-size: clamp(1.7rem, 4.3vw, 3.8rem);
    text-align: center;
    padding: 6.5% 0;
    border-radius: 50%;
}

.wrapping div:first-of-type dd {
    width: 68%;
    font-size: clamp(1.3rem, 4.1vw, 3.1rem);
    line-height: 1.25;
    letter-spacing: 0.05em;
}

.wrapping .text div:nth-of-type(2) {
    justify-content: flex-end;
}

.wrapping div:nth-of-type(2) dt {
    width: 20%;
    background-color: #E8390D;
    border-radius: 25px;
    color: #FFF;
    font-size: clamp(1rem, 3.1vw, 2.4rem);
    text-align: center;
    padding: 0.5% 0 1% 0.5%;
    margin-right: 5%;
}

.wrapping div:nth-of-type(2) dd {
    width: 68%;
    font-size: clamp(1rem, 3.4vw, 2.5rem);
    margin: 0;
}

.wrapping div:nth-of-type(2) dd:nth-of-type(2) {
    width: 100%;
    margin: 0;
    font-size: clamp(0.8rem, 2.4vw, 1.8rem);
    text-align: center;
}

.recommend {
    background-color: #F2F2F2;
    padding-bottom: 4%;
    position: relative;
}

.recommend .list {
    display: flex;
    justify-content: space-between;
    align-content: flex-start;
    flex-wrap: wrap;
    margin: 0 7.5%;
    gap: 0;
}

.recommend li {
    width: 32.5%;
    position: relative;
}

.recommend li a {
    display: block;
    padding: 5.5% 0 7%;
}

.recommend .ttl {
    margin-top: 5.5%;
}

.recommend p {
    font-size: clamp(0.7rem, 2.3vw, 1.7rem);
    line-height: 1.1;
    background-color: #FFF;
    font-weight: bold;
    text-align: center;
    border-radius: 50px;
    filter: drop-shadow(2px 4px 2px #bcbcbc);
    padding: 4% 0 4.3%;
    margin-top: 8%;
}

.recommend li:nth-of-type(6) a {
    padding-bottom: 13%;
}

.recommend li:nth-of-type(6) p {
    margin-top: 10%;
}

.present {
    width: 51.5%;
    position: absolute;
    bottom: 3%;
    right: 8%;
}

.search-text {
    color: #514136;
    font-size: clamp(1.7rem, 5.2vw, 3.9rem);
    line-height: 1.3;
    margin-top: 4%;
}

.comment {
    position: absolute;
    z-index: 10;
}

.c-1 {
    width: 50%;
    top: -11%;
    right: 0;
}

.c-2 {
    width: 58%;
    top: -2%;
    right: -14%;
}

.c-3 {
    width: 62%;
    top: -8%;
    right: -12%;
}

.c-4 {
    width: 62%;
    top: -12%;
    right: -12%;
}

.c-5 {
    width: 70%;
    top: -6%;
    right: -15.5%;
}

.c-6 {
    width: 67%;
    top: -2%;
    right: -20%;
}

.c-7 {
    width: 60%;
    top: -9%;
    right: -13%;
}

.c-8 {
    width: 63%;
    top: -3%;
    right: -14%;
}

.c-9 {
    width: 57%;
    top: 0%;
    right: -25%;
}

.recommend .red {
    color: #E8390D;
}

.recommend .green {
    color: #509E60;
}

.recommend .navy {
    color: #5271AD;
}

.recommend .orange {
    color: #EA6A2A;
}

.recommend .brawn {
    color: #514136;
}

.recommend .blue {
    color: #58B9E1;
}

.netshop {
    background-color: #1D50A2;
    padding: 10% 6.5% 14%;
    margin: 7% 3.5%;
    position: relative;
}

.netshop::after {
    position: absolute;
    content: "";
    border: 2px solid #FFF;
    top: 1%;
    bottom: 1%;
    left: 1.5%;
    right: 1.5%;
}

.netshop p {
    color: #FFF;
    font-size: clamp(0.7rem, 2.1vw, 1.57rem);
    margin-top: 5%;
}

.blBtn {
    width: 80%;
    margin-top: 2%;
}

.orBtn {
    width: 92%;
    margin-top: 6%;
    position: relative;
    z-index: 10;
}


/* hover */
.recommend li a:hover {
    opacity: 1;
}

.recommend li a:hover img {
    animation: rotate-scale-up .75s linear both;
}
@keyframes rotate-scale-up {
    0% {
        
        transform: scale(1) rotateZ(0);
    }
    50% {
        transform: scale(1.15) rotateZ(180deg);
    }
    100% {
        transform: scale(1) rotateZ(360deg);
    }
}

.recommend .red a:hover {
    background-color: rgba(232, 57, 13, 0.8);
}

.recommend .green a:hover {
    background-color: rgba(80, 158, 96, 0.8);
}

.recommend .navy a:hover {
    background-color: rgba(82, 113, 173, 0.8);
}

.recommend .orange a:hover {
    background-color: rgba(234, 106, 42, 0.8);
}

.recommend .brawn a:hover {
    background-color: rgba(81, 65, 54, 0.8);
}

.recommend .blue a:hover {
    background-color: rgba(88, 185, 225, 0.8);
}

/* スクロールで表示 */

.is-active {
    opacity: 1;
    visibility: visible;
    animation: rotate-in .5s cubic-bezier(.25,.46,.45,.94) both;
}
@keyframes rotate-in {
    0% { 
        transform:rotate(15deg);
        transform-origin:100% 0;
        opacity:0
    }
    100% {
        transform:rotate(0);
        transform-origin:100% 0;
        opacity:1
    }
}

/* アニメーション */
.popup {
    animation: popup 0.45s cubic-bezier(0.22, 1, 0.36, 1) forwards .8s;
}
@keyframes popup {
    0% {
        transform: translateY(40px) scale(0.8);
        opacity: 0;
    }
    100% {
        transform: translateY(0) scale(1.0);
    }
    80%, 100% {
        opacity: 1;
    }
}

.fade-in-top {
    animation: fade-in-top .4s cubic-bezier(.39,.575,.565,1.000) both;
}
@keyframes fade-in-top { 
    0% {
        transform: translateY(-100px);opacity:0
    }
    100% {
        transform: translateY(0);opacity:1
    }
}

.scale-in-center {
    animation: scale-in-hor-center .7s cubic-bezier(.25,.46,.45,.94) both;
}
@keyframes scale-in-hor-center {
    0% {
        transform:scaleX(0);opacity:1
    }
    100% {
        transform:scaleX(1);opacity:1
    }
}

.delay-01 {
    animation-delay: .5s;
}

.delay-02 {
    animation-delay: .8s;
}

.delay-03 {
    animation-delay: 1.3s;
}

.delay-04 {
    animation-delay: 1.7s;
}


/*****************
固定ボタン
*****************/
/* ページトップボタン */
.page-top {
    position: fixed;
    bottom: 18.5vw;
    right: 3%;
    z-index: 99;
}

.page-top a {
    border-radius: 5px;
    background-color: #1D50A2;
    width: 8.5vw;
    height: 8.5vw;
    display: flex;
    align-items: center;
    justify-content: center;
}

.page-top a img {
    width: 60%;
}

.float-btn {
    width: 100%;
    padding: 3% 0 0;
    position: fixed;
    bottom: 0;
    right: 0;
    z-index: 99;
}

.float-btn__list {
    max-width: 750px;
    margin: 0 auto;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.footer {
    margin-bottom: 20%;
}

@media (768px < width) {
    .sp {
        display: none;
    }

    .pc {
        display: block;
    }

    .wrapping div:first-of-type dt {
        padding: 6% 0;
    }

    .page-top {
        bottom: 5%;
    }

    .page-top a {
        width: 50px;
        height: 50px;
    }

    .float-btn {
        width: auto;
        bottom: auto;
        top: 10%;
        right: 0;
    }
    
    .float-btn__list {
        max-width: 150px;
        margin: 0;
        flex-direction: column;
        align-items: end;
    }
    
    .float-btn__list li {
        width: 75%;
    }

    .footer {
        margin-bottom: 2%;
    }
    
}