@charset "utf-8";

/* 外部CSSの読み込み
------------------------------------------------------------ */
@import "base.css";
@import "contents.css";
@import "navi.css";

/* ------------------------------------------------------------ */
@import url("https://fonts.googleapis.com/css2?family=Josefin+Sans:ital,wght@0,100;0,300;0,400;1,200&display=swap");
#header h1 {
    font-size: 0.8em;
    color: #fff;
    position: absolute;
    left: 320px;
    top: 0;
}

.h1p {
    font-size: 0.8em;
    position: absolute;
    right: 0;
    top: 0;
}

#header .olaaa {
    width: 310px;
    height: 145px;
    margin-left: 5px;
}

.bt_home {
    width: 83px;
    height: 40px;
    background: url(../images/bg_navi_home.jpg) left top no-repeat;
    position: absolute;
    right: 5px;
    top: 35px;
}
.bt_home a:hover img {
    filter: alpha(opacity=0);
    -moz-opacity: 0;
    opacity: 0;
}
@media screen and (max-width: 1000px) {
    .h1p {
        display: none;
    }
    .bt_home {
        display: none;
    }
    #gnavi {
        display: none;
    }
    #header {
        height: 65px;
        background: url(../images/header-bg-sp.jpg);
        position: fixed;
        top: 0;
        z-index: 1000;
    }
    #header .olaaa {
        width: 140px;
        height: 65px;
    }
    #header h1 {
        display: none;
    }
}
.pc1000 {
    display: block;
}
.sp1000 {
    display: none;
}
@media screen and (max-width: 1000px) {
    .pc1000 {
        display: none;
    }
    .sp1000 {
        display: block;
    }
}
.pc767 {
    display: block;
}
.sp767 {
    display: none;
}
@media screen and (max-width: 767px) {
    .pc767 {
        display: none;
    }
    .sp767 {
        display: block;
    }
    #img_top {
        width: 100% !important;
        /* padding-left: 10px; */
    }
    #img_top img {
        /* display: flex; */
        margin: 0 auto;
    }
}

/*  */
nav {
    align-items: center;
    position: fixed;
    right: revert;
    right: 25px;
    top: 0px;
}
@media screen and (max-width: 1000px) {
    nav nav {
        display: inline;
    }
}
.menu__box {
    display: flex;
    flex-direction: row;
    list-style-type: none;
}
@media screen and (max-width: 1000px) {
    .menu__box {
        flex-direction: column;
        position: fixed;
        visibility: hidden;
        top: 0;
        left: 0;
        width: 100%;
        margin: -600px 0 0 0;
        padding: 156px 0;
        /* padding-top: 108px; */
        /* padding-bottom: 47vh; */
        text-align: center;
        background-color: #cbbd96;
        box-shadow: 1px 0 6px rgba(0, 0, 0, 0.2);
        z-index: 1;
        transition-duration: 0.5s;
    }
}

.red {
    /* color: #f06c64; */
}

.menu__item {
    display: flex;
    flex-direction: column;
    padding: 0 1em 0 1.9em;
    color: #ffffff;
    font-family: sans-serif;
    font-size: 14px;
    font-weight: 400;
    text-decoration: none;
    text-transform: uppercase;
}
@media screen and (max-width: 1000px) {
    .menu__item {
        display: block;
        padding: 12px 24px;
        color: #ffffff !important;
        font-size: 18px;
        transition-duration: 0.5s;
        font-weight: bold;
    }
    .menu__item:hover {
        /* background-color: #4f5464; */
    }
}

#menu__toggle {
    opacity: 0;
}
#menu__toggle:checked ~ .menu__btn > span {
    transform: rotate(45deg);
}
#menu__toggle:checked ~ .menu__btn > span::before {
    top: 0;
    transform: rotate(0);
    background: #fff;
}
#menu__toggle:checked ~ .menu__btn > span::after {
    top: 0;
    transform: rotate(90deg);
    background: #fff;
}
#menu__toggle:checked ~ .menu__box {
    visibility: visible;
    left: 0;
    margin: 0;
}

.menu__btn {
    transition-duration: 0.25s;
    box-sizing: border-box;
    display: flex;
    align-items: center;
    position: relative;
    bottom: 2px;
    width: 26px;
    height: 26px;
    cursor: pointer;
    z-index: 2;
}
.menu__btn span {
    display: inline-block;
    position: absolute;
    width: 100%;
    height: 3px;
    background-color: #ffffff;
}
.menu__btn span::before {
    display: inline-block;
    position: absolute;
    width: 100%;
    height: 3px;
    background-color: #ffffff;
    content: "";
    top: -8px;
    transition-duration: 0.25s;
}
.menu__btn span::after {
    display: inline-block;
    position: absolute;
    width: 100%;
    height: 3px;
    background-color: #ffffff;
    content: "";
    top: 8px;
    transition-duration: 0.25s;
}
@media screen and (min-width: 1000px) {
    .menu__btn {
        display: none;
    }
} /*# sourceMappingURL=log.css.map */
