@charset "UTF-8";

/*====================================================================================================

　CSS構成

　//絶対に変更しないCSS
　- reset.css           全てのブラウザ固有CSSをリセットするCSS。基本触らないこと。
　- bootstrap.min.css   Bootstrapコンポーネントを利用するためのCSS。基本触らないこと。
　- all.min.css         Font Awesome を利用するためのCSS。基本触らないこと。
　- aos.css             AOSを利用するためのCSS。基本触らないこと。

　//基本的には変更しないCSS
　- base.css            基本の文字設定や、Webフォントの読み込みなど。基本触らなくてもOK。

　//メインで利用しているCSS
　- common.css          ヘッダー、フッター、下層ページのタイトルなど、共通ページレイアウトを記載したCSS
　- stlye.css           各ページ固有のレイアウトを記載したCSS

　//補助的に利用しているCSS
　- module.css          見出しやリスト、テーブルなど、共通利用できるパーツをまとめたCSS
　- utility.css         マージンやパディング、文字サイズや文字色など、補助的に利用できるCSS

====================================================================================================*/


/*------------------------------------------------------------------
  base
------------------------------------------------------------------*/

html {
    overflow-x: hidden;
}

html {
    --bg-color: #f1f2f3;
    --primary-color: #4da6ff;
    --primary-deep-color-op06: rgba(77, 166, 255, .6);
    --primary-light-color: #b2d9ff;
    /* --accent-color: #0292f4; */
    --white-color: #fff;
    --gray-color: #cccccc;
    --gray-dark-color: #72706a;
    --gray-light-color: #ececec;
    --gray-color-op02: rgba(204, 204, 204, .2);
    --black-color: #000;
    --gradient-blue: linear-gradient(0deg, #4da6ff, #b2d9ff);
    --gradient-navy: linear-gradient(135deg, #0a1c2f, #4a6d89);
    --letter-spacing: .02em;
    position: relative;
    font-family: "Zen Old Mincho", serif;
    --jp-ttl-font: "Zen Old Mincho", serif;
    --en-font: "Zen Old Mincho", serif;
    font-weight: 500;
    color: var(--black-color);
    letter-spacing: .03em;
    line-height: 1.725;
    z-index: 1;
    background-size: cover;
}

a {
    color: var(--white-color);
}

.nav-tel a {
    color: var(--white-color);
}

body {
    font-size: 1rem;
    background-color: var(--bg-color);
}

@media screen and (max-width:1599px) {
    body {
        font-size: 1.125rem;
    }
}

@media screen and (max-width:991px) {
    body {
        /* font-size: 1rem; */
    }
}

@media screen and (max-width:574px) {
    body {
        font-size: 1rem;
    }
}

@media screen and (max-width:374px) {
    body {
        /* font-size: 0.85rem; */
    }
}

* {
    /* letter-spacing: var(--letter-spacing); */
}

hr {
    border-top: 1px dashed #ccc;
    border-right: none;
    border-bottom: none;
    border-left: none;
}

main {
    overflow: hidden;
}


/* input-style ----------------------------------------*/

input[type="text"],
input[type="password"],
input[type="tel"],
input[type="email"],
input[type="number"],
select,
textarea {
    padding: 8px;
    border: 1px solid #ddd;
    background: #fff;
    border-radius: 3px;
}

select {
    padding: 8px 25px 8px 10px;
}

input[type="text"]:focus,
input[type="password"]:focus,
input[type="tel"]:focus,
input[type="email"]:focus,
input[type="number"]:focus,
select:focus,
textarea:focus {
    /* border: 1px solid #fff; */
    /* box-shadow: 0 0 5px 0 #9cb4f8; */
}


/* input[type="text"].required,
input[type="password"].required,
input[type="tel"].required,
input[type="email"].required,
input[type="number"].required,
select.required,
textarea.required {
    border: 1px solid var(--red-color);
    background: rgba(224, 71, 71,.1);
} */

input[type="text"].required:focus,
input[type="password"].required:focus,
input[type="tel"].required:focus,
input[type="email"].required:focus,
input[type="number"].required:focus,
select.required:focus,
textarea.required:focus {
    border: 1px solid var(--primary-color);
    /* box-shadow: 0 0 5px 0 #f89c9c; */
}

label:hover,
select:hover {
    cursor: pointer;
}

.inputfile_box {
    margin-bottom: 15px;
}

::-webkit-input-placeholder {
    color: #aaa;
    opacity: 1;
}

:-moz-placeholder {
    color: #aaa;
}

::-moz-placeholder {
    color: #aaaaaa;
    opacity: 1;
}

:-ms-input-placeholder {
    color: #aaa;
}


/*------------------------------------------------------------------
  Custom Bootstrap
------------------------------------------------------------------*/

.container,
.container-sm,
.container-md,
.container-lg,
.container-xl,
.container-fluid {
    padding-left: 6vw;
    padding-right: 6vw;
}

@media (min-width: 576px) {
    .container,
    .container-sm {
        max-width: initial;
    }
}

@media screen and (min-width:768px) {
    .container,
    .container-sm,
    .container-md {
        max-width: initial;
    }
}

@media screen and (min-width:992px) {
    .container,
    .container-sm,
    .container-md,
    .container-lg,
    .container-xl,
    .container-fluid {
        padding-left: 60px;
        padding-right: 60px;
    }
    .container,
    .container-sm,
    .container-md,
    .container-lg {
        max-width: initial;
    }
}

@media screen and (min-width:1200px) {
    .container,
    .container-sm,
    .container-md,
    .container-lg,
    .container-xl {
        max-width: 1470px;
    }
}

@media print {
    .container,
    .container-sm,
    .container-md,
    .container-lg,
    .container-xl,
    .container-fluid {
        padding: 0 15px !important;
    }
}