@charset "utf-8";
@import url('https://fonts.googleapis.com/css2?family=Cabin:wght@700&display=swap');
/*------------------------------------------------------------
    デフォルトスタイル
------------------------------------------------------------*/
html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, font, img, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, b, u, i, center, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td {
    margin: 0;
    padding: 0;
    background: transparent;
    border: 0;
    outline: 0;
    font-size: 1em;
}
html {
    font-size: 62.5%;
}
body, table, input, textarea, select, option {
    font-family: "游ゴシック", "Yu Gothic", "游ゴシック体", "YuGothic", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "Meiryo UI", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
}
article, aside, canvas, details, figcaption, figure, footer, header, hgroup, menu, nav, section, summary {
    display: block;
}
ol, ul {
    list-style: none;
}
blockquote, q {
    quotes: none;
}
:focus {
    outline: 0;
}
ins {
    text-decoration: none;
}
del {
    text-decoration: line-through;
}
img {
    vertical-align: top;
    max-width: 100%;
    height: auto;
}
a, a:link {
    color: #1e1e1e;
    text-decoration: none;
}
a:visited {
    color: #1e1e1e;
}
a:hover {
    color: #1e1e1e;
}
a:active {
    color: #1e1e1e;
}
/*------------------------------------------------------------
    レイアウト
------------------------------------------------------------*/
body {
    min-width: 1200px;
    color: #1e1e1e;
    font-size: 16px;
    font-weight: 500;
    line-height: 1.5;
    font-feature-settings: "palt";
    background-color: #FFF;
}
#container {
    padding-top: 89px;
    text-align: left;
}
#main {
    margin-bottom: 80px;
}
/*------------------------------------------------------------
    ヘッダー
------------------------------------------------------------*/
#gHeader {
    width: 100%;
    position: fixed;
    left: 0;
    top: 0;
    z-index: 100;
    background: #fff;
}
#gHeader::after {
    width: 100%;
    height: 15px;
    position: absolute;
    left: 0;
    top: 100%;
    background-image: -moz-linear-gradient(90deg, rgba(226, 226, 226, 0) 0%, rgb(226, 226, 226) 100%, rgb(226, 226, 226) 100%);
    background-image: -webkit-linear-gradient(90deg, rgba(226, 226, 226, 0) 0%, rgb(226, 226, 226) 100%, rgb(226, 226, 226) 100%);
    background-image: -ms-linear-gradient(90deg, rgba(226, 226, 226, 0) 0%, rgb(226, 226, 226) 100%, rgb(226, 226, 226) 100%);
    content: '';
}
#gHeader h1 {
    box-sizing: border-box;
    margin: 0 auto 4px;
    padding-top: 7px;
    width: 1180px;
    font-size: 13px;
    font-weight: 500;
}
#gHeader .h-wrap {
    margin: 0 auto;
    width: 1180px;
}
#gHeader .h-box {
    box-sizing: border-box;
    padding-bottom: 13px;
    width: 705px;
    float: left;
}
#gHeader .tel a {
    display: inline-block;
    vertical-align: top;
}
#gHeader .tel a:hover {
    opacity: 0.7;
}
#gHeader .logo {
    margin-top: 4px;
}
#gHeader .h-btn {
    margin-top: -31px;
    width: 367px;
    float: right;
}
#gHeader .h-btn a {
    display: block;
}
#gHeader .h-btn a .on {
    display: none;
}
#gHeader .h-btn a:hover .on {
    display: block;
}
#gHeader .h-btn a:hover .off {
    display: none;
}
/*------------------------------------------------------------
    フッター
------------------------------------------------------------*/
#gFooter {
    padding-bottom: 20px;
    background: #282828;
}
#gFooter p {
    padding: 15px;
    text-align: center;
    font-size: 14px;
    line-height: 1.7;
    letter-spacing: 0.075em;
    background: #ebebeb;
}
#gFooter p em {
    font-style: normal;
    font-weight: bold;
}
#gFooter a:hover {
    opacity: 0.7;
}
.page-top {
    position: fixed;
    right: 30px;
    bottom: 40px;
}
.page-top a {
    display: block;
}
.page-top a:hover {
    opacity: 0.7;
}