@charset "UTF-8";

/* ======================================================
/  サイト入口
/====================================================== */
body {
    background: #fff;
}

.ib {
    display: inline-block;
}

/* header
/====================================================== */
header.header {
    background-color: #fff;
    border-bottom: 25px solid #FFEC00;
}

.header-inr {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    gap: 10px;
    position: relative;
    max-width: 1100px;
    margin: 0 auto;
    padding: 12px 15px;
}

.header-address {
    font-size: 14px;
}

.header-address span {
        color: #faa0b4;
}

.header-address .tels {
    font-size: min(6vw,23px);
    font-weight: bold;
    line-height: 1.1;
}

@media screen and (max-width: 800px) {
header.header .pc-il {
    display: inline;
}

.header-address span.season {
    font-size: min(4vw,14.4px);
}
}

@media screen and (min-width: 801px) {
    .header-inr {
        display: flex;
        align-items: center;
        justify-content: space-between;
        overflow: hidden;
        padding: 60px 15px 20px;
    }
	.header-address .tels  {
        font-size: 23px;
	}
}

/* mv
/====================================================== */
.mv_visual_inr {
    max-width: 1200px;
    position: relative;
}

.mv_visual_body {
    position: absolute;
    width: min(30vw, 224px);
    height: min(30vw, 224px);
    display: flex;
    left: 67%;
    bottom: 4%;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    background-color: #e9452c;
    border-radius: 50%;
}

.mv_visual_txt {
    color: #FFEC00;
    padding-top: 3vw;
    font-size: min(3.8vw, 24px);
    font-weight: bold;
    letter-spacing: 0.03em;
    line-height: 1.3;
}

.mv_visual_txt span {
    color: #fff;
    font-size: min(3vw, 22px);
    margin-top: min(1vw, 13px);
    line-height: 1.27;
    letter-spacing: 0.03em;
    display: block;
}

@media screen and (min-width: 801px) {
    .mv_visual_body {
        width: min(19vw, 224px);
        height: min(19vw, 224px);
        left: 61%;
        bottom: 4%;
    }

    .mv_visual_txt {
        font-size: min(2vw, 23px);
        padding-top: 23px;
    }

    .mv_visual_txt span {
        line-height: 1.75;
        font-size: min(1.5vw, 16px);
        margin-top: min(1vw, 13px);
    }
}

/* philosophy
/====================================================== */
.philosophy {
    color: #474645;
    padding: 65px 0 80px;
    overflow: hidden;
}

.philosophy-inr {
    max-width: 500px;
    margin: 0 auto;
    position: relative;
    padding: 0 10px;
}

.philosophy-inr::before {
    content: "";
    display: block;
    width: 35vw;
    aspect-ratio: 270 / 507;
    background: url(../img/entrance/img_entrance01.png?240925) no-repeat;
    background-size: contain;
    position: relative;
    top: -30px;
    left: 50%;
    transform: translateX(-107%);
}

.philosophy-inr::after {
    content: "";
    display: block;
    width: 35vw;
    aspect-ratio: 270 / 485;
    background: url(../img/entrance/img_entrance02.png?240925) no-repeat;
    background-size: contain;
    position: absolute;
    top: -10px;
    left: 61%;
}

.philosophy-title {
    color: #E12C1F;
    font-size: 32px;
    font-weight: bold;
    text-align: center;
    position: relative;
    text-align: center;
    max-width: 465px;
    margin: 0 auto 30px;
    letter-spacing: 0.14em;
}

.philosophy-title::after {
    content: "";
    position: absolute;
    width: 100%;
    height: 5px;
    left: 0;
    bottom: 0;
    background: url(../img/entrance/deco_line.png);
}

.philosophy-subtitle {
    font-size: min(4.5vw,23px);
    font-weight: bold;
    text-align: center;
    margin-bottom: 60px;
    letter-spacing: 0.14em;
    line-height: 1.65;
}

.philosophy-subtitle span {
    color: #E12C1F;
}

.philosophy-tagline {
    font-size: min(5vw,19px);
    color: #E12C1F;
    font-weight: bold;
    text-align: center;
    margin-bottom: 8px;
    letter-spacing: 0.075em;
    line-height: 1.33;
}

.philosophy-txt {
    line-height: 2;
    max-width: 480px;
    margin: 0 auto;
    font-size: min(4vw,14px);
    letter-spacing: 0.02em;
    text-align: justify;
}

.entrance_bnr {
    padding: 0 20px;
}

.entrance_bnr ul {
    display: flex;
    align-items: center;
    flex-direction: column;
    justify-content: center;
    max-width: 1000px;
    margin: 0 auto;
    gap: 20px;
}

.entrance_bnr ul li {
    max-width: 400px;
}



@media screen and (min-width: 801px) {
    .entrance_bnr ul {
        flex-direction: row;
        gap: 5%;
    }

    .philosophy-inr::before {
        position: absolute;
        width: 271px;
        height: 507px;
        top: -30px;
        right: 100%;
        left: initial;
        aspect-ratio: auto;
        transform: none;
    }
    
    .philosophy-inr::after {
        width: 270px;
        height: 485px;
        top: -10px;
        left: 105%;
        right: initial;
        aspect-ratio: auto;
        transform: none;
    }
}

.copy {
    font-size: 10px;
    padding: 20px 10px;
    margin-top: 40px;
    font-weight: bold;
    color: #1A1311;
    background-color: #D4D5D5;
    border: none;
    text-align: center;
}
