@charset "utf-8";

/* CSS Document */

html {
    font-family: sans-serif;
    -ms-text-size-adjust: 100%;
    -webkit-text-size-adjust: 100%;
}

body {
    margin: 0px;
    padding: 0px;
    color: #333;
    /*全体の文字色*/
    font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", 'Montserrat', sans-serif, a-otf-ud-shin-maru-go-pr6n, sans-serif, ro-nikkatsu-sei-kai-std, serif;
    /*フォント種類*/
    font-size: 15px;
    /*文字サイズ*/
    line-height: 1.7;
    /*行間*/
    background: #fff;
    /*背景色*/
    -webkit-text-size-adjust: none;
}

h1,
h2,
h3,
h4,
h5,
p,
ul,
ol,
li,
dl,
dt,
dd,
form,
figure,
form {
    margin: 0px;
    padding: 0px;
    font-size: 100%;
    font-weight: normal;
}

ul {
    list-style-type: none;
}

ol {
    padding-left: 40px;
    padding-bottom: 15px;
}

img {
    border: none;
    max-width: 100%;
    height: auto;
    vertical-align: middle;
}

table {
    border-collapse: collapse;
    font-size: 100%;
    border-spacing: 0;
}

iframe {
    width: 100%;
}

img {
    max-width: 100%;
    height: auto;
}

* {
    word-break: break-word;
}


/*widthとborderとpaddingを足して100%*/

*,
*::before,
*::after {
    box-sizing: border-box;
}


/*margin top*/

.mt0 {
    margin-top: 0px;
}

.mt10 {
    margin-top: 10px;
}

.mt20 {
    margin-top: 20px;
}

.mt30 {
    margin-top: 30px;
}

.mt40 {
    margin-top: 40px;
}

.mt50 {
    margin-top: 50px;
}

.mt60 {
    margin-top: 60px;
}

.mt70 {
    margin-top: 70px;
}

.mt80 {
    margin-top: 80px;
}


/*margin bottom*/

.mb0 {
    margin-bottom: 0px;
}

.mb10 {
    margin-bottom: 10px;
}

.mb20 {
    margin-bottom: 20px;
}

.mb30 {
    margin-bottom: 30px;
}

.mb40 {
    margin-bottom: 40px;
}

.mb50 {
    margin-bottom: 50px;
}

.mb60 {
    margin-bottom: 60px;
}

.mb70 {
    margin-bottom: 70px;
}

.mb90 {
    margin-bottom: 90px;
}


/*margin right*/

.mr0 {
    margin-right: 0px;
}

.mr10 {
    margin-right: 10px;
}

.mr20 {
    margin-right: 20px;
}

.mr30 {
    margin-right: 30px;
}

.mr40 {
    margin-right: 40px;
}

.mr50 {
    margin-right: 50px;
}

.mr60 {
    margin-right: 60px;
}

.mr70 {
    margin-right: 70px;
}

.mr80 {
    margin-right: 80px;
}


/*margin left*/

.ml0 {
    margin-left: 0px;
}

.ml10 {
    margin-left: 10px;
}

.ml20 {
    margin-left: 20px;
}

.ml30 {
    margin-left: 30px;
}

.ml40 {
    margin-left: 40px;
}

.ml50 {
    margin-left: 50px;
}

.ml60 {
    margin-left: 60px;
}

.ml70 {
    margin-left: 70px;
}

.ml80 {
    margin-left: 80px;
}


/*padding top*/

.pt0 {
    padding-top: 0px;
}

.pt10 {
    padding-top: 10px;
}

.mt20 {
    padding-top: 20px;
}

.pt30 {
    padding-top: 30px;
}

.pt40 {
    padding-top: 40px;
}

.pt50 {
    margin-top: 50px;
}

.pt60 {
    padding-top: 60px;
}

.pt70 {
    padding-top: 70px;
}

.pt80 {
    padding-top: 80px;
}


/*margin bottom*/

.mb0 {
    margin-bottom: 0px;
}

.mb10 {
    margin-bottom: 10px;
}

.mb20 {
    margin-bottom: 20px;
}

.mb30 {
    margin-bottom: 30px;
}

.mb40 {
    margin-bottom: 40px;
}

.mb50 {
    margin-bottom: 50px;
}

