@charset "utf-8";


/* ------ */

.pan ol {
    display: flex;
    flex-wrap: wrap;
    list-style: none;
    margin: 3% 0;
}

.pan ol li {
    font-size: 16px;
}

.pan ol li a {
    border-bottom: dotted 1px rgb(0, 0, 0);
}

.pan ol li:not(:last-of-type)::after {
    content: "›";
    margin: 0 .6em;
    color: #777;
}

.flex {
    display: flex;
}

/*------------------------
メインビジュアル
-------------------------*/

.main_visual {
    width: 100%;
    max-width: 1200px;
    margin: 0 auto;
    position: relative;
}

.main_visual img {
    width: 100%;
}

.main_visual h1 {
    width: max-content;
    font-size: 32px;
    color: #fff;
    margin: 0 auto;
    padding: 16px 26px;
    position: absolute;
    top: 42%;
    right: 0;
    left: 0;
    margin: auto;
    border: solid 2px #fff;
}

.to_allergy {
    width: 80%;
    max-width: 1200px;
    margin: 5% auto;
}

.to_allergy a {
    font-size: 32px;
    font-weight: 700;
    padding: 0 5px 5px;
    border-bottom: solid 2px rgb(255, 143, 143);
}

@media (max-width: 800px) {

    .main_visual h1 {
        width: max-content;
        font-size: 20px;
        color: #fff;
        margin: 0 auto;
        padding: 16px 26px;
        position: absolute;
        top: 30%;
        right: 0;
        left: 0;
        margin: auto;
        border: solid 2px #fff;
    }

    .to_allergy a {
        font-size: 16px;
        font-weight: 700;
        padding: 0 5px 5px;
        border-bottom: solid 2px rgb(255, 143, 143);
    }

    .to_allergy {
        width: 80%;
        max-width: 1200px;
        margin: 5% auto 0;
    }

}


/*----------------------------
sec01
-----------------------------*/


.sec01 {
    width: 100%;
    max-width: 1200px;
    margin: 120px auto 0;
}

.sec01 h2 {
    display: flex;
    align-items: center;
    font-size: 32px;
}

.sec01 h2::before {
    content: " ";
    width: 2.5em;
    height: 2px;
    margin-right: 16px;
    background-color: rgb(255, 143, 143);
}

.sec01 .contents {
    width: 80%;
    margin: 5% auto;
}

.sec01 .contents .title {
    position: relative;
}

.sec01 .contents .title img {
    width: 100%;
}

.sec01 .contents .title p {
    width: max-content;
    text-align: center;
    font-size: 32px;
    color: #fff;
    margin: 0 auto;
    padding: 16px 26px;
    position: absolute;
    top: 42%;
    right: 0;
    left: 0;
    margin: auto;
    border: solid 2px #fff;
}

.sec01 .contents .comment {
    font-size: 30px;
}

.sec01 .contents .flex {
    width: 100%;
}

.sec01 .contents .flex p {
    font-size: 16px;
}

.sec01 .contents .flex .text {
    padding-left: 16px;
}

.sec01 .contents .flex .left {
    width: 35%;
}

.sec01 .contents .flex .left .title {
    background-color: antiquewhite;
    padding: 10px 0 10px 10px;
}

.sec01 .contents .flex .right {
    width: 60%;
    margin: 0 0 0 5%;
}

.sec01 .contents .flex .right .title {
    background-color: antiquewhite;
    padding: 10px 0 10px 16px;
}


.sec01 .contents .title02 {
    background-color: antiquewhite;
    padding: 10px 0 10px 16px;
}

.sec01 .contents .text {
    font-size: 16px;
    padding-left: 16px;
}


.sec01 .link {
    padding: 0;
    margin: 2% auto;
    width: 100%;
    display: flex;
    align-items: center;
}

.sec01 .link li {
    list-style: none;
    border-bottom: solid 1px #fff;
    margin-left: 20px;
}

.sec01 .link li:hover {
    list-style: none;
    border-bottom: solid 1px rgb(255, 143, 143);
}

.sec01 .link img {
    width: 15%;
    margin: 0 2%;
}

@media (max-width: 800px) {

    .sec01 {
        width: 100%;
        max-width: 1200px;
        margin: 50px auto 0;
        padding: 0;
    }

    .sec01 .contents .title p {
        width: max-content;
        font-size: 24px;
        color: #fff;
        margin: 0 auto;
        padding: 16px 26px;
        position: absolute;
        top: 32%;
        right: 0;
        left: 0;
        margin: auto;
        border: solid 2px #fff;
        text-shadow: 1px 2px 3px #808080;
    }

    .mobile_br {
        display: none;
    }

    .sec01 .contents .flex {
        width: 100%;
        display: block;
    }

    .sec01 .contents .flex .left {
        width: 100%;
    }

    .sec01 .contents .flex .right {
        width: 100%;
        margin: 0 0 0 0%;
    }

    .sec01 .contents .comment {
        font-size: 24px;
    }

    .sec01 h2::before {
        content: " ";
        width: 1.5em;
        height: 2px;
        margin-right: 16px;
        background-color: rgb(255, 143, 143);
    }

    .sec01 .link {
        padding: 0;
        margin: 2% auto;
        width: 100%;
        display: block;
        align-items: center;
    }

    .sec01 .link li {
        list-style: none;
        border-bottom: solid 1px #fff;
        margin-left: 5px;
        text-align: center;
        margin-bottom: 10px;
        padding-bottom: 3px;
        border-bottom: solid 1px rgb(255, 143, 143);
        width: max-content;
    }

}

/*------------------------
sec02
------------------------*/

.sec02 h2 {
    display: flex;
    align-items: center;
    font-size: 32px;
    padding-top: 7%;
}

.sec02 h2::before {
    content: " ";
    width: 2.5em;
    height: 2px;
    margin-right: 16px;
    background-color: rgb(255, 143, 143);
}

.sec02 {
    width: 100%;
    max-width: 1200px;
    margin: 120px auto 10%;
}


.sec02 .hyou {
    width: 90%;
    margin: 0 auto;
}

.scroll {
    display: none;
}

@media (max-width: 800px) {

    .sec02 .hyou {
        width: 1200px;
        margin: 0 30px;
    }

    .sec02 {
        overflow-y: scroll;
        margin: 50px auto 20%;
    }

    .sec02 h2 {
        display: flex;
        align-items: center;
        font-size: 26px;
        padding-top: 7%;
    }

    .sec02 h2::before {
        content: " ";
        width: 1.5em;
        height: 2px;
        margin-right: 16px;
        background-color: rgb(255, 143, 143);
    }

    .scroll {
        display: block;
        margin: 10% 0 0% 10%;
        font-size: 20px;
        font-weight: 500;
        color: #000;
    }

    .scroll::after {
        content: "→";
        margin-left: 10px;
        color: rgb(255, 143, 143);
    }

}










/* ----- */