
/* CSS Document */
@font-face { font-family: "fgm"; font-display: swap; src: url("../font/fg-m.woff2") format("woff2"), url("../font/fg-m.woff") format("woff"); }
@font-face { font-family: "impact"; font-display: swap; src: url("../font/impact.woff2") format("woff2"), url("../font/impact.woff") format("woff"); }
@font-face { font-family: 'nsj'; font-style: normal; font-weight: 300; font-display: swap; src: local("Noto Sans CJK JP Light"), url("../font/NotoSansJP-Light.woff2") format("woff2"), url("../font/NotoSansJP-Light.woff") format("woff"), url("https://fonts.gstatic.com/ea/notosansjp/v5/NotoSansJP-Light.otf") format("opentype"); }
@font-face { font-family: 'nsj-reg'; font-style: normal; font-weight: 400; font-display: swap; src: local("Noto Sans CJK JP"), url(../font/NotoSansJP-Regular.woff2) format("woff2"), url(../font/NotoSansJP-Regular.woff) format("woff"), url(https://fonts.gstatic.com/ea/notosansjp/v5/NotoSansJP-Regular.otf) format("opentype"); }
@font-face { font-family: 'nsj-md'; font-style: normal; font-weight: 500; font-display: swap; src: local("Noto Sans CJK JP"), url(../font/NotoSansJP-Medium.woff2) format("woff2"), url(../font/NotoSansJP-Medium.woff) format("woff"), url(https://fonts.gstatic.com/ea/notosansjp/v5/NotoSansJP-Medium.otf) format("opentype"); }
@font-face { font-family: 'nsj-bold'; font-style: normal; font-weight: 700; font-display: swap; src: local("Noto Sans CJK JP"), url(../font/NotoSansJP-Bold.woff2) format("woff2"), url(../font/NotoSansJP-Bold.woff) format("woff"), url(https://fonts.gstatic.com/ea/notosansjp/v5/NotoSansJP-Bold.otf) format("opentype"); }
@font-face { font-family: 'nsj-black'; font-style: normal; font-weight: 900; font-display: swap; src: local("Noto Sans CJK JP"), url(../font/NotoSansJP-Bold.woff2) format("woff2"), url(../font/NotoSansJP-Bold.woff) format("woff"), url(https://fonts.gstatic.com/ea/notosansjp/v5/NotoSansJP-Bold.otf) format("opentype"); }
/*/--------------------------------------------------------------------------/*/
/* ===== CLEARFIX ===== */
/*/--------------------------------------------------------------------------/*/
#header:after, section:after, .content:after { content: ""; display: block; clear: both; }

/*/--------------------------------------------------------------------------/*/
/* ===== HTML,BODY ===== */
/*/--------------------------------------------------------------------------/*/
body { font-family: "nsj", sans-serif; padding-top: 138px; }
@media screen and (max-width: 870px) { body { padding-top: 112px; } }
@media screen and (max-width: 680px) { body { padding-top: 57px; } }

h2, h3, h4, h5 { font-family: "fgm", "nsj", sans-serif; }

#top { position: absolute; top: 0; }

a:link, a:visited { text-decoration: none; }

.content { box-sizing: border-box; max-width: 1100px; padding: 0 20px; margin: 0 auto; }

img { height: auto !important; }

.left_col { float: left; }

.right_col { float: right; }

.centering { text-align: center; }

@media screen and (max-width: 680px) { .scroll-prevent { position: fixed; z-index: -1; width: 100%; height: 100%; } }

/*/--------------------------------------------------------------------------/*/
/* ===== HEADER ===== */
/*/--------------------------------------------------------------------------/*/
#header ul { list-style: none; }

#header a { text-decoration: none; }

#header h1 { line-height: 1; font-family: impact; font-size: 3.2rem; font-weight: normal; margin-right: 20px; }
@media only screen and (max-width: 880px) { #header h1 { font-size: 44px; } }

#header h1 a { display: block; line-height: 1; }

#header h1 a:link, #header h1 a:visited { color: #000; }

#header h1 span { display: inline-block; color: #B72822; }

#header h1 small { display: inline-block; margin-left: -0.1rem; font-size: 1rem; }

#header > div { float: right; line-height: 1; }

#header h2 { font-size: 0.9375rem; text-align: center; }

#header h2 span { font-size: 0.75rem; }

#header .tel { font-family: Arial, Helvetica, "sans-serif"; font-style: italic; font-weight: bold; font-size: 3.125rem; text-align: center; }

#header .tel a { position: relative; }

#header .tel a:link, #header .tel a:visited { color: #B72822; }

#header .tel + p { font-size: 0.75rem; text-align: center; }

#header > .contact { display: flex; flex-wrap: wrap; float: right; padding: 1.75em 1.125em 0 0; }

#header > .sns { float: right; width: 34px; padding: 0 0.9375em 0 0; }

#header > ul a { position: relative; display: block; box-sizing: border-box; text-align: center; }

#header > ul a:link, #header > ul a:visited { color: #FFF; opacity: 1; transition: opacity 0.2s ease-out; }

#header > ul a:hover { opacity: 0.5; }

#header > .contact li:first-child { padding: 0 9px 0 0; }

#header > .contact a { box-sizing: border-box; border-radius: 4px; width: 155px; height: 3.125em; line-height: 3.125; text-align: center; }

#header > .contact li:nth-child(2) a { padding-top: 0.5625em; line-height: 1; }

#header > .contact span { position: relative; display: inline-block; padding-left: 40px; }

#header > .contact span:before { content: ""; position: absolute; top: calc(50% - 17px); left: 0; display: block; background-image: url("../image/header-icons.png"); background-repeat: no-repeat; width: 34px; height: 34px; }

#header > .contact li:nth-child(1) a:link { background-color: #C2C2CB; }

#header > .contact li:nth-child(2) a:link { background-color: #234499; }

#header > .contact li:nth-child(1) span:before { background-position: -34px 0; }

#header > .contact li:nth-child(2) span:before { background-position: 0 0; }

#header > .sns li:first-child { margin-bottom: 0.625em; }

#header > .sns a { background-image: url("../image/header-icons.png"); background-repeat: no-repeat; width: 34px; height: 34px; text-indent: -9999px; }

#header > .sns li:nth-child(1) a { background-position: -102px 0; }

#header > .sns li:nth-child(2) a { background-position: -136px 0; }

#header nav { clear: both; flex-grow: 1; }
#header nav.mobile_menu { display: none; }

#header nav ul { display: flex; flex-wrap: wrap!important; justify-content: space-around; }


#header .header_inner_top .header_inner{width:100%;flex-wrap:nowrap;}

#header .contact li:nth-child(3) a::before{left:10px;}
@media only screen and (max-width: 680px) { #header nav ul { display: block; } }

#header nav li { box-sizing: border-box; }
@media only screen and (max-width: 680px) { #header nav li { border-bottom: 1px solid rgba(255, 255, 255, 0.5); } }

#header nav a { position: relative; display: block; padding: 0.6em 0; line-height: 1; text-align: center; }
@media only screen and (max-width: 680px) { #header nav a { text-align: left; padding: 1em 0; } }

#header nav a, #header nav a:link, #header nav a:visited { color: #000; }
@media only screen and (max-width: 680px) { #header nav a, #header nav a:link, #header nav a:visited { color: #fff; } }

#header { font-family: "nsj-reg", sans-serif; max-width: none; position: absolute; top: 0; left: 0; width: 100%; height: 138px; }
#header > div { float: none; }
#header .header_inner { max-width: 1460px; margin-left: auto; margin-right: auto; }
@media only screen and (max-width: 1060px) { #header .header_inner { padding-left: 10px; padding-right: 10px; } }
@media screen and (max-width: 680px) { #header .header_inner_top { display: none; } }
#header .header_inner_top .header_inner { display: -webkit-flex; display: -ms-flexbox; display: flex; -webkit-justify-content: flex-end; -ms-flex-pack: end; justify-content: flex-end; -ms-flex-wrap: wrap; -webkit-flex-wrap: wrap; flex-wrap: wrap; align-items: center; }
#header .header_inner_bottom { position: relative; }
@media only screen and (max-width: 680px) { #header .header_inner_bottom { position: static; } }
@media screen and (max-width: 680px) { #header .header_inner_bottom { display: block; overflow: visible; } }
#header .header_inner_bottom .header_inner { display: -webkit-flex; display: -ms-flexbox; display: flex; -ms-flex-wrap: wrap; -webkit-flex-wrap: wrap; flex-wrap: wrap; align-items: center; margin-top: 16px; margin-bottom: 10px; padding-left: 16px; }
@media only screen and (max-width: 1060px) { #header .header_inner_bottom .header_inner { padding-left: 0; } }
@media only screen and (max-width: 680px) { #header .header_inner_bottom .header_inner { margin-top: 0; } }
#header .header_info { display: -webkit-flex; display: -ms-flexbox; display: flex; -webkit-justify-content: flex-end; -ms-flex-pack: end; justify-content: flex-end; align-items: center; font-size: 14px; color: #000; }
@media screen and (max-width: 1230px) { #header .header_info .header_info_desc { display: none; } }
@media screen and (max-width: 930px) { #header .header_info .time { display: none; } }
#header .tel { font-family: "nsj-bold", sans-serif; font-style: normal; font-size: 20px; margin: 10px 16px 10px 20px; display: -webkit-flex; display: -ms-flexbox; display: flex; align-items: center; }
#header .tel > span { padding-top: 2px; margin-right: 4px; }
#header .tel a:link, #header .tel a:visited { font-size: 30px; color: black; }
#header .tel + p { font-size: 14px; }
@media screen and (max-width: 1230px){#header .tel + p { font-size: 13px; letter-spacing: -0.05em; }}
@media screen and (max-width: 1080px){#header .tel + p { display: none; }}
@media only screen and (max-width: 768px){
  #header .tel {font-size: 16px;}
  #header .tel a:link, #header .tel a:visited {font-size: 20px;}
}
#header .contact { display: -webkit-flex; display: -ms-flexbox; display: flex; align-items: center; }
#header .contact li a { display: block; position: relative; background: #B72822; font-size: 14px; color: white; border-radius: 4px; padding: 10px 14px 10px 48px; margin: 10px; -moz-transition: 0.3s; -webkit-transition: 0.3s; -ms-transition: 0.3s; transition: 0.3s; }
#header .contact li a:hover { background: #c1514c; }
#header .contact li a:before { content: ''; position: absolute; left: 16px; top: 0; }
#header .contact li.catalog a:before { width: 26px; height: 100%; background: url("../image/icon_catalog_wht.png") center center no-repeat; background-size: contain; }
#header .contact li.mail a:before { width: 23px; height: 100%; background: url("../image/icon_mail_wht.png") center center no-repeat; background-size: contain; }
#header .contact li.human a:before { width: 28px; height: 100%; background: url("../image/icon_human_wht.png") center center no-repeat; background-size: contain; }

.admin-bar #header { top: 32px; }
@media screen and (max-width: 782px) { .admin-bar #header { top: 46px; } }

.header_fix #header { position: fixed; background: #fff; -moz-transition: 0.3s; -webkit-transition: 0.3s; -ms-transition: 0.3s; transition: 0.3s; z-index: 100; }

@media screen and (min-width: 680px) { #header nav a:after { content: ""; position: absolute; bottom: -14px; left: 50%; display: block; border-bottom: 4px solid #B72822; width: 0; transition: all 0.2s ease-out; }
  #header nav a:hover:after { left: 0; border-bottom: 6px solid #B72822; width: 100%; } }
#menuflg { display: none; }

#menubtn { position: absolute; top: 0; right: 0; display: none; background-color: #B72822; width: 52px; height: 52px; cursor: pointer; }

#menubtn span { position: absolute; display: block; text-align: center; transition: all 0.2s ease-out; }

#menubtn span:nth-child(1), #menubtn span:nth-child(2), #menubtn span:nth-child(3) { left: 10px; background-color: #FFF; width: 32px; height: 2px; }

#menubtn span:nth-child(1) { top: 10px; }

#menubtn span:nth-child(2) { top: 18px; opacity: 1; }

#menubtn span:nth-child(3) { top: 26px; }

#menubtn span:last-child { bottom: 8px; color: #FFF; width: 100%; line-height: 1; font-size: 10px; font-weight: bold; }

#menuflg:checked + #menubtn span:nth-child(1) { top: 18px; transform: rotate(45deg); }

#menuflg:checked + #menubtn span:nth-child(2) { opacity: 0; }

#menuflg:checked + #menubtn span:nth-child(3) { top: 18px; transform: rotate(-45deg); }

.mega_menu { position: absolute; top: 0; left: 0; width: 100%; padding-top: 22px; color: #fff; z-index: 100; -moz-transition: 0.3s; -webkit-transition: 0.3s; -ms-transition: 0.3s; transition: 0.3s; opacity: 0; visibility: hidden; height: 0; }
@media only screen and (max-width: 680px) { .mega_menu { display: none; } }
.mega_menu.is-active { top: calc(100% - 14px); opacity: 1; visibility: visible; height: auto; }
@media only screen and (max-width: 680px) { .mega_menu.is-active { display: none; } }
.mega_menu .mega_menu_inner { background: #a8372a; padding: 35px 0; }
.mega_menu .mega_menu_menu { width: 1050px; max-width: 98%; margin: 0 auto; }
.mega_menu .mega_menu_parent_title { font-size: 1.125rem; font-family: 'nsj-bold', sans-serif; }
.mega_menu .mega_menu_parent_title a { color: white; }
.mega_menu .sub_menus { display: -webkit-flex; display: -ms-flexbox; display: flex; -webkit-justify-content: start; -ms-flex-pack: start; justify-content: start; -ms-flex-wrap: wrap; -webkit-flex-wrap: wrap; flex-wrap: wrap; margin-top: 28px; }
.mega_menu .sub_menus.uniform_menu { -webkit-justify-content: flex-start; -ms-flex-pack: start; justify-content: flex-start; }
.mega_menu .sub_menus.uniform_menu .sub_menu_item { width: 250px; margin: 0 0 20px; }
.mega_menu .sub_menus .sub_menu_item { display: -webkit-flex; display: -ms-flexbox; display: flex; align-items: center; margin: 0 30px 20px;width:25%; }
.mega_menu .sub_menus .sub_menu_item .eye_catch { margin-right: 14px; }
.mega_menu .sub_menus .sub_menu_item a { color: #fff; }
.mega_menu .sub_menus .sub_menu_item a:hover { text-decoration: underline !important; }

@media screen and (max-width: 1060px) { #header h1 { font-size: 4.6vw; }
  #header > .contact, #header > .sns { font-size: 1.5vw; }
  #header > ul li:nth-child(2) a::before { left: 10px; }
  #header nav ul { font-size: 0.875rem; } }
@media screen and (max-width: 880px) { #header > ul li:nth-child(1) a:before, #header > ul li:nth-child(2) a:before { background-size: cover; top: 10px; width: 20px; height: 20px; }
  #header > .contact li:nth-child(1) a:before { background-position: -20px 0; }
  #header nav ul { font-size: 0.75rem; }
  #header .sns { width: 78px; padding-top: 1.75em; }
  #header .sns li { float: left; }
  #header .sns li:first-child { margin: 0 10px 0 0; } }
@media screen and (max-width: 780px) { #header nav ul { font-size: 0.625rem; }
  #header nav a { padding-right: 0.3em; padding-left: 0.3em; } }
@media screen and (max-width: 680px) { #menubtn { display: block; }
  #header { position: fixed; top: 0; left: 0; z-index: 100; box-sizing: border-box; background: #FFF; box-shadow: 0 5px rgba(0, 0, 0, 0.1); width: 100%; height: 52px; min-height: 52px; padding: 10px 10px 0 10px; margin: 0; }
  #header h1 { width: 200px; padding: 0 0 7px 0; font-size: 2.1875rem; }
  #header > div { display: none; }
  #header > .contact, #header > .sns { display: none; }
  #header nav { box-sizing: border-box; overflow: hidden; max-height: 0; padding: 32px 16px; opacity: 0; transition: all 0.2s ease-in-out; background-color: #B72822; position: absolute; left: 0; top: 52px; width: 100%; }
  #header nav.pc_menu { display: none; }
  #header nav.mobile_menu { display: block; }
  #header nav .sub-menu { display: -webkit-flex; display: -ms-flexbox; display: flex; -webkit-justify-content: flex-start; -ms-flex-pack: start; justify-content: flex-start; -ms-flex-wrap: wrap; -webkit-flex-wrap: wrap; flex-wrap: wrap; }
  #header nav .sub-menu li { width: 50%; border-bottom: none; }
  #header nav .sub-menu li a { padding-top: 0.3em; }
  .menu-open #header nav { max-height: calc(100vh - 52px); opacity: 1; overflow: scroll; padding-bottom: 80px; }
  #header #menuflg:checked + #menubtn + nav { max-height: 350px; opacity: 1; }
/*#header nav ul { font-size: 14px; }
 #header nav ul:first-child li a { line-height: 1; }
 #header nav ul:first-child li, #header nav ul:first-child li:last-child { border: none; border-top: 1px solid #666; width: 50%; }

 #header nav li:first-child { display: block; }
 #header nav ul:first-child li:nth-child(odd) { border-right: 1px solid #666; }
 #header nav ul:last-child li { width: calc(100% / 3); }*/}
/*/--------------------------------------------------------------------------/*/
/* ===== CONTENT ===== */
/*/--------------------------------------------------------------------------/*/
#content { margin: 0 auto; }
#content [id^="sec-"] h2 { font-size: 1.75em; color: #B72822; text-align: center; margin: 0.6em 0; position: relative; }
@media only screen and (max-width: 680px) { #content [id^="sec-"] h2 { margin: 0; font-size: 1.25em; } }
#content [id^="sec-"] h2:before, #content [id^="sec-"] h2:after { content: ''; position: absolute; top: 50%; display: inline-block; width: 18%; height: 2px; background-color: #B72822; }
@media only screen and (max-width: 880px) { #content [id^="sec-"] h2:before, #content [id^="sec-"] h2:after { width: 10%; } }
#content [id^="sec-"] h2:before { left: 8%; }
@media only screen and (max-width: 880px) { #content [id^="sec-"] h2:before { left: 5%; } }
@media only screen and (max-width: 680px) { #content [id^="sec-"] h2:before { left: 0; } }
#content [id^="sec-"] h2:after { right: 8%; }
@media only screen and (max-width: 880px) { #content [id^="sec-"] h2:after { right: 5%; } }
@media only screen and (max-width: 680px) { #content [id^="sec-"] h2:after { right: 0; } }

/* ===== HEADER ===== */
#content header { background-color: #B72822; padding: 2em 0; }
@media only screen and (max-width: 680px) { #content header { padding: 1em 0; } }

#content header .case_number { font-size: 1.25rem; text-align: center; color: #FFF; margin-bottom: 0; }

#content header h2 { color: #FFF; font-size: 2rem; text-align: center; }

#content header h2 + p { color: #FFF; margin: 0; line-height: 1; font-size: 1.25rem; text-align: center; }

#content header p br { display: none; }

#content header .content { position: relative; display: -webkit-flex; display: -ms-flexbox; display: flex; flex-direction: column; align-items: center; }

#content header .pdf { position: absolute; right: 20px; bottom: 0; width: 172px; height: 36px; font-size: 1rem; }

#content header .pdf a { position: relative; display: block; width: 172px; height: 36px; text-indent: -9999px; }

#content header .pdf a:before, #content header .pdf a:after { content: ""; position: absolute; top: 0; left: 0; z-index: 1; display: block; background-image: url("../image/pdf-icon.png"); background-repeat: no-repeat; background-size: cover; width: 172px; height: 36px; transition: all 0.2s ease-out; }

#content header .pdf a:before { background-position: top; opacity: 1; }

#content header .pdf a:after { background-position: bottom; opacity: 0; }

#content header .pdf a:hover:before { opacity: 0; }

#content header .pdf a:hover:after { opacity: 1; }

/* ===== LOCAL ===== */
#local { max-width: 1100px; margin: 80px auto; }

#local ol { display: flex; flex-wrap: wrap; font-size: 1.0625rem; list-style: none; }

#local li { position: relative; box-sizing: border-box; border: 2px solid #B72822; border-radius: 8px; line-height: 1.4; letter-spacing: 0; transition: all 0.2s ease-out; }

#local li:hover { background-color: #B72822; }

#local li:after { content: ""; position: absolute; bottom: 0.7em; left: calc(50% - 0.3em); display: block; border-top: 2px solid #B72822; border-right: 2px solid #B72822; width: 0.6em; height: 0.6em; transform: rotate(135deg); transition: all 0.2s ease-out; }

#local li:hover:after { border-color: #FFF; }

#local a { position: relative; display: block; margin: -2px; text-align: center; transition: all 0.2s ease-out; }

#local a:link, #local a:visited { color: #B72822; }

#local a:hover { color: #FFF; }

/* ===== SECTION ===== */
#content section { margin-bottom: 80px; padding: 30px 0 0 0; }

#content h3 { /*position: relative;
max-width: 1100px;
margin: 0 auto 1.3em auto;
font-family: 'nsj-md', sans-serif;
font-size: 1.5rem;*/ position: relative; max-width: 1100px; width: 100%; height: 50px; margin: 0 auto 1.3em auto; font-size: 1.125rem; text-align: center; color: #fff; display: inline-block; background: #c1261f; border-bottom: 4px solid #4b4a4a; display: -webkit-flex; display: -ms-flexbox; display: flex; -webkit-justify-content: center; -ms-flex-pack: center; justify-content: center; align-items: center; }
@media only screen and (max-width: 680px) { #content h3 { font-size: 1rem; height: 40px; border-bottom-width: 2px; } }

#content h4 { /*margin-bottom: 1em;
font-family: 'nsj-md', sans-serif;
font-size: 1.125rem;*/ margin-bottom: 1em; font-size: 1.25rem; font-family: 'nsj-md', sans-serif; color: #fff; background: #4b4a4a; height: 36px; border-radius: 4px; display: -webkit-flex; display: -ms-flexbox; display: flex; -webkit-justify-content: center; -ms-flex-pack: center; justify-content: center; align-items: center; position: relative; }
@media only screen and (max-width: 680px) { #content h4 { font-size: 1rem; } }
#content h4:before { content: ''; display: block; position: absolute; left: 0; top: calc(50% - 3px); width: 20px; height: 6px; background: #c1261f; }
#content h4 a:link, #content h4 a:visited { color: #fff; }

#content h5 { margin-bottom: 1em; font-size: 1rem; }

#content p + h5 { margin-top: 1.5em; }

#content p, #content td { line-height: 2; }

#content p { margin-bottom: 1em; }

#content img { max-width: 100%; }

#content .wp-pagenavi { padding: 0 0 60px 0; text-align: center; }

@media screen and (max-width: 1140px) { #content h3 { margin: 0 auto 1.3em auto; }
  #content section .content { padding-right: 10px; padding-left: 10px; } }
@media screen and (max-width: 880px) { #content header .pdf { top: 0; } }
@media screen and (max-width: 680px) { #content header .content { padding: 0 10px; display: -webkit-flex; display: -ms-flexbox; display: flex; flex-direction: column; align-items: center; }
  #content header p br { display: block; }
  #content header .pdf, #content header .pdf a, #content header .pdf a:before, #content header .pdf a:after { width: 134px; height: 28px; }
  #content section .content { padding-right: 0; padding-left: 0; margin-right: 10px; margin-left: 10px; }
  #content #local { margin: 10px 10px 0 10px; }
  #content #local ol { justify-content: center; font-size: 0.8125rem; }
  #content #local ol li { width: calc(100% / 2 - 5px); margin-bottom: 10px; }
  #content #local ol li:nth-child(odd) { margin-right: 10px; }
  #content #local ol li:last-child { margin-right: 0; }
  #local a { padding: 0.75em 0; }
  .left_col { float: none; }
  .right_col { float: none; } }
@media screen and (max-width: 480px) { #content header h2 { font-size: 1.625rem; }
  #content header h2 + p { padding-bottom: 0; font-size: 1rem; }
  #content header .pdf { position: static; margin: 0 auto; } }
.example_items { display: -webkit-flex; display: -ms-flexbox; display: flex; -ms-flex-wrap: wrap; -webkit-flex-wrap: wrap; flex-wrap: wrap; margin-top: 2em; }
@media only screen and (max-width: 880px) { .example_items { flex-direction: column; } }
.example_items article { width: 30%; margin-bottom: 2em; margin-left: 5%; }
@media only screen and (max-width: 880px) { .example_items article { width: 95%; margin-left: auto; margin-right: auto; margin-bottom: 2em; } }
.example_items article:nth-child(3n + 1) { margin-left: 0; }
@media only screen and (max-width: 880px) { .example_items article:nth-child(3n + 1) { margin-left: auto; } }
.example_items article .article_title { font-family: nsj-bold, sans-serif; display: -webkit-flex; display: -ms-flexbox; display: flex; align-items: center; height: 2em; }
.example_items article .image { margin-top: 1em; overflow: hidden; }
.example_items article .image img { display: block; margin-left: auto; margin-right: auto; -moz-transition: 0.3s; -webkit-transition: 0.3s; -ms-transition: 0.3s; transition: 0.3s; }
@media only screen and (max-width: 880px) { .example_items article .image img { width: 100%; } }
.example_items article .image:hover img { transform: scale(1.07); }
.example_items article .desc { font-size: 15px; line-height: 1.65 !important; margin-top: 10px; margin-bottom: 0 !important; }
.example_items article .more { font-family: 'nsj-reg', sans-serif; font-size: 12px; color: #c1261f; -moz-transition: 0.3s; -webkit-transition: 0.3s; -ms-transition: 0.3s; transition: 0.3s; }
.example_items article .more:after { content: '>'; margin-left: 3px; }
.example_items article .more:hover { color: black; }

/*/--------------------------------------------------------------------------/*/
/* ===== FOOTER ===== */
/*/--------------------------------------------------------------------------/*/
/* ===== CONTACT ===== */
#contactfoot { background: url("../image/bg_footer_cta.jpg"); background-size: cover; color: #fff; overflow: hidden; padding: 44px 20px 70px; }
@media only screen and (max-width: 680px) { #contactfoot { padding: 40px 16px 50px; } }

.contactfoot_header h2 { font-family: 'nsj-md', sans-serif; font-size: 30px; text-align: center; margin-bottom: 1em; }
@media only screen and (max-width: 680px) { .contactfoot_header h2 { font-size: 20px; } }
.contactfoot_header .desc { font-size: 18px; text-align: center; }
@media only screen and (max-width: 680px) { .contactfoot_header .desc { font-size: 13px; } }

.contactfoot_inner { display: -webkit-flex; display: -ms-flexbox; display: flex; -webkit-justify-content: center; -ms-flex-pack: center; justify-content: center; align-items: center; margin-top: 46px; }
@media only screen and (max-width: 880px) { .contactfoot_inner { flex-direction: column; } }
.contactfoot_inner .tel { text-align: center; padding-right: 46px; }
@media only screen and (max-width: 880px) { .contactfoot_inner .tel { padding-right: 0; } }
.contactfoot_inner .tel h3 { font-family: 'nsj-md', sans-serif; font-size: 20px; }
@media only screen and (max-width: 680px) { .contactfoot_inner .tel h3 { font-size: 13px; } }
.contactfoot_inner .tel a { font-family: 'nsj-bold', sans-serif; font-size: 46px; color: #fff; text-align: center; }
@media only screen and (max-width: 680px) { .contactfoot_inner .tel a { font-size: 30px; } }
.contactfoot_inner .tel p { font-size: 16px; }
@media only screen and (max-width: 680px) { .contactfoot_inner .tel p { font-size: 12px; } }
.contactfoot_inner .btns { padding-left: 50px; border-left: 1px solid white; }
@media only screen and (max-width: 880px) { .contactfoot_inner .btns { padding-left: 0; border-left: none; margin-top: 32px; } }
.contactfoot_inner .btns a { box-sizing: border-box; display: block; font-family: 'nsj-bold', sans-serif; font-size: 24px; color: white; border: 3px solid white; width: 400px; height: 80px; line-height: 74px; padding-left: 120px; position: relative; -moz-transition: 0.3s; -webkit-transition: 0.3s; -ms-transition: 0.3s; transition: 0.3s; }
@media only screen and (max-width: 680px) { .contactfoot_inner .btns a { font-size: 13px; width: 200px; height: 40px; border-width: 2px; line-height: 36px; padding-left: 54px; } }
.contactfoot_inner .btns a.mail:hover { background: white; color: #cc0000; }
.contactfoot_inner .btns a.mail:hover:before { background: url("../image/icon_mail_lg_h.png") center center no-repeat; background-size: contain; }
.contactfoot_inner .btns a.mail:before { position: absolute; top: 0; left: 43px; content: ''; width: 54px; height: 100%; background: url("../image/icon_mail_lg.png") center center no-repeat; background-size: contain; }
@media only screen and (max-width: 680px) { .contactfoot_inner .btns a.mail:before { width: 27px; left: 16px; } }
.contactfoot_inner .btns a.catalog { margin-top: 32px; }
.contactfoot_inner .btns a.catalog:hover { background: white; color: #333; }
.contactfoot_inner .btns a.catalog:hover:before { background: url("../image/icon_catalog_lg_h.png") center center no-repeat; background-size: contain; }
.contactfoot_inner .btns a.catalog:before { position: absolute; top: 0; left: 40px; content: ''; width: 54px; height: 100%; background: url("../image/icon_catalog_lg.png") center center no-repeat; background-size: contain; }
@media only screen and (max-width: 680px) { .contactfoot_inner .btns a.catalog:before { width: 28px; left: 16px; } }

/*#contactfoot { display: flex; box-sizing: border-box; max-width: 1100px; border-width: 3px 0; border-style: solid; border-color: #F0F0F2; margin: 0 auto 80px auto; padding: 60px 0;
}

#contactfoot > div { box-sizing: border-box;
}

#contactfoot h2,
#contactfoot p { line-height: 1.2; text-align: center;
}

#contactfoot > div:nth-child(1) { border-right: 3px solid #F0F0F2; width: 51%;
}

#contactfoot > div:nth-child(2) { width: 49%;
}

#contactfoot h2 { position: relative; color: #333; letter-spacing: 1px; font-size: 1.25rem;
}

#contactfoot h2:before { content: ""; display: block; background-image: url("../_images/common/footer-icons.png"); background-size: cover; width: 85px; height: 85px; margin: 0 auto 20px auto; opacity: 1; transition: all 0.2s ease-out;
}

#contactfoot > div:nth-child(1) h2:before { background-position: 0 0;
}

#contactfoot > div:nth-child(2) h2:before { background-position: -85px 0;
}

#contactfoot a:hover h2:before { opacity: 0.5;
}

#contactfoot .tel { font-family: Arial, Helvetica, "sans-serif"; font-style: italic; font-weight: bold; font-size: 3.5rem; text-align: center;
}

#contactfoot a:link .tel,
#contactfoot a:visited .tel { color: #B72822;
}

#contactfoot a:hover .tel { text-decoration: underline;
}

#contactfoot .tel + p { font-size: 0.875rem;
}

#contactfoot a:link p:last-child,
#contactfoot a:visited p:last-child { color: #333;
}

#contactfoot > div:nth-child(2) p { margin-top: 1em;
}

#contactfoot > div:nth-child(2) span { display: inline-block; border-radius: 6px; font-size: 1.25rem; font-weight: bold; text-decoration: none;
}

#contactfoot > div:nth-child(2) a:link span,
#contactfoot > div:nth-child(2) a:visited span { background-color: #B72822; color: #FFF; border: 2px solid #B72822; padding: 0.55em 3em; transition: all 0.2s ease-out;
}

#contactfoot > div:nth-child(2) a:hover span { background: #FFF; color: #B72822;
}

@media screen and (max-width: 880px) {
 #contactfoot h2, #contactfoot > div:nth-child(2) a { font-size: 2.5vw; }
 #contactfoot .tel { font-size: 8vw; }
 #contactfoot .tel + p { font-size: 1.8vw; }

}


@media screen and (max-width: 680px) {
 #contactfoot { display: block; padding: 20px 0; margin-bottom: 20px; }
 #contactfoot > div:nth-child(1) { border-right: none; width: 100%; margin-bottom: 20px; }
 #contactfoot > div:nth-child(2) { border-top: 3px solid #F0F0F2; width: 90%; margin: 0 auto; padding-top: 20px; }
 #contactfoot h2, #contactfoot > div:nth-child(2) a { font-size: 1rem; }
 #contactfoot h2:before { background-size: 253px 80px; width: 80px; height: 80px; margin-bottom: 5px; }
 #contactfoot > div:nth-child(1) h2:before { background-position: 0 0; } #contactfoot > div:nth-child(2) h2:before { background-position: -80px 0; }
 #contactfoot .tel + p { font-size: 0.875rem; }
 #contactfoot .tel { font-size: 2.5rem; }
 #contactfoot > div:last-child p { margin-top: 0.7em; }

}

@media screen and (max-width: 380px) {
 #contactfoot .tel + p { font-size: 0.75rem; }
}*/
/* ===== ONLINESHOP ===== */
#footer_links { background: #f0f0eb; padding-top: 46px; padding-bottom: 40px; }

.footer_banner { display: -webkit-flex; display: -ms-flexbox; display: flex; -webkit-justify-content: center; -ms-flex-pack: center; justify-content: center; -ms-flex-wrap: wrap; -webkit-flex-wrap: wrap; flex-wrap: wrap; }
@media only screen and (max-width: 680px) { .footer_banner { flex-direction: column; align-items: center; } }
.footer_banner .bn { width: 342px; margin: 6px 6px 12px; }
@media only screen and (max-width: 680px) { .footer_banner .bn { width: 286px; } }
.footer_banner .bn img { max-width: 100%; width: auto; }
.footer_banner .bn p { font-family: 'nsj-reg', sans-serif; font-size: 13px; text-align: center; margin-top: 1em; }
@media only screen and (max-width: 680px) { .footer_banner .bn p { font-size: 12px; } }

#onlineshop h2 span, #recruit h2 span, #bring h2 span, #lezene h2 span, #rental h2 span, #fshield h2 span, #ariga h2 span { position: relative; display: inline-block; padding-right: 20px; }

#onlineshop h2 span:before, #onlineshop h2 span:after, #recruit h2 span:before, #recruit h2 span:after, #bring h2 span:before, #bring h2 span:after, #lezene h2 span:before, #lezene h2 span:after, #rental h2 span:before, #rental h2 span:after, #fshield h2 span:before, #fshield h2 span:after, #ariga h2 span:before, #ariga h2 span:after { content: ""; position: absolute; display: block; box-sizing: border-box; border-color: #444; border-style: solid; width: 12px; height: 10px; }

#onlineshop h2 span:before, #recruit h2 span:before, #bring h2 span:before, #lezene h2 span:before, #rental h2 span:before, #fshield h2 span:before, #ariga h2 span:before { top: 5px; right: 0; border-width: 2px; }

#onlineshop h2 span:after, #recruit h2 span:after, #bring h2 span:after, #lezene h2 span:after, #rental h2 span:after, #fshield h2 span:after, #ariga h2 span:after { top: 8px; right: 3px; border-width: 0 0 2px 2px; }

#onlineshop { max-width: 715px; margin: 0 auto 40px auto; padding: 0 10px; }

#onlineshop h2 { position: relative; color: #c1261f; margin-bottom: 1em; font-family: 'nsj-bold', serif; font-size: 13px; text-align: center; font-weight: normal; }

#onlineshop h2 br { display: none; }

#onlineshop ul { display: flex; justify-content: space-between; list-style: none; }
@media only screen and (max-width: 680px) { #onlineshop ul { flex-direction: column; align-items: center; } }

#onlineshop ul li { border: 1px solid #c1261f; }
@media only screen and (max-width: 680px) { #onlineshop ul li { width: 286px; margin-top: 10px; } }

#onlineshop ul img { width: 100%; max-width: 345px; }
@media only screen and (max-width: 680px) { #onlineshop ul img { max-width: 100%; } }

#onlineshop a:link, #onlineshop a:visited { opacity: 1; transition: all 0.2s ease-out; }

#onlineshop a:hover { opacity: 0.5; transition: all 0.2s ease-out; }

/*@media screen and (max-width: 680px) {
 #onlineshop { margin-bottom: 20px; }
 #onlineshop h2 { margin-bottom: 10px; }
 #onlineshop h2 span { line-height: 1.2; }
 #onlineshop h2 br { display: block; line-height: 1px; height: 1px; }
 #onlineshop ul { display: block; }
 #onlineshop li { text-align: center; width: auto; margin-bottom: 10px; }
 #onlineshop li:last-child { margin-bottom: 0; }

}*/
/* ===== RECRUIT ===== */
#recruit { max-width: 1100px; margin: 0 auto 80px auto; }

#recruit h2 { position: relative; color: #333; margin-bottom: 0.75em; font-size: 1rem; text-align: center; font-weight: normal; }

#recruit p { text-align: center; }

#recruit p img { width: 100%; max-width: 398px; }

#recruit a:link, #recruit a:visited { opacity: 1; transition: all 0.2s ease-out; }

#recruit a:hover { opacity: 0.5; transition: all 0.2s ease-out; }

@media screen and (max-width: 480px) { #recruit { padding: 0 10px; margin-bottom: 20px; }
  #recruit h2 { margin-bottom: 10px; font-size: 1rem; } }
/* ===== BRING ===== */
#bring { max-width: 1100px; margin: 0 auto 80px auto; }

#bring h2 { position: relative; color: #333; margin-bottom: 0.75em; font-size: 1rem; text-align: center; font-weight: normal; font-family: 'nsj'; }

#bring p { text-align: center; }

#bring p img { width: 100%; max-width: 398px; }

#bring a:link, #bring a:visited { opacity: 1; transition: all 0.2s ease-out; }

#bring a:hover { opacity: 0.5; transition: all 0.2s ease-out; }

@media screen and (max-width: 480px) { #bring { padding: 0 10px; margin-bottom: 20px; }
  #bring h2 { margin-bottom: 10px; font-size: 1rem; } }
/* ===== LEZENE ===== */
#lezene { max-width: 1100px; margin: 0 auto 80px auto; }

#lezene h2 { position: relative; color: #333; margin-bottom: 0.75em; font-size: 1rem; text-align: center; font-weight: normal; font-family: 'nsj'; }

#lezene p { text-align: center; }

#lezene p img { width: 100%; max-width: 398px; }

#lezene a:link, #lezene a:visited { opacity: 1; transition: all 0.2s ease-out; }

#lezene a:hover { opacity: 0.5; transition: all 0.2s ease-out; }

@media screen and (max-width: 480px) { #lezene { padding: 0 10px; margin-bottom: 20px; }
  #lezene h2 { margin-bottom: 10px; font-size: 1rem; } }
@media screen and (max-width: 350px) { #lezene h2 { font-size: 0.85rem; } }
/* ===== rental ===== */
#rental { max-width: 1100px; margin: 0 auto 80px auto; }

#rental h2 { position: relative; color: #333; margin-bottom: 0.75em; font-size: 1rem; text-align: center; font-weight: normal; font-family: 'nsj'; }

#rental p { text-align: center; }

#rental p img { width: 100%; max-width: 398px; }

#rental a:link, #rental a:visited { opacity: 1; transition: all 0.2s ease-out; }

#rental a:hover { opacity: 0.5; transition: all 0.2s ease-out; }

@media screen and (max-width: 480px) { #rental { padding: 0 10px; margin-bottom: 20px; }
  #rental h2 { margin-bottom: 10px; font-size: 1rem; } }
@media screen and (max-width: 350px) { #rental h2 { font-size: 0.85rem; } }
/* ===== fshield ariga ===== */
#fshield, #ariga { max-width: 1100px; margin: 0 auto 80px auto; }

#fshield h2, #ariga h2 { position: relative; color: #333; margin-bottom: 0.75em; font-size: 1rem; text-align: center; font-weight: normal; font-family: 'nsj'; }

#fshield p, #ariga p { text-align: center; }

#fshield p img, #ariga p img { width: 100%; max-width: 398px; }

#fshield a:link, #ariga a:link, #fshield a:visited, #ariga a:visited { opacity: 1; transition: all 0.2s ease-out; }

#fshield a:hover, #ariga a:hover { opacity: 0.5; transition: all 0.2s ease-out; }

@media screen and (max-width: 480px) { #fshield, #ariga { padding: 0 10px; margin-bottom: 20px; }
  #fshield h2, #ariga h2 { margin-bottom: 10px; font-size: 1rem; } }
@media screen and (max-width: 350px) { #fshield h2, #ariga h2 { font-size: 0.85rem; } }
/* ===== TO TOP ===== */
#totop { position: fixed; right: 20px; bottom: 15px; z-index: 100;display:block;width:100px;text-align:center;font-weight:bold; }
@media only screen and (max-width: 880px) { #totop { bottom: 88px; } }

#totop a { display: block; color:#c00;}

#totop a img{
	width: 75%;
}

/*#totop a:link,
#totop a:visited { position: relative; box-sizing: border-box; background-color: #234499; border: 2px solid #234499; width: 4em; height: 4em; transition: all 0.2s ease-out;
}

#totop a:hover { background-color: #FFF;
}

#totop a:link:after,
#totop a:visited:after { content: ""; position: absolute; top: calc(50% - 0.2em); left: calc(50% - 0.5em); display: block; border-width: 2px 2px 0 0; border-style: solid; border-color: #FFF; width: 1em; height: 1em; transform: rotate(-45deg);
}

#totop a:hover:after { border-color: #234499;
}*/
/* ===== ONLINEROOM ===== */
#onlineroom{display:none;}
#home #onlineroom { position: fixed; right: 20px; bottom: 20px; z-index: 100; overflow: hidden; width: 132px; height: 68px;display:block; }
@media only screen and (max-width: 880px) { #home #onlineroom { width: 100px; height: 52px; } }
@media only screen and (max-width: 680px) { #home #onlineroom { bottom: 70px; } }

#home #onlineroom a { position: relative; display: block; width: 132px; height: 68px; text-indent: -9999px; transition: all 0.2s ease-out; }

#home #onlineroom a:before, #home #onlineroom a:after { content: ""; position: absolute; top: 0; left: 0; display: block; background-image: url("../image/onlineroom.png"); background-size: cover; width: 132px; height: 68px; transition: all 0.2s ease-out; }
@media only screen and (max-width: 880px) { #home #onlineroom a:before, #home #onlineroom a:after { width: 100px; height: 52px; } }

#home #onlineroom a:before { opacity: 1; }

#home #onlineroom a:after { background-position: bottom; opacity: 0; }

#home #onlineroom a:hover:before { opacity: 0; }
#home
#onlineroom a:hover:after { opacity: 1; }

@media screen and (max-width: 680px) { #totop { position: fixed; right: 35px; bottom: 60px; width: 3em; height: 3em;z-index:10; }
  #totop a:link, #totop a:visited { width: 6em; height: 3em;font-size:12px; }
  #totop a:link:after, #totop a:visited:after { content: ""; position: absolute; top: calc(50% - 0.1em); left: calc(50% - 0.3em); width: 0.6em; height: 0.6em; }
  #home #onlineroom { position: fixed; right: 10px; width: 99px; height: 51px; display:none;}
  #home #onlineroom a, #home #onlineroom a:before, #home #onlineroom a:after { width: 99px; height: 51px; } }

/* ===== campaign =====  */

#campaign{position:fixed;bottom:20px;right:20px;}
#campaign p{position:absolute;top:-5px;right:-5px;display:block;width:14px;height:14px;background-color:#ddd;text-align:center;line-height:12px;z-index:999!important;border:1px solid #ddd;font-weight:bold;border-radius:50%;font-size:12px;}
#campaign p a{color:#000;}
#campaign p a:hover{opacity:0.7;}
#home #campaign{right:170px;z-index:900;}
#campaign img{height:68px!important;}
#campaign a:hover{opacity:0.7;}
@media screen and (max-width: 680px){
  #campaign{bottom:70px;right:20px;}
  #home #campaign{right:120px;}
  #campaign img{height:51px!important;}
}
/* ===== FOOTER ===== */
#footer { padding-top: 50px; transition: all 0.2s ease-out; }
@media only screen and (max-width: 680px) { #footer { margin-top: 30px; } }

#footer .footer_inner { max-width: 1100px; margin: 0 auto; padding: 0 10px 120px; display: -webkit-flex; display: -ms-flexbox; display: flex; position: relative; }
@media only screen and (max-width: 880px) { #footer .footer_inner { flex-direction: column; align-items: center; } }
@media only screen and (max-width: 680px) { #footer .footer_inner { padding: 0 10px 80px; } }
#footer .company_info h2 { font-family: impact, sans-serif; font-size: 55px; }
@media only screen and (max-width: 880px) { #footer .company_info h2 { text-align: center; } }
@media only screen and (max-width: 680px) { #footer .company_info h2 { font-size: 30px; } }
#footer .company_info h2 a { color: black; }
#footer .company_info h2 a span { display: inline-block; color: #B72822; }
#footer .company_info h2 a small { margin-left: -0.1rem; font-size: 1rem; }
#footer .company_info .company_name { font-family: "nsj-bold", sans-serif; font-size: 20px; }
@media only screen and (max-width: 880px) { #footer .company_info .company_name { text-align: center; } }
@media only screen and (max-width: 680px) { #footer .company_info .company_name { font-size: 15px; } }
#footer .company_info p { font-size: 16px; margin-top: 0.5em; }
@media only screen and (max-width: 880px) { #footer .company_info p { text-align: center; } }
@media only screen and (max-width: 680px) { #footer .company_info p { font-size: 13px; } }
#footer .footer_nav { display: -webkit-flex; display: -ms-flexbox; display: flex; justify-content: space-around; flex-grow: 1; font-family: 'nsj-reg', sans-serif; font-size: 14px; }
@media only screen and (max-width: 880px) { #footer .footer_nav { display: none; } }
#footer .footer_nav nav ul li { list-style: none; }
#footer .footer_nav nav ul a { display: inline-block; color: black; margin-bottom: 0.8em; }
#footer .footer_nav nav ul a:hover { color: #a8372a; }
#footer .footer_nav nav ul a:before { content: '＞'; margin-right: 2px; }
#footer .footer_nav nav .sub-menu { padding-left: 1em; }
#footer .footer_nav nav .sub-menu li a:before { content: '-'; }
#footer .sns { position: absolute; bottom: 25px; left: 0; display: -webkit-flex; display: -ms-flexbox; display: flex; }
@media only screen and (max-width: 880px) { #footer .sns { left: 50%; transform: translateX(-50%); } }
#footer .sns li { list-style: none; margin-right: 18px; }
#footer .sns a { display: block; width: 68px; height: 68px; }
@media only screen and (max-width: 680px) { #footer .sns a { width: 34px; height: 34px; } }
#footer .sns a img { max-width: 100%; }
#footer .copyright { display: -webkit-flex; display: -ms-flexbox; display: flex; -webkit-justify-content: center; -ms-flex-pack: center; justify-content: center; align-items: center; background: #a8372a; font-size: 13px; color: #fff; text-align: center; height: 60px; }
@media only screen and (max-width: 880px) { #footer .copyright { font-size: 10px; } }

/*#footer nav { margin-bottom: 1em;
}

#footer nav p { display: flex; font-size: 1rem;
}

#footer nav a { box-sizing: border-box; border-right: 1px solid #FFF; padding: 0 2.4%; text-align: center;
}

#footer nav a:first-child { padding-left: 0;
}

#footer nav a:last-child { border-right: none; padding-right: 0; white-space: nowrap;
}

#footer nav a:link,
#footer nav a:visited { color: #FFF; text-decoration: none;
}

#footer nav a:hover { text-decoration: underline;
}

#footer .copyright { margin-bottom: 4em; letter-spacing: 2px;
}

#footer .copyright br { display: none;
}

#footer h3 { margin-bottom: 1.2em; font-size: 1rem; text-align: center;
}

#footer h3 span { position: relative; display: inline-block;
}

#footer h3 span:after,
#footer h3 span:before { content: ""; position: absolute; top: calc(50% - 1px); display: inline-block; border-top: 3px solid #FFF; width: 100px; height: 0;
}

#footer h3 span:after { left: calc(-100px - 1em);
}

#footer h3 span:before { right: calc(-100px - 1em);
}

#footer ul { display: flex; flex-wrap: wrap; justify-content: space-between; width: 146px; margin: 0 auto; list-style: none;
}

#footer li { width: 58px; height: 58px;
}

#footer li a { display: block; background-image: url("../_images/common/footer-icons.png"); height: 58px; text-indent: -9999px;
}

#footer li:nth-child(1) a { background-position: -200px 0;
}

#footer li:nth-child(2) a { background-position: -258px 0;
}

@media screen and (max-width: 1140px) { #footer nav p { font-size: 0.875rem; }
 #footer nav a { padding: 0 1.5%; }

}

@media screen and (max-width: 880px) {
 #footer nav p { flex-wrap: wrap; font-size: 0.75rem; }
 #footer nav p a { box-sizing: border-box; border-width: 1px 0 0 1px; border-style: solid; border-color: #444; width: 25%; padding: 4px 0; }
 #footer nav p a:nth-child(4) { border-right-width: 1px; }
 #footer nav p a:nth-child(n + 5) { border-width: 1px 0 1px 1px; }
 #footer nav p a:last-child { border-right: 1px solid #444; }
 #footer .copyright { text-align: center; }
 #footer .copyright br:nth-of-type(1) { display: block; }

}


@media screen and (max-width: 680px) {
 #footer { padding: 20px 0 25px 0; }
 #footer h2 { margin-bottom: 0.8em; font-size: 1rem; text-align: center; }
 #footer nav p { flex-wrap: wrap; font-size: 0.75rem; }
 #footer nav p a { width: 50%; }
 #footer nav p a:nth-child(n + 5) { border-width: 1px 0 0 1px; }
 #footer nav p a:nth-child(even) { border-width: 1px 1px 0 1px; }
 #footer nav p a:nth-child(n + 7) { border-width: 1px 0 1px 1px; }
 #footer nav p a:last-child { border-right: 1px solid #444; }
 #footer ul { width: 111px; }
 #footer li { width: 48px; height: 48px; }
 #footer li a { background-repeat: no-repeat; background-size: 261px; height: 48px; }
 #footer li:nth-child(1) a { background-position: -165px 0; }
 #footer li:nth-child(2) a { background-position: -213px 0; }

 #footer .copyright { margin-bottom: 1.5em; padding: 0; letter-spacing: 0; }

 #footer h3 { margin-bottom: 1em; }
 #footer h3 span:after, #footer h3 span:before { width: 80px; }
 #footer h3 span:after { left: calc(-80px - 1em); }
 #footer h3 span:before { right: calc(-80px - 1em); }

}

@media screen and (max-width: 480px) { #footer .copyright { font-size: 0.625rem; }
 #footer .copyright br { display: block; }

}

@media screen and (max-width: 360px) {
 #footer h3 span:after, #footer h3 span:before { width: 60px; }
 #footer h3 span:after { left: calc(-60px - 1em); }
 #footer h3 span:before { right: calc(-60px - 1em); }

}*/
.job_cta { margin-top: 32px; }
.job_cta .card_list { display: -webkit-flex; display: -ms-flexbox; display: flex; -webkit-justify-content: space-between; -ms-flex-pack: justify; justify-content: space-between; }
@media only screen and (max-width: 680px) { .job_cta .card_list { flex-direction: column; align-items: center; } }
.job_cta .card_list .card { width: 30%; }
@media only screen and (max-width: 680px) { .job_cta .card_list .card { width: 100%; text-align: center; } }
.job_cta .card_list .card_title { display: -webkit-flex; display: -ms-flexbox; display: flex; -webkit-justify-content: center; -ms-flex-pack: center; justify-content: center; align-items: center; font-family: 'nsj-md', sans-serif; text-align: center; height: 4em; }
@media only screen and (max-width: 680px) { .job_cta .card_list .card_title { font-size: 13px; } }
.job_cta .job_cta_btn { margin-top: 24px; }
.job_cta .job_cta_btn a { box-sizing: border-box; display: -webkit-flex; display: -ms-flexbox; display: flex; -webkit-justify-content: center; -ms-flex-pack: center; justify-content: center; align-items: center; margin: 0 auto; padding-right: 20px; width: 380px; height: 60px; font-family: 'nsj-bold', sans-serif; color: #cc0000; border: 2px solid #c1261f; position: relative; -moz-transition: 0.3s; -webkit-transition: 0.3s; -ms-transition: 0.3s; transition: 0.3s; }
@media only screen and (max-width: 680px) { .job_cta .job_cta_btn a { width: 280px; height: 40px; font-size: 13px; padding-right: 0; } }
.job_cta .job_cta_btn a:hover { background: rgba(193, 38, 31, 0.1); }
.job_cta .job_cta_btn a:after { content: ''; position: absolute; width: 10px; height: 100%; background: url("../image/arrow_red2.png") center center no-repeat; background-size: contain; right: 20px; }
@media only screen and (max-width: 680px) { .job_cta .job_cta_btn a:after { width: 7px; right: 10px; } }

.flow { width: 80%; margin: 0 auto; list-style: none; counter-reset: number 0; }
.flow.order li { height: auto; }
.flow.order li:not(:first-child) { margin-top: -180px; }
.flow.order li:after { height: calc(100% - 70px); }

.flow li { position: relative; height: calc(6em + 4px); margin-bottom: 3em; }
.flow li > div { font-family: 'nsj-md', sans-serif; }

.flow li:before { position: absolute; left: calc(50% - 2em - 2px); z-index: 1; display: block; background-color: #CCC; color: #FFF; border: 2px solid #234499; border-radius: 50%; width: 4em; height: 2em; line-height: 1; padding: 1em 0; font-family: "fgm", sans-serif; text-align: center; counter-increment: number; content: "STEP\a" counter(number,decimal-leading-zero); white-space: pre; }

.flow li:after { content: ""; position: absolute; left: calc(50% - 0.5em); display: block; background-color: #CCC; width: 1em; top: 0; height: calc(100% + 60px); }

.flow li:last-child:after { display: none; }

.flow li div:first-child { position: relative; box-sizing: border-box; color: #234499; width: 50%; padding: 1em 0 0 0; line-height: 1; font-size: 1.25rem; font-family: 'nsj-bold', sans-serif; }
.flow li div:first-child span { background: #fff; display: inline-block; padding: 0 10px; }

.flow li div:first-child:before { content: ""; position: absolute; top: calc(50% + 0.5em); left: 0; display: block; background-color: #234499; height: 2px; width: 100%; z-index: -1; }

.flow .right p { left: calc(50% + 6em); width: calc(50% - 8em); }

.flow .right > div { font-family: 'nsj-md', sans-serif; padding-left: calc(50% + 60px); }

.flow .right div:first-child { left: 50%; padding-left: 3.1em; }

.flow .right div:first-child:before { content: ""; position: absolute; top: calc(50% + 0.6em); left: 1.3em; display: block; background-color: #234499; width: 1.3em; height: 2px; }

#content .flow li p { position: relative; max-width: 313px; font-size: 0.75rem; margin-top: 1.5em; padding: 0; text-align: left; font-family: 'nsj-md', sans-serif; font-weight: normal; }

#content .flow li p.flow-desc { margin-top: 10px; margin-bottom: 10px; padding-left: 13px; line-height: 1.4; }
#content .flow li p.flow-desc:before { content: '・'; position: absolute; left: 0; top: 0.1em; }

.flow li:nth-child(1):before { background: #85CFE9; }

.flow li:nth-child(2):before { background: #D61262; }

.flow li:nth-child(3):before { background: #FDD02B; }

.flow li:nth-child(4):before { background: #EA501A; }

.flow li:nth-child(5):before { background: #F29300; }

.flow li:nth-child(6):before { background: #172A88; }

.flow li:nth-child(7):before { background: #1C2D58; }

.flow li:nth-child(8):before { background: #920783; }

.flow li:nth-child(9):before { background: #8ACEC8; }

.flow li:nth-child(9):after { content: none; }

/*カタログ販売フロー スマホver*/
.flow_sp { display: none; }

@media screen and (max-width: 768px) { .flow { width: 96%; }
  .flow li { padding-left: 80px; }
  .flow li:before { left: 0; }
  .flow li:after { left: 27px; }
  .flow li div:first-child { width: 100%; }
  .flow li div:first-child:before { display: none; }
  .flow .right div:first-child { left: 0; padding-left: 0; }
  .flow .right > div { padding-left: 0; }
  .flow .right p { left: 0; width: auto; }
  .flow.order li:not(:first-child) { margin-top: 0; }
  .flow.order li:after { height: calc(100% + 60px); } }
br.tablet { display: none; }
@media only screen and (max-width: 880px) { br.tablet { display: block; } }

img { -webkit-backface-visibility: hidden; }

.aligncenter { display: block; margin: 0 auto; }

.alignright { display: block; margin-left: auto; }

.alignleft { display: block; margin-right: auto; }

@media screen and (max-width: 680px) {
  h4{min-height:36px!important;height:auto!important;line-height:24px;padding-left:25px;text-align:left;padding-top:4px;padding-bottom:5px;}
  .ow-button-base a{width:100%!important;}
  #content h3{line-height:18px;}
  #pl-6144 #panel-6144-14-0-0, #pl-6144 #panel-6144-19-0-0,#pl-5985 #panel-5985-19-0-1{margin:50px 0px 50px!important;}
}
/*# sourceMappingURL=common.css.map */


/* ヘッダーの「カタログ無料請求」のボタンの表記を「WEBカタログ」 */

.catalog span {
  padding-left: 8px;
}


/* 「特集」欄追加 */

section.pickup_container {
    background: #f3f3ee;
}
section.pickup_container .pickup_inner {
    max-width: 1100px;
    margin: 0 auto;
    position: relative;
}
.pickup_header {
    position: relative;
}
.pickup_header .pickup__title {
    position: relative;
    height: 190px;
    text-align: center;
    font-family: 'nsj-md', sans-serif;
    font-size: 30px;
    padding-top: 60px;
    /* padding-top: 100px; */
    margin-top: 1em;
    /* margin-bottom: 2em; */
    box-sizing: border-box;
    z-index: 1;
}
.pickup_container .pickup__title:before {
    opacity: 0.1;
    color: #c1261f;
}
.pickup_container .pickup__title:before {
    content: 'PICK UP';
    /* color: #fff; */
}
.pickup_header .pickup__title:before {
    position: absolute;
    font-family: "impact", sans-serif;
    font-size: 150px;
    /* font-size: 200px; */
    font-weight: normal;
    line-height: 1;
    width: 100%;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    z-index: -1;
}
.pickup_header .pickup__title .title_en {
    font-family: "impact", sans-serif;
    font-size: 28px;
    font-weight: normal;
    color: #c1261f;
    position: relative;
}
.pickup_header .pickup__title:after {
    display: block;
    content: '';
    width: 30px;
    height: 4px;
    background: #c1261f;
    position: absolute;
    top: 75%;
    /* top: 100%; */
    left: 50%;
    transform: translate(-50%, 0.5em);
}
.pickup_item_list a {
    color: #333;
}
.pickup_item_list a:hover {
    text-decoration: underline;
}

@media only screen and (max-width: 680px) {
section.pickup_container .pickup_inner {
    width: 100%;
}
.pickup_header .pickup__title {
    height: 95px;
    font-size: 20px;
    padding-top: 42px;
}
.pickup_header .pickup__title:before {
    font-size: 100px;
}
.pickup_header .pickup__title:before {
    font-size: 100px;
}
.pickup_header .pickup__title .title_en {
    font-size: 14px;
}
.pickup_header .pickup__title:after {
    width: 15px;
    height: 2px;
}
.pickup_header .pickup__title:after {
    top: 95%;
}
}

.pickup_item {
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    gap: 30px;
    /* background: url(../_images/products/ptn_stripe_f.png); */
    padding: 35px 45px;
    /* margin-top: 38px; */
}
.pickup_item article.pickup_item_list {
    background: #fff;
    width: 33.3333%;
    padding: 20px 18px;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    flex-direction: column;
    box-sizing: border-box;
}
.pickup_item .pickup_item_list .pickup_desc {
    font-family: "nsj-reg", sans-serif;
    font-size: 15px;
    line-height: 1.8;
    margin-top: 1.5em;
    margin-bottom: 2.5em;
}

@media only screen and (max-width: 991px) {
.pickup_item {
    flex-direction: column;
    gap: 20px;
    max-width: 680px;
    margin-top: 18px;
    padding: 22px 15px;
}
.pickup_item article.pickup_item_list {
    width: 100%;
}
.pickup_item pickup_item_list .pickup_desc {
    font-size: 13px;
}
}