.mb70 {
    margin-bottom: 70px;
}

.mb90 {
    margin-bottom: 90px;
}


/*margin right*/

.mr0 {
    margin-right: 0px;
}

.mr10 {
    margin-right: 10px;
}

.mr20 {
    margin-right: 20px;
}

.mr30 {
    margin-right: 30px;
}

.mr40 {
    margin-right: 40px;
}

.mr50 {
    margin-right: 50px;
}

.mr60 {
    margin-right: 60px;
}

.mr70 {
    margin-right: 70px;
}

.mr80 {
    margin-right: 80px;
}


/*text-align*/

.text_l {
    text-align: left;
}

.text_r {
    text-align: right;
}

.text_c {
    text-align: center;
}

.box_center {
    margin: 0 auto;
}

.clearfix:after {
    content: "";
    clear: both;
    display: block;
}


/*width*/

.w-5 {
    width: 5%;
}

.w-10 {
    width: 10%;
}

.w-15 {
    width: 15%;
}

.w-20 {
    width: 20%;
}

.w-25 {
    width: 25%;
}

.w-30 {
    width: 30%;
}

.w-35 {
    width: 35%;
}

.w-40 {
    width: 40%;
}

.w-45 {
    width: 45%;
}

.w-50 {
    width: 50%;
}

.w-55 {
    width: 55%;
}

.w-60 {
    width: 60%;
}

.w-65 {
    width: 65%;
}

.w-70 {
    width: 70%;
}

.w-75 {
    width: 75%;
}

.w-80 {
    width: 80%;
}

.w-85 {
    width: 85%;
}

.w-90 {
    width: 90%;
}

.w-95 {
    width: 95%;
}

@media screen and (max-width: 40em) {
    .w-5 {
        width: auto;
    }
    .w-10 {
        width: auto;
    }
    .w-15 {
        width: auto;
    }
    .w-20 {
        width: auto;
    }
    .w-25 {
        width: auto;
    }
    .w-30 {
        width: auto;
    }
    .w-35 {
        width: auto;
    }
    .w-40 {
        width: auto;
    }
    .w-45 {
        width: auto;
    }
    .w-50 {
        width: auto;
    }
    .w-55 {
        width: auto;
    }
    .w-60 {
        width: auto;
    }
    .w-65 {
        width: auto;
    }
    .w-70 {
        width: auto;
    }
    .w-75 {
        width: auto;
    }
    .w-80 {
        width: auto;
    }
    .w-85 {
        width: auto;
    }
    .w-90 {
        width: auto;
    }
    .w-95 {
        width: auto;
    }
    .sp-w-25 {
        width: 25%;
    }
    .sp-w-50 {
        width: 50%;
    }
    .sp-w-75 {
        width: 75%;
    }
}


/* padding: top */

hr {
    width: 100%;
    height: 1px;
    border: 0;
    background-color: #ebebeb;
    margin: 1.5em 0;
}

a {
    color: #333;
    text-decoration: none;
}

a:focus,
a:hover {
    color: #947c2b;
}

.font_l {
    font-size: 1.5em;
}

.s-font {
    font-size: .5em;
}

.font-red {
	color: red;
}
.font-blue {
	color:navy;
}

.font-bold {
	font-weight: bold;
}

/* 文字折り返し */

.wide-brake {
    display: none;
}

.pc-brake {
    display: inherit;
}

.pad-brake {
    display: none;
}

.sp-brake {
    display: none;
}

.spt-brake {
    display: none;
}

@media screen and (max-width: 1580px) {
    .wide-brake {
        display: inline;
    }
}

@media screen and (max-width: 1270px) {
    .wide-brake {
        display: none;
    }
}

@media screen and (max-width: 950px) {
    .pc-brake {
        display: none;
    }
    .pad-brake {
        display: inline;
    }
    .spt-brake {
        display: inline;
    }
	.sp-brake {
        display: none;
    }
}

@media screen and (max-width: 600px) {
    .pc-brake {
        display: none;
    }
    .pc-brake2 {
        display: none;
    }
	.pad-brake {
        display: none;
    }
    .sp-brake {
        display: inline;
    }
}
@media screen and (max-width: 600px) {
.sp-none {
	display: none;
	}
}


