/* おおまかにブレイクポイントを決める
SP ~ 519px
tab 520px ~ 959px
PC 960px~
*/

/* =======================
変数宣言
:root {
    --変数名1:値1;
    --変数名2:値2;
}
=======================*/
:root {
    --size-xs: 1rem;
    --size-sm: 1.2rem;
    --size-md: 1.6rem;
    --size-lg: 2.4rem;
    --size-xl: 3.2rem;
    --size-xxl: 4.2rem;
    --size-xxxl: 6.6rem;
    --text-color: #333333;
    --main-color: #ffbf00;
    --accent-color: #b92946;
    --sub-color: #ffe642;
    --gray-color: #bdbebd;
    --main-color-rgb: 255, 191, 0;
    --font-sans: 'Noto Sans JP', sans-serif;
    --font-serif: 'Noto Serif JP', serif;
    --gutter-base: 8px;
    --side-gutter: calc(var(--gutter-base)*2);
    --contents-gutter: calc(var(--gutter-base)*7.5);
    --contents-gutter-pc: calc(var(--gutter-base)*12.5);
    --section-gutter: calc(var(--gutter-base)*10);
    --section-gutter-pc: calc(var(--gutter-base)*20);
    --footer-gutter: calc(var(--gutter-base)*30);
}


/* =======================
共通設定
=======================*/
html {
    font-size: 62.5%;
    scroll-behavior: smooth;
}

body {
    font-size: var(--size-md);
    color: var(--text-color);
    line-height: 1.75;
    font-family: var(--font-sans);
}


a {
    /* aタグのテキストデコレーションを消す */
    text-decoration: none;
    color: var(--text-color);
}

.center {
    max-width: 1240px;
    margin-left: auto;
    margin-right: auto;
}

.btn {
    border: 1px solid var(--text-color);
    display: block;
    max-width: 320px;
    line-height: 90px;
    margin-left: auto;
    margin-right: auto;
    text-align: center;
    transition: 0.4s;
}

.title {
    text-align: center;
    font-size: var(--size-lg);
    font-weight: 600;
    letter-spacing: 0.24rem;
}

/*--- スクロールダウン ---*/
.scroll {
    right: var(--gutter-base);
}

.scroll .scroll_down::before {
    content: "";
    display: block;
    width: 1px;
    height: 80px;
    background-color: #ffe642;
    position: absolute;
    top: calc(90% - 40px);
    right: var(--side-gutter);
}

.scroll .scroll_down::after {
    content: "";
    display: block;
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background-color: #ffe642;
    position: absolute;
    transform-origin: center;
    top: calc(90% - 40px);
    right: calc(var(--side-gutter) - 4px);
    animation: anim 2s ease-out infinite;
}

@keyframes anim {
    0% {
        transform: scale(0) translateY(0);
        opacity: 0;
    }

    70% {
        transform: scale(1) translateY(75px);
        opacity: 1;
    }

    90% {
        transform: scale(1) translateY(75px);
        opacity: 1;
    }

    100% {
        transform: scale(1) translateY(75px);
        opacity: 0;

    }
}

@media screen and (min-width:710px) {

    .title {
        font-size: var(--size-xl);
    }

    /* ========min-width:710px======== */
}

@media screen and (min-width:960px) {

    .btn:hover {
        border: 1px solid var(--main-color);
        background-color: var(--main-color);
        color: #fff;
    }

    .title {
        font-size: var(--size-xxl);
    }

    /* ========min-width:960px======== */
}

/* =======================
ヘッダー、ナビ
=======================*/

/* スマホ用ナビ */
header nav {
    background-color: rgba(var(--main-color-rgb), 0.96);
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100vh;
    padding-top: calc(var(--gutter-base)*10);
    padding-left: calc(var(--gutter-base)*5);
    padding-right: calc(var(--gutter-base)*5);
    transition: 0.3s;
    /* ふわっと消せないdisplay: none;じゃない方法で消す */
    opacity: 0;
    /* リンクは消えた訳ではないので、visibility: hidden; */
    visibility: hidden;
}

header.on nav {
    /* 押されたらふわっと出てくる */
    opacity: 1;
    visibility: visible;
}

header nav a {
    color: var(--text-color);
    font-size: var(--size-lg);
    line-height: 2.4;
    text-align: center;
    /* border-bottom: 2px dotted #fff; */
    display: block;
}

header nav span {
    display: block;
    font-size: var(--size-lg);
    margin-top: var(--section-gutter);
    padding: calc(var(--gutter-base)*3);
    border: 2px solid var(--text-color);
    text-align: center;
}

@media screen and (min-width:300px) {
    header nav a {
        font-size: var(--size-xl);
    }

    /* ========min-width:300px======== */
}

/* ヘッダー */
header {
    z-index: 100;
    position: fixed;
    width: 100%;
    top: 0;
    padding-top: var(--gutter-base);
    padding-left: var(--gutter-base);
    padding-right: var(--gutter-base);
}

header .header_inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
}

header .header_inner h1 {
    width: 120px;
}