/* PC sp 表示・非表示 */
    @media(min-width:751px){
    .sp{
        display: none !important;
    	}
	}
	@media(max-width:750px){
    .pc{
        display: none !important;
       }
	}



/*ボックス横並び２個
---------------------------------------------------------------------------*/

*,
*:before,
*:after {
    box-sizing: border-box;
}

.col_2 {
    width: 100%;
    display: flex;
    display: -ms-flexbox;
    /* IE10 */
    flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    /* IE10 */
}

.col_2>div {
    width: 50%;
    padding: 10px;
}

@media screen and (max-width: 480px) {
    .col_2>div {
        width: 100%;
    }
}

/*ボックス横並び２個 SPボックスリバース
---------------------------------------------------------------------------*/

*,
*:before,
*:after {
    box-sizing: border-box;
}

.col_2_reverse {
    width: 100%;
    display: flex;
	flex-wrap: wrap;
}

.col_2_reverse>div {
    width: 50%;
    padding: 10px;
}

@media screen and (max-width: 480px) {
	.col_2_reverse {
	flex-wrap: wrap-reverse;
}
    .col_2_reverse>div {
        width: 100%;
    }
}


/*ボックス横並び３個
---------------------------------------------------------------------------*/

*,
*:before,
*:after {
    box-sizing: border-box;
}

.col_3 {
    width: 100%;
    display: flex;
    display: -ms-flexbox;
    /* IE10 */
    flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    /* IE10 */
}

.col_3>div {
    width: 33.33333%;
    padding: 10px;
}

@media screen and (max-width: 480px) {
    .col_3>div {
        width: 100%;
    }
}


/*ボックス横並び4個
---------------------------------------------------------------------------*/

*,
*:before,
*:after {
    box-sizing: border-box;
}

.col_4 {
    width: 100%;
    display: flex;
    display: -ms-flexbox;
    /* IE10 */
    flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    /* IE10 */
}

.col_4>div {
    width: 25%;
    padding: 10px;
}

@media screen and (max-width: 600px) {
    .col_4>div {
        width: 50%;
    }
}

@media screen and (max-width: 400px) {
    .col_4>div {
        width: 100%;
    }
}


/* image-container */

.image-container {
    position: relative;
    margin: 0 auto 1.5em;
}

.image-container.wide {
    width: 100%;
    max-width: 50em;
}

.image-container.middle {
    width: 80%;
    max-width: 50em;
}

.image-container.narrow {
    width: 40%;
    max-width: 50em;
}

.image-container.left {
    box-sizing: border-box;
    width: 90%;
    max-width: 60em;
    padding-right: 15em;
}

.image-container.right {
    box-sizing: border-box;
    width: 90%;
    max-width: 60em;
    padding-left: 15em;
}

@media screen and (max-width: 40em) {
    .read-image.middle {
        width: 100%;
    }
    .read-image.narrow {
        width: 60%;
    }
    .image-container.left,
    .image-container.right {
        width: 80%;
        max-width: 50em;
        margin: 0 auto 1.5em;
        padding: 0;
    }
}


/*--------------------------------------------------------------*/


/* ハンバーガーメニュ */

.toggle-button {
    display: block;
    position: fixed;
    top: 0;
    right: 0;
    z-index: 20;
    width: 4em;
    height: 4em;
    margin: 0;
    padding: 0;
    font-size: 1em;
    border-left: 1px solid #333;
    border-bottom: 1px solid #333;
    background-color: #000;
}

.toggle-button .line {
    display: block;
    position: absolute;
    top: 50%;
    left: 50%;
    width: 1.2em;
    height: .2em;
    margin: -.1em 0 0 -.6em;
    background-color: #E4B02D;
    transition: all .2s ease;
}

.toggle-button .line:nth-of-type(1) {
    transform: translateY(-0.4em);
}

.toggle-button .line:nth-of-type(3) {
    transform: translateY(0.4em);
}

.toggle-button.close .line:nth-of-type(1) {
    transform: rotate(-45deg);
}

.toggle-button.close .line:nth-of-type(2) {
    opacity: 0;
}

.toggle-button.close .line:nth-of-type(3) {
    transform: rotate(45deg);
}

@media screen and (min-width: 950px) {
    .toggle-button {
        display: none;
    }
}

@media screen and (max-width: 950px) {
    .toggle-button {
        display: block;
    }
}

.isnt-touch .toggle-button:hover {
    cursor: pointer;
}

.isnt-touch .toggle-button:hover .line:nth-of-type(1) {
    transform: translateY(-0.6em);
}

.isnt-touch .toggle-button:hover .line:nth-of-type(3) {
    transform: translateY(0.6em);
}

.isnt-touch .toggle-button.close:hover .line {
    width: 1.6em;
    margin: -.1em 0 0 -.8em;
}

.isnt-touch .toggle-button.close:hover .line:nth-of-type(1) {
    transform: rotate(-45deg);
}

.isnt-touch .toggle-button.close:hover .line:nth-of-type(3) {
    transform: rotate(45deg);
}


/* ヘッダー */

.header {
    position: fixed;
    top: 0;
    left: 0;
    z-index: 10;
    width: 100%;
    height: 5em;
    background-color: #000;
    transition: height .2s ease-out;
}

.header .site-title {
    position: absolute;
    top: 50%;
    left: 2em;
    transform: translateY(-50%);
}

.header .cmpany_name {
    position: absolute;
    top: 50%;
    right: 2em;
    transform: translateY(-140%);
    color: #fff;
    font-size: .7em;
}

.btn_header {
    padding-right: 20px;
}

.btn_header a {
    display: inline-block;
    text-align: center;
    background-color: #9c6a00;
    border: 1px solid #9c6a00;
    font-size: 10px;
    color: #9c6a00;
    text-decoration: none;
    font-weight: bold;
    position: relative;
    padding: 1px 20px;
}

.btn_header a span {
    position: relative;
    z-index: 1;
}

.btn_header a::before,
.btn_header a::after {
    content: "";
    display: block;
    background-color: #FFF;
    width: 50%;
    height: 100%;
    position: absolute;
    top: 0;
    transition: .2s;
}

.btn_header a::before {
    left: 0;
}

.btn_header a::after {
    right: 0;
}

.btn_header a:hover:before,
.btn_header a:hover:after {
    width: 0;
    background-color: #FFF;
}

.btn_header a:hover {
    color: #FFF;
}

.header .main-navi {
    position: absolute;
    top: 50%;
    right: 2em;
    transform: translateY(-20%);
}

.header.scrolled {
    height: 5em;
    border-bottom: 1px solid #ebebeb;
}


/* ヘッダーとタイトル*/

.header .site-title {
    margin: 0;
    font-family: "FrizQuadrataW01-Regular";
    font-size: 1em;
    line-height: 4rem;
    letter-spacing: .1em;
}

.header .site-title a {
    text-decoration: none;
    color: #222629;
}

.header .site-title .brand-logo {
    width: 18rem;
    margin-right: 2em;
    vertical-align: middle;
}

@media screen and (max-width: 950px) {
    .header .cmpany_name {
        right: 7em;
    }
}

@media screen and (max-width: 600px) {
    .header .site-title {
        position: relative;
        transition: left .2s ease-out;
        font-size: 4vw;
        line-height: 1;
        left: 1em;
    }
    .header .site-title .brand-logo {
        width: 15rem;
        margin-right: 4vw;
        margin-top: 10px;
    }
    .header.navi-open .site-title {
        left: -18em;
    }
    .header .cmpany_name {
        transform: translateY(-170%);
        left: 2em;
    }
    .btn_header {
        display: none;
    }
}

@media screen and (max-width: 400px) {
    .header .site-title .brand-logo {
        width: 12rem;
        margin-right: 4vw;
    }
}


/* site-navi: navi-open */

.site-main,
.site-aside,
.site-footer {
    position: relative;
    left: 0;
    transition: left .2s ease-out;
    opacity: 1;
}

.site-main.navi-open,
.site-aside.navi-open,
.site-footer.navi-open {
    left: -18em;
}


/* メインナビ */

.header .main-navi {
    font-family: "FrizQuadrataW01-Regular";
    font-size: .875em;
    line-height: 4rem;
    letter-spacing: .1em;
}

.header .main-navi .navi-item {
    display: inline-block;
    margin-left: 1.5em;
    text-decoration: none;
    color: #ffffff;
}