header .hum_menu {
    color: var(--text-color);
    display: flex;
    align-items: center;
    gap: var(--gutter-base);
    z-index: 10;
    mix-blend-mode: difference;
    /* 色が重なったところの文字の色が反転する。この場合、黒へ*/
}

header .hum_menu span {
    display: inline-block;
    transition: all .4s;
    /*アニメーションの設定*/
    position: absolute;
    right: var(--side-gutter);
    height: 3px;
    background: #fff;
    width: 45%;
}

header .hum_menu span:nth-of-type(1),
header .hum_menu span:nth-of-type(2),
header .hum_menu span:nth-of-type(3) {
    content: "";
    display: block;
    width: 36px;
    height: 4px;
    background-color: var(--main-color);
    transition: 0.3s;
}

header .hum_menu span:nth-of-type(2) {
    transform: translateY(-14px);
}

header .hum_menu span:nth-of-type(3) {
    transform: translateY(14px);
}

/* headerとonの間は半角スペースなし */
/* class onがくっついたheaderの意味 */
/* 最初の位置に戻して、45度傾ける */
header.on .hum_menu span:nth-of-type(1) {
    opacity: 0;
}

header.on .hum_menu span:nth-of-type(2) {
    transform: translateY(0) rotate(45deg);
}

header.on .hum_menu span:nth-of-type(3) {
    transform: translateY(0) rotate(-45deg);
}

@media screen and (min-width:960px) {
    header {
        padding-top: calc(var(--gutter-base)*4);
        padding-left: calc(var(--gutter-base)*4);
        padding-right: calc(var(--gutter-base)*4);
    }

    /* ハンバーガーメニューを消す */
    /* 詳細度が負けているので、同等にする header .hum_menu と後ろに書かれたものが優先される*/
    header .hum_menu {
        display: none;
    }

    header nav {
        visibility: visible;
        opacity: 1;
        /* positionを元の状態に戻す */
        position: static;
        width: auto;
        height: auto;
        padding: 0;
        /* 背景の色を消す と文字も透明になって見えなくなる → aタグで色指定*/
        background-color: transparent;
    }

    header nav ul {
        display: flex;
        gap: 20px;
    }

    header nav a {
        font-size: var(--size-md);
        color: var(--main-color);
        border-bottom: none;
        line-height: 1;
    }

    header nav span {
        display: none;
    }

    /* ========min-width:960px======== */
}

/* ============
 サブページのトップ
 ============ */
.subpage_top {
    margin-bottom: var(--section-gutter);
    width: 100%;
}

.subpage_top_image {
    width: 100%;
    max-width: 2000px;
    height: 32vh;
    z-index: -1;
}

.subpage_top .subpage_top_image_inner {
    width: 100%;
    height: 100%;
    background-image: url("../../img/subpage_top.jpg");
    background-position: center;
    background-size: cover;
    background-repeat: no-repeat;
    color: #fff;
    position: relative;
}

@media screen and (min-width:960px) {

    .subpage_top {
        max-width: 2000px;
        margin-bottom: var(--section-gutter-pc);
    }

    /* ========min-width:960px===
    
    ===== */
}

/* =======================
フッター
=======================*/
footer {
    margin-top: calc(var(--section-gutter)*1.5);
    border-top: 1px solid var(--text-color);
    border-bottom: calc(var(--gutter-base)*3) solid var(--main-color);
    padding-top: calc(var(--gutter-base)*3);
    padding-bottom: var(--side-gutter);
}

footer img {
    width: 40%;
    margin-left: auto;
    margin-right: auto;
    max-width: 260px;
    margin-bottom: calc(var(--gutter-base)*3);
}

footer span {
    display: block;
    text-align: center;
}

footer address {
    font-size: var(--size-md);
    text-align: center;
    font-style: normal;
    margin-bottom: calc(var(--gutter-base)*3);
}

footer small {
    display: block;
    text-align: center;
}

@media screen and (min-width:520px) {

    footer {
        margin-top: var(--section-gutter-pc);
        padding-top: calc(var(--gutter-base)*5);
    }

    /* ========min-width:520px======== */
}

@media screen and (min-width:960px) {

    footer {
        margin-top: var(--footer-gutter);
        padding-top: var(--contents-gutter);
        padding-bottom: calc(var(--gutter-base)*3);
    }


    /* ========min-width:520px======== */
}

/* =======================
Javascript効果
=======================*/
/* 画面全体がフェードイン */
.body_top {
    opacity: 0;
}

/* タイトルのスライディング表示 */
.effect_area {
    max-width: 320px;
    margin-left: auto;
    margin-right: auto;
}

.sliding2,
.sliding {
    overflow: hidden;
    position: relative;
}

.sliding2::before,
.sliding2::after,
.sliding::before,
.sliding::after {
    content: "";
    display: block;
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    transition: 0.4s;
}

#motto .motto_inner .motto_content .effect_area .sliding::before {
    background-color: var(--accent-color);
    transition-delay: 0.2s;
}

.sliding::before {
    background-color: var(--main-color);
    transition-delay: 0.2s;
}

.sliding2::after,
.sliding::after {
    background-color: #ffffff;
}

.sliding2::before,
.sliding2::after,
.sliding.on::before,
.sliding.on::after {
    left: 100%;
}