.header .main-navi .navi-item.current {
    color: #E4B02D
}

.header .main-navi .navi-item.disabled {
    color: #ccc;
}

.isnt-touch .header .main-navi a:hover {
    color: #E4B02D;
}

.isnt-touch .header .main-navi .entry:hover {
    color: #fff;
}

@media screen and (max-width: 950px) {
    .header .main-navi {
        position: fixed;
        top: 0;
        right: -18em;
        width: 18em;
        height: 100%;
        border-left: 1px solid #ebebeb;
        background-color: #000;
        font-size: 1em;
        line-height: 4rem;
        transform: translateY(0);
        transition: right .2s ease-out;
    }
    .header .main-navi.open {
        right: 0;
    }
    .header .main-navi .navi-wrapper {
        position: absolute;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
        width: 10em;
    }
    .header .main-navi a {
        display: block;
        margin: 0;
    }
    .header .main-navi a:before {
        content: '\f04b';
        font-family: 'Font Awesome 5 Free';
        font-size: 1em;
        font-weight: 900;
        color: #947c2b;
        margin-right: .5em;
        vertical-align: middle;
    }
    .header .main-navi .navi-item {
        margin-left: 0;
    }
    .header .main-navi .navi-item.disabled {
        display: block;
    }
}


/*ページメイン画像
---------------------------------------------------------------------------*/

#imgbox {
    background-color: #0045a0;
    margin: 0;
    padding: 0;
    text-align: center;
}

.conbox {
    width: 80%;
    margin: auto;
}


/* 横ラインのtitle */

.side-border-title {
    position: relative;
    text-align: center;
}

.side-border-title .title-text {
    display: inline-block;
    position: relative;
    padding: 0 1em;
    background-color: #fff;
}

.side-border-title:before {
    content: "";
    display: inline-block;
    position: absolute;
    top: 50%;
    left: 0;
    width: 100%;
    border-top: 1px solid #ebebeb;
}


/* イメージヘッダー小タイトル */

.heder_sfont {
    font-size: 1vw;
    color: #fff;
}

@media screen and (max-width: 50em) {
    .heder_sfont {
        font-size: 2vw;
        color: #fff;
    }
}


/* 下リンク */

.site-under {
    margin: 0 auto;
    padding: 4em 5% 0;
    border-top: 1px solid #ebebeb;
}

.primary-content .site-under {
    margin-top: 3em;
}

.secondary-content .site-under {
    margin-top: 3em;
}

.tertiary-content .site-under {
    margin-top: 6em;
}

.site-link {
    display: flex;
    flex-wrap: wrap;
    margin: 0 auto;
}

.site-link a {
    text-decoration: none;
}

.site-link .page-group {
    width: 16.666666%;
    padding: 0 1em;
    border-left: 1px solid #ebebeb;
    margin-bottom: 3em;
}

.site-link .group-title {
    margin-bottom: 1em;
    font-family: serif;
    font-weight: bold;
    font-style: normal;
}

.site-link .page-item {
    margin-left: 0;
    font-size: .875em;
}

.site-link .page-item a:before {
    content: '- ';
}

.site-link .disabled {
    color: #ccc;
}

@media screen and (max-width: 80em) {
    .site-link .page-group {
        width: 33.333333%;
    }
}

@media screen and (max-width: 950px) {
    .site-link .page-group {
        width: 50%;
    }
}

@media screen and (max-width: 600px) {
    .site-link .page-group {
        width: 100%;
    }
}


/* KUHL総合サイトリンク*/

.kjcase {
    width: 95%;
    margin: 0 auto;
}

#kj {
    position: relative;
    display: block;
    width: 100%;
    height: auto;
    background-color: black;
    padding: 10px;
}

#kj a {
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    width: 100%;
    color: #fff;
    font-size: .8em;
    text-align: center;
}

#kj a:hover {
    background-color: #9c6a00;
}


/* site-footer */

.site-footer {
    position: relative;
    margin-top: 1em;
    padding: 1em 5% 3em;
    border-top: 1px solid #ebebeb;
}

.copyright {
    font-family: monarcha, serif;
    font-weight: 400;
    font-style: normal;
    text-align: center;
    font-size: .75em;
}