/*
Theme Name:sanki-theme-2025
Author: Sanki Sangyo
Author URI: https://www.sanki-kobe.com/
Version: 1.0
*/

/* --------------------------------------
ブラウザスタイル初期化
--------------------------------------*/
*, *:before, *:after {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}
body, div, dl, dt, dd, ul, ol, li, h1, h2, h3, h4, h5, h6, pre, form, fieldset, p, blockquote, th, td {
    margin: 0;
    padding: 0;
}
html, body {
    width: 100%;
}
img {
    vertical-align: bottom;
}
a {
	transition: all 0.3s;
}

/* --------------------------------------
背景＆基本設定
--------------------------------------*/
html {
    overflow:auto;
}
body {
    font-size:1em;
    background-color: white;
    -webkit-text-size-adjust: none;
    min-width: 980px;
    font-family: "IBM Plex Sans JP", 'Hiragino Kaku Gothic ProN', 'ヒラギノ角ゴ ProN W3',  Meiryo, メイリオ, sans-serif;
    overflow-x: hidden;
    position: relative;
    color: #333333;
}
img {
    border: none;
}
a {
    color: #333333;
}
a:link {
    color: #333333;
}
a:hover {
    color: #666666;
}
a:visited {
    color: #333333;
}
p {
    margin: 0;
    padding: 0;
    line-height: 2;
}
ul {
    list-style: none;
    margin-bottom: 20px;
}
ol {
    margin-left: 25px;
}

hr {
    overflow: hidden;
    height: 0;
    border: #bdbdbd dotted 1px;
    margin: 5px 0 15px 0;
}

/* --------------------------------------
レイアウト定義
--------------------------------------*/

.wrapper {
    padding: 0;
    z-index: 1;
    position: relative;
    padding-top: 0px;
    background-color: #ffffff;
}
/*トップページメイン画面*/
#ibox,#ibox-kari {
width: 100%;
    height: 650px;
    position: relative;
	    z-index: 100;
	background:white;
}
#ibox:before,#ibox-kari:before {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    right: 0;
    left: 0;
}
#ibox-in {
    text-align: center;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 100%;
}
#ibox-in p {
    color: #000000;
    font-size: 2em;
    font-family: 'Shippori Mincho', serif;
    line-height: 1.7;
    display: inline-block;
}
#ibox-in .ibox-big {
    font-size: 3em;
    background: rgb(255 255 255 / 70%);
    padding: 2px 10px;
}
div#vegasSliderInner {
    position: relative;
    width: 100%;
    height: 650px;
}
div#vegasSliderInner .in-ibox-link-wrap a {
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
	transition:0.3s;
}
div#vegasSliderInner .in-ibox-link-wrap a:before {
    content: "";
    background: hsl(0deg 0% 100% / 0%);
    position: absolute;
    top: 0;
    bottom: 0;
    right: 0;
    left: 0;
    transition: 0.3s;
}
div#vegasSliderInner .in-ibox-link-wrap a:hover:before {
    background: hsl(0deg 0% 100% / 30%);
}


#content {
    padding: 0px 0;
    width: 1000px;
    margin: 0px auto 30px;
    z-index: 10;
    position: relative;
}

#pan {
    font-size: 0.8em;
    width: auto;
    margin: 10px auto 10px;
    color: #333333;
}
#pan a {
    text-decoration: none;
}
.breadcrumbs {
    display: inline-block;
}
.infobox {
    display: block;
    text-align: center;
    margin-bottom:20px;
}
.cat {
    font-size: 0.8em;
    font-family: 'Arial', 'Helvetica', sans-serif;
    display: inline-block;
}
.cat a {
    text-decoration: none;
    background: black;
    color: white;
    padding: 4px 10px;
    border-radius: 40px;
}
#content #main .cat p {
    margin-bottom:0;
}
.tags a {
     border: 1px solid #c7c7c7;
    padding: 3px 10px;
    font-size: 0.8em !important;
    margin: 3px;
    border-radius: 2px;
    background-color: white;
    color: black;
    text-decoration:none;
}

#content #main {
    width: 1000px;
    float: none;
    font-size: 1em;
    line-height: 1.8;
    margin: 0 auto;
    text-align: justify;
}

#content #main .post {
    margin-bottom: 40px;
    background-position: center;
    border: 2px solid #00000075;
}

#content #main.main-2 {
    width: 760px;
    float: right;
	    margin-top: 60px;
}

/* --------------------------------------
各ページタイトル
--------------------------------------*/

#content #main .singletitle a, #content #main .title a {
    color: #2c3b42;
    text-decoration: none;
}
/* --------------------------------------
マウスオーバー設定
--------------------------------------*/
#header .menu li a:hover {
    opacity: 0.60; /* opera  firefox safari */
    filter: alpha(opacity=60); /* ie */
    -ms-filter: "alpha( opacity=60 )";
}
#content #main a:hover img {
    opacity: 0.60; /* opera  firefox safari */
    filter: alpha(opacity=60); /* ie */
    -ms-filter: "alpha( opacity=60 )";
}
#content #side a:hover img {
    opacity: 0.60; /* opera  firefox safari */
    filter: alpha(opacity=60); /* ie */
    -ms-filter: "alpha( opacity=60 )";
}
#content #side li:hover {
    opacity: 0.60; /* opera  firefox safari */
    filter: alpha(opacity=60);/* ie */
    -ms-filter: "alpha( opacity=60 )";
    background: #FFF;/* border-left:#ff6000 2px solid; */
}
/* --------------------------------------
ヘッダー定義
--------------------------------------*/
.wrapper_head {
    margin: 0px auto;
    width: 100%;
    z-index: 1000;
    position: relative;
    padding: 0 0 0;
}
header {
    padding: 0 0 0 0;
    margin: 0 0 0;
    background-color: transparent;
    position: absolute;
    width: 100%;
}
#header {
    background-repeat: no-repeat;
    background-position: left top;
    z-index: 1000;
    height: auto;
    position: relative;
    transition: all .3s ease-out;
    width: 100%;
    padding: 20px 3vw 0px;
}
/*ロゴ　スクロール時非表示*/

.header_logo {
    text-align: center;
    margin-bottom: 20px;
    position: relative;
}
.header_logo h1 {
    margin: 0 !important;
    line-height: 0;
}
.header_logo img {
    width: 330px;
}
.header_logo a {
    text-decoration: none;
    line-height: 1;
}
.header_logo a:hover {
	/*opacity:0.6;*/
}
/*ロゴ左寄せ*/
.header_logo.logo_left {
    margin-bottom: 20px;
}
header .info_right {
    margin-bottom: 20px;
    width: 50%;
}
header .mail-zone a {
    padding: 28px 0 0;
    display: block;
    background: gray;
    height: 108px;
    width: 120px;
    font-size: 0.9em;
    color: white;
    text-decoration: none;
    font-family: 'Noto Serif JP', serif;
}
header .mail-zone img {
    display: block;
    width: 34px;
    margin: 0px auto 12px;
}

.h-sub {
    display: block;
    font-size: 0.9em;
    position: relative;
    font-family: 'Shippori Mincho', serif;
    font-weight: normal;
}

#pagetop {
    display: block;
    position: absolute;
    right: 0;
    bottom: 0;
}
a#pagetop:hover {
    opacity: 0.6;
}

/*-------------------------------------
グローバルナビ定義（gnavi・グロナビ）
------------------------------------- */

#gnav {
    background: #ffffff;
    width: 100vw;
    margin-left: calc(-50vw + 50%);
    background-size: auto;
    position: relative;
}
#pc-nav {
    flex-wrap: wrap;
    justify-content: space-between;
    display: flex;
    margin: 0;
}
#pc-nav li {
    width: auto;
    padding: 14px 0 14px;
    position: relative;
}
#pc-nav li a, #pc-nav li .nav-span {
    border-color: #d5cec5;
    width: 100%;
    height: 38px;
    text-align: center;
    display: flex;
    justify-content: center;
    align-items: center;
    text-decoration: none;
    position: relative;
    font-size: 0.8em;
    color: white;
    font-weight: bold;
	cursor: pointer;
}
@media screen and (min-width:1600px) {
	/*大画面に対応*/
#pc-nav li a, #pc-nav li .nav-span {
	font-size: 1em;
}
}
#pc-nav li .nav-span.nav-con {
    border: 1px solid;
    padding: 0 20px;
    border-radius: 200px;
}
#pc-nav li:last-child a {
    border-color: #d5cec5;
}
#pc-nav li a:hover {
opacity:0.6;
}

#sp-nav {
    display:none;
}

#navbutton {
    display: block;
    position: absolute;
    top: 20px;
    right: 20px;
    height: auto;
    padding: 0;
    transition: all .5s ease;
    text-align: center;
}

#navbutton .lines {
    background: white;
    display: inline-block;
    width: 30px;
    height: 2px;
    position: relative;
    transition: .3s;
    margin: 0 9px 0;
}
#navbutton .lines:after, #navbutton .lines:before {
    background: white;
    position: absolute;
    display: inline-block;
    height: 2px;
    content: '';
    transition: .3s;
}

#navbutton .lines:before {
    top: 9px;
    right: 0;
    width: 30px;
}

#navbutton .lines:after {
top: -9px;
    right: 0px;
    width: 30px;
}

#navbutton span.menu-tx {
    font-size: 0.7px;
    display: block;
    margin-top: 6px;
    color: white;
}

#navbutton a.xclose {
    display: block;
    position: relative;
    margin-top: 0px;
    z-index: 1020;
    cursor: pointer;
}

#navbutton .xclose .lines {
    background: 0 0;
}

#navbutton .xclose .lines:before {
    top: 0px;
    right: 0px;
    transform: rotate3d(0,0,1,45deg);
    transition: .3s;
    width: 30px;
}

#navbutton .xclose .lines:after {
    top: 0px;
    right: 0px;
    transform: rotate3d(0,0,1,-45deg);
    transition: .3s;
}

a#sidr-menu-button {
    display: block;
    position: relative;
    padding: 8px;
    margin-top: 0px;
    cursor: pointer;
    opacity: 1;
    transition: all .5s ease;
    text-decoration: none;
    border: 1px solid #b6b6b6;
    border-radius: 4px;
}
#h-nav {
    display: none;
}
/*ハンバーガメニューcss*/
.ac-nav, .sidr-class-ac-nav {
    width: 100%;
    line-height: 1.2;
}

.ac-child a, .sidr-class-ac-child a {
    text-decoration: none;
    padding: 10px 20px 10px 40px;
    display: block;
    font-size: 90%;
    position: relative;
    border-bottom: 1px solid #d8d8d8;
}

.ac-parent,
.sidr-class-ac-parent,
.ac-alone,
.sidr-class-ac-alone {
    position: relative;
	border-bottom: 1px solid #00c400;
    color: black;
    text-align: center;
    cursor: pointer;
    width: 100%;
    float: none;
    clear: none;
    padding: 0;
    text-align: left;
}

.ac-alone a,
.sidr-class-ac-alone a,
.ac-parent,
.sidr-class-ac-parent {
    text-decoration: none;
    padding: 14px 10px 14px 20px;
    display: block;

}

.ac-alone a:hover,
.sidr-class-ac-alone a:hover,
.ac-parent:hover,
.sidr-class-ac-parent:hover,
.ac-child a:hover, .sidr-class-ac-child a:hover {
    opacity:0.6;
}


/* 擬似要素で三角形を作成 */
.ac-alone a:before, .sidr-class-ac-alone a:before, .ac-parent:before, .sidr-class-ac-parent:before {
    content: '';
    width: 8px;
    height: 8px;
    -webkit-transform: translate(0, -50%) rotate( 45deg);
    transform: translate(0, -50%) rotate( 45deg);
    position: absolute;
    top: 50%;
    left: 10px;
    transition: .3s;
}

.ac-parent:after, .sidr-class-ac-parent:after {
    content: '';
    width: 10px;
    height: 10px;
    border-top: 2px solid #00c400;
    border-right: 2px solid #00c400;
    -webkit-transform: translate(0, -50%) rotate( 45deg);
    transform: translate(0, -50%) rotate( 135deg);
    position: absolute;
    top: 50%;
    right: 12px;
    transition: .3s;
}

/* オープン時にopenクラスを付与 */
.ac-parent.open:after, .sidr-class-ac-parent.open:after {
    transform: rotate(-45deg);
}
.ac-child, .sidr-class-ac-child {
    display: none;
    background-color: white;
    text-align: left;
    padding: 10px 0;
        border: none;
}
.ac-child a:before, .sidr-class-ac-child a:before {
    content: '';
    width: 6px;
    height: 6px;
    border-top: 1px solid #6a6a6a;
    border-right: 1px solid #6a6a6a;
    -webkit-transform: translate(0, -50%) rotate(45deg);
    transform: translate(0, -50%) rotate(45deg);
    position: absolute;
    top: 50%;
    left: 20px;
    transition: .3s;
}

.sidr-class-nav-res {
    padding: 20px;
    background: white;
}
.sidr-class-nav-res a {
    display: block;
    margin: 0 0 10px;
}
.sidr-class-nav-res a img {
    width: 100%;
    height: auto;
}
p.sidr-class-nav-info {
    color: rgb(152, 152, 152);
    line-height: 1.4;
    display: block;
}
p.sidr-class-nav-info span {
    color: #0076c1;
}


/*--ここまで--*/


/* -------------------------------------
ドロップダウン
-------------------------------------*/
#pc-nav ul.sub-menu {
    display: none;
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    z-index: 9999;
    width: 180px;
    background-color: #ffffff;
    padding: 20px 0;
    border-radius: 8px;
}
#pc-nav ul.sub-menu.nav-con-menu {
	    top: 58px;
}


#pc-nav ul.sub-menu li {
    float: none;
    position: static;
    background-image: none;
    width: auto;
    border: none;
    width: 100%;
    text-align: left;
    padding: 0;
    position: relative;
}
#pc-nav ul.sub-menu li:hover {
opacity:0.6;
}
#pc-nav ul.sub-menu li a {
    text-indent: 0px;
    font-size: 0.8rem;
    padding: 2px 20px;
    color: #000000;
    display: block;
    border: none;
    height: auto;
    text-align: center;
    transition: 0.2s;
}

#pc-nav ul.sub-menu li a:hover {
    opacity: 0.6;
    background: unset;
    transition: all 0.3s;
}

#pc-nav ul.sub-menu li:hover:before{
    content:none;
}

#pc-nav ul.sub-sub-menu {
    margin-bottom:0;
}
#pc-nav ul.sub-sub-menu li a {
    font-size: 90%;
    color: #3c3c3c;
    line-height: 1.3;
    padding-left: 30px;
    position: relative;
}

#pc-nav ul.sub-sub-menu li a:before {
    content: "∟";
    position: absolute;
    top: 9px;
    left: 7px;
}


/* --------------------------------------
サイドバー定義
--------------------------------------*/
#content #side {
    position: relative;
    float: left;
    width: 210px;
    font-size: 0.9em;
	    margin-top: 60px;
}

#content #side ul li {
    position: relative;
}

#content #side a {
    text-decoration: none;
    display: block;
    line-height: 1.6;
    padding: 8px 10px;
    border-bottom: 1px solid #d9d9d9;
}

/* --------------------------------------
フッター定義
--------------------------------------*/
footer {
    margin-top:120px;
    background: white;
}
#footer {
    clear: both;
    text-align: center;
    font-size: 0.85em;
    padding-bottom: 0px;
	position: relative;
    z-index: 10;
}
/* フッター文字色定義 */

.footer_logo a {
    text-decoration: none;
    line-height: 1;
}
.footer_logo img {
    width: 268px;
    height: auto;
}
.footer_info {
    margin-top: 20px;
}
.footer_com {
    height: auto;
    padding-top: 34px;
}

.footer_top {
    width: 1000px;
    margin: 0px auto 46px;
}
.footer_left {
    width: 50%;
    text-align:left;
}
.footer_right {
    width: 50%;
}

#footer-nav {
    justify-content: flex-start;
    flex-flow: wrap column;
    height: 160px;
    margin: 10px 0;
    margin-left: 20px;
}
#footer-nav a {
    text-decoration: none;
    font-size: 0.9rem;
    position: relative;
	    color: #4f4f4f;
}
#footer-nav a:hover {
    opacity: 0.6;
}
#footer-nav li {
    display: block;
    margin: 8px 20px;
    display: list-item;
}
#footer-nav li#f-nav-sub-wrap {
    width: 60%;
}

#footer-nav-sub {
    margin-left: 10px;
}
#footer-nav-sub li {
    width: 100%;
    margin: 0;
}
#footer-nav-sub a {
    font-weight: normal;
    line-height: 1.4;
    display: block;
    margin: 10px 0;
    padding: 0 0 0 12px;
}
#footer-nav-sub a:before {
    content: "∟";
    color: gray !important;
    position: absolute;
    top: 50%;
    left: 0;
    transform: translateY(-50%);
    color: #49a56f;
    font-size: 0.9em;
    margin-right: 6px;
}

.footer_btm {
    width: 100vw;
    margin-left: calc(-50vw + 50%);
    background: #d9f6d9;
    padding: 10px 0;
}
.footer_btm_wrap {
    width: 1000px;
    margin: 0 auto;
}
#footermenu {
    margin: 0px 0px 20px 0;
    text-align: left;
}
#footermenu ul {
    display: inline;
}
#footermenu ul li {
    display: inline-block;
    font-size: 0.85em;
    padding: 0 0 0 10px;
    width: auto;
    white-space: nowrap;
}
#footermenu ul li:first-child {
    padding: 0 0 0 0;
}
#footermenu ul a {
    text-decoration: none;
    font-size: 0.8em;
}
#footermenu ul a:hover {
    opacity: 0.60;
    filter: alpha(opacity=60);
    -ms-filter: "alpha( opacity=60 )";
}
#copyright {
    padding: 0;
    font-size: 0.8em;
    color: black;
    text-align: center;
}
#copyright a {
    text-decoration: none;
    color: white;
}
/* --------------------------------------
コンテンツ共通パーツ
--------------------------------------*/

#content #main p {
    margin-bottom: 24px;
    padding: 0;
}
#content #main .singleline {
    overflow: hidden;
}
.datetx {
    font-size: 0.9em;
    display: block;
    text-align: left;
}
.datetx p {
color:#00c400 !important;
	    margin-bottom: 6px !important;
}
#submain {
    height: auto;
    background-color: #a4e2a2;
    position: relative;
    text-align: center;
    margin: 0 0 20px;
    padding: 70px 30px;
    height: 350px;
    display: flex;
    align-items: flex-end;
}
#submain img {
    width: 100%;
    height: auto;
    position: absolute;
    z-index: 0;
    top: -550px;
    opacity: 0.5;
}
#submain .h1wrap {
    width: 1000px;
    margin: 0 auto;
}
#submain h1 {
    color: white;
    text-align: left;
    padding: 0px 0px 0px;
    font-size: 2em;
    font-weight: normal;
    display: block;
    margin-top: 0px;
    width: auto;
}
span.subh1-title {
    font-size: 1.1rem;
    color: white;
    display: block;
}
span.subh1-title-big {
    color: #ffffff !important;
    font-size: 3rem;
    font-weight: bold;
    line-height: 1;
    letter-spacing: 2px;
    margin: 20px 0 0px;
    padding: 0;
    text-align: left;
    display: inline-block;
}

.dotted {
    border-bottom: 1px dotted #ccc;
    margin-bottom: 15px;
}
.blog-eyecatch {
    margin: 0 0 16px;
}
.blog-eyecatch img {
    width: 100%;
    height: auto;
    border-top-right-radius: 40px;
    border-bottom-left-radius: 40px;
}
.post_box {
    margin-bottom: 40px !important;
    position: relative;
    width: 30%;
}
.postslink {
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
        z-index: 100;
}

.post_box:hover img, .post_box:hover p,
.topics_box:hover img, .topics_box:hover p {
    opacity: 0.6;
	transition: all 0.3s;
}

.topics_box {
    width: 23%;
    position: relative;
}
.flexwrap.topics-wrap {
    margin-bottom: 20px;
    margin-top: 40px;
}
.flexwrap.topics-wrap:before {
    width: 23%;
    content: "" !important;
    display: block;
    order: 1;
}
.flexwrap.topics-wrap:after {
    width: 23%;
    content: "" !important;
    display: block;
}
.topics_box a {
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
        z-index: 100;
}

.exc-wrap {
    font-size: 0.8em;
}

.e-title {
    text-align: left;
    margin: 0;
    line-height: 1.9;
}

.moretext {
    text-align: center;
    margin-top: 20px;
}

.moretext a {
    display: inline-block;
    padding: 8px 30px;
    border: 1px solid gray;
    border-radius: 4px;
    font-size: 0.8em;
    color: #ffffff;
    text-decoration: none;
}

.moretext a:hover {
    background-color: gray;
    color: white;
}

/* --------------------------------------
コンテンツ背景
--------------------------------------*/

.bg-g-y-wrap {
    width: 100vw;
    margin-left: calc(-50vw + 50%);
    background: rgb(217,246,217);
    background: linear-gradient(90deg, rgba(217,246,217,1) 0%, rgba(255,255,236,40%) 100%);
    position: relative;
}
.bg-g-y-wrap2 {
    width: 100vw;
    margin-left: calc(-50vw + 50%);
    background: rgb(217,246,217);
    background: linear-gradient(90deg, #edfbec 0%,#fcfef6 100%);
}

/* --------------------------------------
見出し設定
--------------------------------------*/

/* h1共通部分 */

#toph1 {
    text-align:center;
    background-color: green;
    margin-bottom:20px;
}

.home #content h1 {
    clear: both;
    color: #ffffff;
    font-size: 0.9em;
    font-weight: bold;
    letter-spacing: 2px;
    line-height: normal;
    position: relative;
    z-index: 10;
    display: inline-block;
    padding: 4px;
}

#content #main h1.singletitle, #content #main h1 {
    clear: both;
    color: #2c3b42;
    font-size: 2em;
    font-weight: normal;
    letter-spacing: 2px;
    line-height: normal;
    text-align: center;
    position: relative;
    z-index: 10;
    padding: 0;
    margin-top: 18px;
}

#content #main h2 {
    clear: both;
    color: #313131;
    font-size: 2.1rem;
    margin: 70px 0px;
    font-weight: bold;
    letter-spacing: 2px;
    line-height: normal;
    padding: 0;
    text-align: center;
    position: relative;
}
#content #main h2:after {
    content: "";
    border-bottom: 2px solid #00c400;
    height: 2px;
    width: 100px;
    display: block;
    margin: 0 auto;
    margin-top: 6px;
    position: absolute;
    bottom: -16px;
    left: 50%;
    transform: translate(-50%, 0);
}
#content #main h3 {
    clear: both;
    color: #00c400;
    font-size: 1.2em;
    margin: 40px 0px 16px;
    font-weight: bold;
    letter-spacing: 2px;
    line-height: normal;
    padding: 0;
    text-align: left;
}
#content #main h4 {
    clear: both;
    color: #303030;
    font-size: 1.1em;
    margin: 48px 0 16px 0;
    font-weight: bold;
    letter-spacing: 1px;
    line-height: normal;
    padding: 0;
}

#side h2 {
    clear: both;
    color: #444444;
    border-bottom: #d9d9d9 solid 2px;
    font-size: 1rem;
    margin: 70px 0 2px 0;
    font-weight: bold;
    letter-spacing: 2px;
    line-height: normal;
    padding: 0px 0 10px;
}
#side .side_area .widget:first-child h2 {
    margin-top: 0px;
}

/* --------------------------------------
デバイスごとの表示
--------------------------------------*/
.sp_only {/* スマホにだけ表示させたいものに使用する */
    display: none;
}

/* --------------------------------------
WordPress FCKEditor table
--------------------------------------*/

table {
    border-collapse: collapse;
    width: 100%;
    margin: 0 auto 5px auto;
}
td {
    padding: 10px;
}
/* --------------------------------------
テーブル
--------------------------------------*/

.tablestyle {
    border-collapse: collapse;
    width: 100%;
    margin: 0 auto;
}
.tdstyle {
    background-color: #ffffff;
    padding: 8px 10px;
    width: 26%;
    text-align: center;
    font-weight: normal;
}
.tdstyle_none {
    background-color: #F5F3F3;
    border: 1px solid #d2d2d2;
    padding: 8px 10px;
    text-align: center;
}
.tablestyle td {
    padding: 40px 10px;
    border-bottom: 1px solid #d0d0d0;
}

/* --------------------------------------
<div class="sq?"></div>での 飾り設定
--------------------------------------*/
.sq1, .sq2, .sq3, .sq4, .sqred {
    display: inline-block;
}
/* 色:グレー */
.sq1 {
    border: 1px solid #ECEBEB;
    background-color: #F3F3F3;
    margin: 0 0 20px 0;
    padding: 20px 20px 0 20px;
}
/* 囲み:グレー */
.sq2 {
    border: 5px solid #F3F3F3;
    background-color: #fff;
    margin: 0 0 20px 0;
    padding: 20px 20px 0 20px;
}
/* 色:ピンク */
.sq3 {
    border: 1px solid #FFE8E8;
    background-color: #fff1f4;
    margin: 10px 0;
    padding: 20px 20px 0 20px;
}
/* 囲み:ピンク */
.sq4 {
    border: 5px solid #fff1f4;
    background-color: #fff;
    margin: 10px 0;
    padding: 20px 20px 0 20px;
    ;
}
/* 囲み：赤 */
.sqred {
    border: 1px solid #f29e9e;
    background-color: #fffafa;
    margin: 10px 0;
    padding: 20px 20px 0 20px;
}


/* --------------------------------------
テキスト飾り設定
--------------------------------------*/

.hosoku {
    color: #5a5a5a;
    font-size: 90%;
}
.hissu {
    font-size: 0.8em;
    color: #ffffff;
    margin-left: 10px;
    font-weight: normal;
    background: #e60012;
    padding: 3px 6px;
}
.nini {
    font-size: 0.8em;
    color: #ffffff;
    margin-left: 10px;
    font-weight: normal;
    background: #737373;
    padding: 3px 6px;
}
.fs70 {
    font-size: 70%;
}
.fs80 {
    font-size: 80%;
}
.fs90 {
    font-size: 90%;
}
.fs110 {
    font-size: 110%;
}
.fs120 {
    font-size: 120%;
}
.fs130 {
    font-size: 130%;
}
.fs160 {
    font-size: 160%;
}
.fs200 {
    font-size: 200%;
}
.mt0 {
    margin-top: 0px !important;
}
.mt10 {
    margin-top: 10px !important;
}
.mt20 {
    margin-top: 20px !important;
}
.mt30 {
    margin-top: 30px !important;
}
.mt40 {
    margin-top: 40px !important;
}
.mt50 {
    margin-top: 50px !important;
}
.mt60 {
    margin-top: 60px !important;
}
.mt-60 {
    margin-top: -60px !important;
}
.mt70 {
    margin-top: 70px !important;
}
.mt80 {
    margin-top: 80px !important;
}
.mb0 {
    margin-bottom: 0px !important;
}
.mb1rem {
    margin-bottom: 1rem !important;
	    display: inline-block;
}
.mb10 {
    margin-bottom: 10px !important;
}
.mb20 {
    margin-bottom: 20px !important;
}
.mb30 {
    margin-bottom: 30px !important;
}
.mb40 {
    margin-bottom: 40px !important;
}
.mb50 {
    margin-bottom: 50px !important;
}
.mb60 {
    margin-bottom: 60px !important;
}
.mb70 {
    margin-bottom: 70px !important;
}
.mb80 {
    margin-bottom: 80px !important;
}
.ml10 {
    margin-left: 10px !important;
}
.ml15 {
    margin-left: 15px !important;
}
.ml20 {
    margin-left: 20px !important;
}
.ml25 {
    margin-left: 25px !important;
}
.ml30 {
    margin-left: 30px !important;
}
.pt10 {
    padding-top: 10px !important;
}

/*テキスト装飾*/
.tk1 {
    font-weight: bold;
    color: #00c400 !important;
    font-size: 116%;
}
.tk2 {
    font-weight: bold;
    font-size: 116%;
}
.tk3 {
  font-weight: bold;
  background: linear-gradient(transparent 70%, #ff3737 20%);
  padding-bottom: 3px;
}
.star {
    display: inline-block;
    margin-right: 20px;
    color: #bda357;
}
/*電話番号装飾*/
.telarea {
  border: 1px solid #CECECE;
  margin: 0 0 10px 0;
  padding: 20px 20px 0 20px;
  display: inline-block;
}
.teltext {
  font-size: 2em;
}
.freedial {
  text-align: left;
}
.uline {
    color: #F00;
    text-decoration: underline;
    font-style: italic;
}

/* --------------------------------------
WordPress 画像貼付け用
--------------------------------------*/
.aligncenter {
    display: block;
    margin-left: auto;
    margin-right: auto;
}
.alignright {
    float: right;
    margin: 0 0 20px 20px;
    display: inline;
}
.alignleft {
    float: left;
    margin: 0 20px 20px 0;
    display: inline;
}
/* --------------------------------------
youtube・googlemap 埋め込み用
--------------------------------------*/
.yt {
    position: relative;
    padding-bottom: 56.25%;
    padding-top: 30px;
    height: 0;
    overflow: hidden;
}

.yt iframe,
.yt object,
.yt embed {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}
/* --------------------------------------
汎用クラス定義
--------------------------------------*/
.clearfix:after {
    content: ".";  /* 新しい要素を作る */
    display: block;  /* ブロックレベル要素に */
    clear: both;
    height: 0;
    visibility: hidden;
}
.clearfix {
    min-height: 1px;
}
* html .clearfix {
    height: 1px;
}


/* --------------------------------------
中央寄せ・右寄せ
--------------------------------------*/
.ac {
    text-align: center;
}
.ar {
    text-align: right;
}
.al {
    text-align: left;
}
/* --------------------------------------
リスト
--------------------------------------*/
ul {
    text-align: left;

}
ul.ul_1 {
    margin-bottom: 20px;
}
ul.ul_1 li {
    position: relative;
    margin-bottom: 1rem;
    padding-left: 1em;
    /* list-style: disc; */
    line-height: 1.4;
}
ul.ul_1 li:before {
    content: "・";
    position: absolute;
    left: 0;
}
ul.ul_1 li:last-child {
    margin-bottom: 0;
}
ul.ul_2 {
    max-width: 500px;
}
ul.ul_2 li {
    display: inline-block;
}
ul.ul_2 li:nth-child(5) {
    margin-bottom: 0;
}
ul.ul_2 li:nth-child(6) {
    margin-bottom: 0;
}

ul.ul_3 li:last-child {
    margin-bottom: 0;
}

/* --------------------------------------
レイアウトbox(2列・3列・4列)
--------------------------------------*/
.flexwrap {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}

.flexeven {
  justify-content: space-evenly;
  display: flex;
  flex-wrap: wrap;
}

#main div.flexwrap:after,#main div.flex-even:after {
    content: none;
}

.two_box {
    width: 48%;
    box-sizing: border-box;
    padding: 0 0 0 0;
    margin: 0 0 0 0;
}

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

.three_box {
    width: 32%;
    box-sizing: border-box;
    padding: 0 0 0 0;
    margin: 0 0 0 0;
}

.four_box {
    width: 22%;
    box-sizing: border-box;
    padding: 0 0 0 0;
    margin: 0 0 0 0;
}
.four_box:first-child {
    margin-left: 0;
}


/* --------------------------------------
電話番号エリア
--------------------------------------*/
.responsedevise {
    border: 1px solid #c1c1c1;
    padding: 15px 5px 15px;
    text-align: center;
    width: 80%;
    margin: 80px auto 0;
    border-radius: 5px;
    position:relative;
    overflow:hidden;
}

/* --------------------------------------
リンクボタン
--------------------------------------*/
.link-t1 {
    text-align: left;
    background: none;
    /* color: #003461 !important; */
    display: inline-block;
    width: auto;
    padding: 6px 14px 6px 0px;
    margin: 0 0 20px;
    text-decoration: none !important;
    line-height: 1.2;
    position: relative;
}

.link-t1:hover {
    opacity:0.6;
}
.btn-b {
    display: inline-block;
}

.btn-b a {
    display: inline-block;
    padding: 18px 60px 20px;
    background: black;
    color: white;
    text-decoration: none;
}

.btn-b a:hover {
    opacity: 0.6;
}

.btn-bs {
    display: inline-block;
}

.btn-bs a {
    display: inline-block;
    padding: 16px 40px 18px;
    background: black;
    color: white;
    text-decoration: none;
    font-size:90%;
    margin: 0 5px;
}

.btn-bs a:hover {
    opacity: 0.6;
}

/* ---------------------
H レスポンシブ用
------------------------*/

/* PC用とモバイル用のロゴを出し分ける */

#pc_logo {
    display: inline;
}
#pc_logo img {
    margin: 0 auto;
}

#content #main p.wp-caption-text {
    margin-top: 2px;
    font-size: 0.9em;
    text-align: center;
    margin-right: 10px;
    padding: 10px 10px 0;
    line-height: 17px;
}

/* --------------------------------------
フォームボタン
--------------------------------------*/

input.wpcf7-form-control {
    height: auto;
    line-height: 2;
    margin: 0px auto;
    border: 1px solid #d8d8d8;
    padding: 10px;
    width: 80%;
}
input.wpcf7-form-control.wpcf7-submit {
    height: auto;
    line-height: 2;
    margin: 0 auto 0;
    border: none;
    padding: 10px;
    background-color: white;
    width: 260px;
    font-weight: normal;
    font-size: 1.1em;
    color: #444444;
    cursor: pointer;
    display: block;
    border: 1px solid #00c400;
    border-radius: 100px;
	position:relative;
}


input.wpcf7-form-control.wpcf7-submit:after {
    content: "";
    color: #00c400;
    position: absolute;
    right: 20px;
    font-weight: bold;
    font-size: 20px;
    line-height: 1;
    width: 15px;
    height: 13px;
    background: url(img/rd-arrow.png);
    top: 50%;
    transform: translate(0, -50%);
}


span.wpcf7-spinner {
    position: absolute;
    margin: 10px;
    left: 50%;
    transform: translate(-90%, 0);
}


.wpcf7-form-control .wpcf7-list-item {
    display: inline-block;
    margin: 0 20px 0 0;
}
select.wpcf7-form-control {/*プルダウンメニュー*/
    width: auto;
    height: auto;
}
textarea.wpcf7-form-control {
    border: 1px solid #d8d8d8;
    padding: 10px;
    width: 80%;
	line-height: 2;
	font-family: 'Hiragino Kaku Gothic ProN', 'ヒラギノ角ゴ ProN W3', Meiryo, メイリオ, sans-serif;
}

.s-button {
    text-align:center;
}
.s-button p {
    margin-bottom: 0 !important;
    display: inline-block;
    position: relative;
}

.s-button p img {
    position: absolute;
    top: 50%;
    right: 20px;
    transform: translate(0%, -50%);
}

.s-button input {
    padding: 10px 40px;
    height: auto;
    margin-top: 50px;
    cursor: pointer;
    width: 200px;
    font-size: 1.2em;
    background-color: black;
    color: white;
    border: none;
}

.s-button p:hover ,.s-button p:hover img  {
    opacity:0.6;
}

/*コンテンツ装飾
ここから*/

.footer_info dl {
    display: flex;
    flex-wrap: wrap;
    color: #4f4f4f;
}
.footer_info dt {
	width: 190px;
    line-height: 2;
}
.footer_info dd {
    line-height: 2;
}
.rd-wrap {
    width: 100%;
    height: 400px;
    background: url(img/rd-bg.jpg);
    background-repeat: no-repeat;
    background-size: cover;
    background-position: right bottom;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
}
.rd-txt-wrap {
    width: 100%;
}
.rd-txt-inner {
    width: 1000px;
    margin: 0 auto;
	text-align: left;
}
.rd-txt-inner p {
    color: white;
    font-size: 1.2rem;
    line-height: 1;
}
.rd-en-txt {
    color: #ffff00 !important;
	    font-size: 3rem;
	    font-weight: bold;
    line-height: 1;
    letter-spacing: 2px;
    margin: 20px 0 30px;
    padding: 0;
    text-align: left;
}
.en-green {
	 color: #00c400 !important;
}
#content #main .en-txt {
    font-size: 2.8rem;
    font-weight: bold;
    line-height: 1;
    letter-spacing: 2px;
    margin: 0 0 30px;
    padding: 0;
    text-align: left;
}
#content #main .en-txt:after {
	content:none !important;
}
p.rd-lead-txt {
    font-size: 1.4rem;
}
.rd-btn-wrap.flexwrap {
    justify-content: center;
    width: 100%;
	margin-bottom: 10px;
}
.rd-btn-wrap a {
    text-decoration: none;
    padding: 25px 10px;
    width: 600px;
    display: inline-block;
    border: 1px solid #00c400;
    border-radius: 200px;
    background: white;
	position:relative;
}
.rd-btn-wrap a:after {
    content: "";
    color: #00c400;
    position: absolute;
    right: 20px;
    font-weight: bold;
    font-size: 20px;
    line-height: 1;
    width: 15px;
    height: 13px;
    background: url(img/rd-arrow.png);
    top: 50%;
    transform: translate(0, -50%);
}
.rd-btn-wrap a:hover {
	color:gray;
}
.rd-btn-wrap a:hover:after {
    opacity: 0.6;
    transition: all 0.3s;
}
a.rd-tr:before {
    content: "";
    background: url(img/rd-tr.png);
    width: 72px;
    height: 72px;
    position: absolute;
    left: -24px;
    top: -40px;
    display: block;
}
a.rd-wr {
    margin: 0 46px;
}
a.rd-wr:before {
    content: "";
    background: url(img/rd-wr.png);
    width: 72px;
    height: 72px;
    position: absolute;
    left: -24px;
    top: -40px;
    display: block;
}
a.rd-ma:before {
    content: "";
    background: url(img/rd-ma.png);
    width: 72px;
    height: 72px;
    position: absolute;
    left: -24px;
    top: -40px;
    display: block;
}

section.top-lead-wrap {
    padding-bottom: 100px;
}
.top-about-ob-bg {
    width: 100vw;
    margin-left: calc(-50vw + 50%);
    padding-top: 70px;
	    position: relative;
}
.top-about-ob-bg:before {
    content: "";
    background: url(img/bg-g-left.png);
    width: 749px;
    height: 554px;
    background-repeat: no-repeat;
    background-size: 100%;
    display: block;
    position: absolute;
    left: -20%;
    top: -5%;
	z-index: -1;
}
.top-about-ob-bg:after {
    content: "";
    background: url(img/bg-g-right.png);
    width: 633px;
    height: 564px;
    background-repeat: no-repeat;
    background-size: 100%;
    display: block;
    position: absolute;
    right: -30%;
    top: 14%;
	z-index: -1;
}

.top-about-ob-wrap {
    width: 1000px;
    margin: 0 auto;
}

.top-about-us-inner.flexwrap {
    align-items: center;
}
.top-about-us-txt p {
    line-height: 1.9;
    font-size: 0.95em;
}
p.lead-txt {
    font-size: 1.2em !important;
    font-weight: bold;
	line-height: 1.4;
}
p.lead-sub-txt {
    margin-bottom: 0 !important;
	font-size: 1em;
}
.top-about-us-txt {
    width: 48%;
}
.top-about-us-img {
    width: 47%;
}
.top-about-us-img img {
    width: 100%;
    height: auto;
}
.g-btn-wrap {
    display: flex;
    justify-content: center;
}
a.g-btn {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    text-decoration: none;
    margin: 0 20px;
}
a.g-btn:hover {
	opacity:0.6;
	    transition: all 0.3s;
}
#content #main a.g-btn:hover img {
	/*2重opacityをさける*/
    opacity: 1;
}

a.g-btn img {
    margin-left: 16px;
}

.top-ob-inner.flexwrap {
    padding-top: 60px;
	    align-items: center;
}
.top-ob-img {
    width: 48%;
}
.top-ob-img img {
    width: 100%;
    height: auto;
}
.top-ob-txt {
    width: 47%;
}
.top-ob-txt ul li a {
    display: block;
    padding: 20px;
    border-bottom: 1px solid gainsboro;
    text-decoration: none;
	position:relative;
}
.top-ob-txt ul li a:hover {
	color:gray;
}
.top-ob-txt ul li a:hover:after {
    opacity: 0.6;
    transition: all 0.3s;
}
.top-ob-txt ul li a:after {
    content: "";
    color: #00c400;
    position: absolute;
    right: 20px;
    font-weight: bold;
    font-size: 20px;
    line-height: 1;
    width: 15px;
    height: 13px;
    background: url(img/rd-arrow.png);
    top: 50%;
    transform: translate(0, -50%);
}

section.top-cha-wrap {
    padding: 60px 0;
}
.top-cha-inner.flexwrap {
    width: 1000px;
    margin: 0 auto;
}

.top-cha-txt .g-btn-wrap {
    justify-content: right;
}
.top-cha-txt .g-btn-wrap a {
    margin: 0;
}

.top-topics-bg {
    width: 100vw;
    margin-left: calc(-50vw + 50%);
    padding-top: 60px;
	    position: relative;
}
.top-topics-bg:before {
    content: "";
    background: url(img/bg-g-left-b.png);
    width: 443px;
    height: 598px;
    background-repeat: no-repeat;
    background-size: 100%;
    display: block;
    position: absolute;
    left: -14%;
    bottom: -40%;
}
.top-topics-inner {
    width: 1000px;
    margin: 0 auto;
}

#submain.sub-company,#submain.sub-vision,#submain.sub-company-kari {
    background: url(img/main-about-us.jpg);
    background-size: cover;
    background-position: center bottom;
}
#submain.sub-challenge,#submain.sub-challenge-kari {
    /* ackground: url(img/main-challenge.jpg); */
    background: url(img/main-nc-01.jpg);
    background-size: cover;
    background-position: center bottom;
}
#submain.sub-business,#submain.sub-lineup,#submain.sub-area,#submain.sub-quality-and-safety {
    background: url(img/main-our-business.jpg);
    background-size: cover;
    background-position: center bottom;
}
#submain.sub-contact,#submain.sub-transportation-request,#submain.sub-worker-request,#submain.sub-storage-request {
    background: url(img/main-contact-us.jpg);
    background-size: cover;
    background-position: center bottom;
}
#submain.sub-topics {
    background: url(img/main-topics.jpg);
    background-size: cover;
    background-position: center bottom;
}
#submain.sub-recruit, #submain.sub-job, #submain.sub-jobdetail {
    background: url(img/main-job.jpg);
    background-size: cover;
    background-position: center bottom;
}
#submain.sub-entry {
    background: url(img/main-entry.jpg);
    background-size: cover;
    background-position: center bottom;
}

dl.com-dl {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}
dl.com-dl dt {
    width: 20%;
    border-bottom: 1px solid #00c400;
    padding: 20px;
    text-align: right;
    line-height: 2rem;
}
dl.com-dl dd {
    width: 77%;
    border-bottom: 1px solid #d9d9d9;
    padding: 20px;
    text-align: left;
    line-height: 2rem;
}
dl.com-dl dd ul {
	margin-bottom:0;
}
dl.com-dl .dl-no-b {
    border: none;
}

dl.com-in-dl {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-start;
}
dl.com-in-dl dt, dl.com-in-dl dd {
    padding: 0;
    border: none;
}
dl.com-in-dl dt {
    text-align: left;
    width: 200px;
}
dl.com-in-dl dd {
    margin-bottom: 1rem;
    line-height: 1.4;
}

.map-3wrap {
    margin-top: 10px;
}
.map-box {
    text-align: center;
    width: 30%;
    height: auto;
}
.map-box iframe {
    border-radius: 10px;
}

.guidelines-box {
    padding: 40px 90px 20px;
    border: 1px solid #d9d9d9;
}
.guidelines-box h3 {
    text-align: left !important;
    padding: 0 0 30px !important;
    margin: 0 !important;
    color: #393939 !important;
}
ul.g-ul li {
    display: inline-block;
    margin-right: 1.2rem;
}

.circle-wrap {
    display: flex;
    flex-wrap: wrap;
	    margin-bottom: 3.5rem;
}
.circle-box {
    width: 92px;
    height: 92px;
    border: 2px solid;
    border-radius: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 1.1rem;
    font-weight: bold;
    margin-right: 30px;
	color: #444444;
}
.circle-box:last-child {
	margin-right:0;
}
.c-rito {
    border-color: #007bc7;
    background: #bfdef1;
}
.c-rizo {
    border-color: #20acec;
    background: #bfe7f9;
}
.c-chuon {
    border-color: #13a152;
    background: #bfe5d0;
}
.c-joon {
    border-color: #f6d60e;
    background: #fdf4bf;
}

.green-cir {
   font-weight: 500;

   &::before{
    content: '';
    background-color: #00c400;
    display: inline-block;
    width:0.7rem;
    height: 0.7rem;
    border-radius: 1rem;
    margin-right: 1rem;
   }
}

figcaption:has(.green-cir){
    padding: 5px 0;
}

.manu-wrap {
    display: flex;
    justify-content: space-between;
}
.manu-box {
    width: 30%;
    height: auto;
}

.mana-wrap {
    display: flex;
    justify-content: space-between;
}
.mana-box {
    text-align: center;
}
.mana-box img {
    margin-bottom: 1rem;
}

p.p-flex {
    display: flex;
    justify-content: flex-start;
}

table.table-haken {
    margin: 0;
}
table.table-haken th {
    background: #d9f6d9;
    text-align: center;
    padding: 10px;
    font-weight: normal;
	border: 4px solid white;
}
table.table-haken td {
    text-align: center;
    padding: 20px 10px;
    background: #f5f5f5;
    border: 4px solid white;
    line-height: 1.2;
}
.br-lt {
    border-top-left-radius: 15px;
}
.br-rt {
    border-top-right-radius: 15px;
}
.br-lb {
    border-bottom-left-radius: 15px;
}
.br-rb {
    border-bottom-right-radius: 15px;
}

.gw-btn-wrap {
    display: flex;
    justify-content: center;
	    flex-wrap: wrap;
}
.gw-btn {
    background: white;
    border: 1px solid #00c400;
    color: #444444;
    padding: 12px 10px;
    border-radius: 100px;
    font-size: 0.9rem;
    width: 180px;
    text-align: center;
	margin: 0 10px;
}

/*タブコントロール*/
.panel,.panel2 {
    display: none;
    text-align: center;
    max-width: 900px;
    margin: 0 auto;
}
.panel.active,.panel2.active2 {
  display: block;
}
.tab-box,.tab-box2 {
	    cursor: pointer;
}
.tab-box.active,.tab-box2.active2 {
    background-color: #00c400;
    color: #fff;
}
/*タブここまで*/


.lineup-box-wrap {
    margin-top: 50px;
    display: flex;
    justify-content: space-between;
	flex-wrap: wrap;
}
.lineup-box {
    width: 400px;
    border: 1px solid #e5e5e5;
    border-radius: 10px;
	overflow: hidden;
    margin-bottom: 50px;
}
.lu-sub-box-wrap {
    text-align: left;
    padding: 14px 30px 20px;
}
p.lu-title {
    color: #00c400 !important;
    font-weight: bold;
}
.lu-sub-box-wrap dl {
    display: flex;
    flex-wrap: wrap;
    color: #4f4f4f;
    justify-content: space-between;
}
.lu-sub-box-wrap dl dt {
    width: 30%;
	    line-height: 1.4;
	    font-weight: bold;
}
.lu-sub-box-wrap dl dd {
    width: 64%;
    line-height: 1.4;
    margin-bottom: 1rem;
}

.q-s-inner {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}
.q-s-img {
    order: 2;
}
.q-s-txt {
    order: 1;
}

.logi-wrap {
    text-align: center;
    margin-bottom: 20px;
}
.logi-wrap img {
    width: 1000px;
    height: auto;
    margin: 20px 0 30px;
}

/*ページネーション調整*/
.wp-pagenavi {
    text-align: center;
    display: flex;
    justify-content: center;
	    margin-top: 40px;
}
.wp-pagenavi span.pages {
    display: none;
}
.wp-pagenavi a.page, .wp-pagenavi .current, .wp-pagenavi span {
    width: 54px;
    height: 54px;
    display: flex;
    justify-content: center;
    align-items: center;
    border: 2px solid #77e077;
    font-size: 0.8rem;
    font-weight: bold;
    margin: 5px;
}
.wp-pagenavi .current {
	    border: 2px solid #77e077 !important;
background:#00c400;
	color:white;
}
.wp-pagenavi a.nextpostslink {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 100px;
    padding-right: 30px;
    border-top-right-radius: 100px;
    border-bottom-right-radius: 100px;
		    border: 2px solid #77e077;
	font-weight:bold;
	    position: relative;
    font-size: 0.9rem;
	    margin: 5px;
}
.wp-pagenavi a.previouspostslink {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 100px;
    padding-left: 30px;
    border-top-left-radius: 100px;
    border-bottom-left-radius: 100px;
    border: 2px solid #77e077;
    font-weight: bold;
    position: relative;
    font-size: 0.9rem;
	    margin: 5px;
}
.wp-pagenavi a:hover {
    border-color: #77e077 !important;
    opacity: 0.6;
}
.wp-pagenavi a.nextpostslink:before {
    content: '';
    position: absolute;
    display: block;
    width: 9px;
    height: 9px;
    border-top: 2px solid #00c400;
    border-right: 2px solid #00c400;
    right: 20px;
    top: 50%;
    transform: translate(0, -50%) rotate(45deg);
}
.wp-pagenavi a.previouspostslink:before {
    content: '';
    position: absolute;
    display: block;
    width: 9px;
    height: 9px;
    border-top: 2px solid #00c400;
    border-right: 2px solid #00c400;
    left: 20px;
    top: 50%;
    transform: translate(0, -50%) rotate(-135deg);
}

#content #side ul li.cat-item a:after {
    content: '';
    position: absolute;
    display: block;
    width: 8px;
    height: 8px;
    border-top: 2px solid #00c400;
    border-right: 2px solid #00c400;
    right: 10px;
    top: 50%;
    transform: translate(0, -50%) rotate(45deg);
}
#content #main.main-2 h2 {
    clear: both;
    color: #444444;
    font-size: 1.2rem;
    margin: 10px 0px 24px;
    font-weight: bold;
    letter-spacing: 2px;
    line-height: normal;
    padding: 0 0 10px 0;
    text-align: left;
    position: relative;
    border-bottom: 2px solid #d9d9d9;
}
#content #main.main-2 h2:after {
    content: "";
    border-bottom: 2px solid #00c400;
    width: 100px;
    height: 0px;
    display: block;
    padding-bottom: 10px;
    position: absolute;
    bottom: -2px;
    left: 0;
    transform: none;
    margin: 0;
}
.single #main.main-2 img { /*投稿ページの画像を全て角丸へ*/
    border-top-right-radius: 60px;
    border-bottom-left-radius: 60px;
}

.g-btn-wrap.g-btn-con-wrap {
    justify-content: flex-start;
	margin-bottom: 20px;
}
.g-btn-wrap.g-btn-con-wrap a:first-child {
    margin-left: 0;
}

.c-form-wrap {
    padding: 50px 50px;
    box-shadow: 1px 0px 12px #d9d9d9;
    border-radius: 10px;
    margin-top: 30px;
}
table.table-form th, table.table-form td {
    vertical-align: top;
    padding: 0;
}
table.table-form th {
    /* width: 22%; */
    width: 200px;
}
table.table-form th p {
    margin-bottom: 0 !important;
    margin-top: 10px;
    position: relative;
}

table.table-form th p span {
    line-height: 1;
    float: right;
    margin-top: 6px;
    margin-right: 18px;
    margin-left: 0;
}
table.table-form td p {
    margin-bottom: 30px !important;
}
input.wpcf7-form-control {
    width: 100%;
    border-radius: 4px;
    border: 2px solid #e8e8e8;
    background: #f9f9f9;
}
textarea.wpcf7-form-control {
    width: 100%;
    border-radius: 4px;
    border: 2px solid #e8e8e8;
    background: #f9f9f9;
}

span.wpcf7-form-control.wpcf7-radio,span.wpcf7-form-control.wpcf7-checkbox {
    margin-top: 10px;
    display: inline-block;
}
input[type="radio"],input[type="checkbox"] {
    position: absolute;
    white-space: nowrap;
    width: 1px;
    height: 1px;
    overflow: hidden;
    border: 0;
    padding: 0;
    clip: rect(0 0 0 0);
    clip-path: inset(50%);
    margin: -1px;
}
.wpcf7-form-control .wpcf7-list-item .wpcf7-list-item-label {
    position: relative;
    cursor: pointer;
    padding-left: 30px;
}
.wpcf7-form-control .wpcf7-list-item .wpcf7-list-item-label::before,
.wpcf7-form-control .wpcf7-list-item .wpcf7-list-item-label::after {
  content: "";
  display: block;
  border-radius: 50%;
  position: absolute;
  transform: translateY(-50%);
  top: 50%;
}
.wpcf7-form-control .wpcf7-list-item .wpcf7-list-item-label::before {
    background-color: #fff;
    border: 2px solid #ddd;
    border-radius: 50%;
    width: 20px;
    height: 20px;
    left: 5px;
}
.wpcf7-form-control .wpcf7-list-item .wpcf7-list-item-label::after {
    background-color: #00c400;
    border-radius: 50%;
    opacity: 0;
    width: 10px;
    height: 10px;
    left: 10px;
}
input[type="radio"]:checked + .wpcf7-list-item-label::after,
input[type="checkbox"]:checked + .wpcf7-list-item-label::after {
  opacity: 1;
}

select.wpcf7-form-control {
    border-radius: 4px;
    border: 2px solid #e8e8e8;
    background: #f9f9f9;
    display: inline-block;
    padding: 10px;
    margin-right: 6px;
margin-top: 6px;
}

input.wpcf7-form-control.wpcf7-date {
    width: 150px;
}

p.input-harf {
    width: 42%;
}
p.input-1-3 {
    width: 80px;
}

p.saiyou-p {
	position:relative;
}
p.saiyou-p span:after {
    content: "名";
    position: absolute;
    right: -22px;
    top: -6px;
}
.mitei-p label {
    margin-left: 10px;
    display: inline-block;
}

.ill-wrap {
    background: #f5f5f5;
    border-radius: 5px;
    display: flex;
    gap: 1rem;
    padding: 3rem;
    justify-content: center;
    margin-bottom: 80px;
}

span.sp-space-h {
    margin-left: 1em;
}
/*スクロール動き*/
.scroll_up {
    transition: 0.8s ease-in-out;
    transform: translateY(30px);
    opacity: 0;
}

.scroll_up.on {
    transform: translateY(0);
    opacity: 1.0;
}

.s-delay1 {
	 transition-delay: 300ms;
}
.s-delay2 {
	 transition-delay: 500ms;
}
.s-delay3 {
	 transition-delay: 600ms;
}

#content #main.main-2 .flexwrap:before {
    content: "";
    display: block;
    width: 30%;
    order: 1;
}
#content #main.main-2 .flexwrap:after {
    content: "";
    display: block;
    width: 30%;
}

.bg-g-y-wrap2 .wrap-inner {
    width: 1000px;
    margin: 0 auto 0;
    padding-bottom: 20px;
    padding-top: 20px;
}
.bg-g-y-wrap2 .wrap-inner p {
    text-align: left;
}
img.pers-img {
    max-width: 860px;
    border-radius: 6px;
    margin-top: 40px;
}
.challenge-b-img-wrap img {
    max-width: 900px;
    margin: 70px auto;
    display: block;
}
.challenge-wrap .yt-wrap {
    max-width: 860px;
    border-radius: 6px;
    margin: 0px auto 30px;
    padding-top: 0px;
    height: 524px;
    position: relative;
}
.challenge-wrap .movie-inner {
    padding-top: 40px;
}
.n-c-box-wrap {
    display: flex;
    justify-content: space-between;
}
.n-c-box {
    width: 48%;
}
.n-c-box dl.com-dl dt {
    padding: 0px 0px;
    /* text-align: center; */
    display: flex;
    justify-content: center;
    align-items: center;
}

ul.num-ul li {
    position: relative;
    padding-left: 2rem;
}
ul.num-ul li:before {
    content: "①";
    position: absolute;
    left: 0;
}
ul.num-ul > li:nth-child(2):before {
    content: "②";
}
ul.sub-ul > li {
    padding-left: 0;
    margin-left: 1.3rem;
    text-indent: -1.3rem;

}
ul.sub-ul > li::before {
    content: "■";
    position: relative;
    font-weight: bold;
    color: #00c400;
    margin-right: 6px;
}

ul.sub-ul ul li{
    list-style-type: disc;
    padding-left: 1.5rem;
    margin-left: 0.75rem;
}

.handled-items-wrap p.hosoku {
    line-height: 1.4;
    font-size: 0.8rem;
}
.h-i-inner {
    display: inline-block;
    padding: 0 20px;
}

p.btn-w {
    display: block;
    text-align: center!important;
}
p.btn-w a {
    text-decoration: none;
    padding: 16px 10px;
    min-width: 360px;
    display: inline-block;
    border: 1px solid #00c400;
    border-radius: 200px;
    background: white;
    position: relative;
    text-align: center;
    color: #00c400;
}
p.btn-w a:hover {
    color: gray;
}
p.btn-w a:after {
    content: "";
    color: #00c200;
    position: absolute;
    right: 20px;
    font-weight: bold;
    font-size: 20px;
    line-height: 1;
    width: 15px;
    height: 13px;
    background: url(img/rd-arrow.png);
    top: 50%;
    transform: translate(0, -50%);
}

.top-catch-wrap {
    padding: 100px 20px 0;
    text-align: center;
}

.movie-inner{
  display: block;
  width: 100%;
  z-index: 1;
  position: absolute;
  top: 0;
  left: 0;
}
.movie-inner img.thumb {
transition: all 0.3s;
margin: 0;
    padding: 0;
}
.movie-inner .hover-img:hover {
   opacity: 0.8;
}
.movie-inner .no-hover-img:hover {
    opacity: 1;
}
.thumb {
    width: 100%;
    max-width: 100%;
    height: auto;
    cursor: pointer;
}
img.thumb-yt {
    position: absolute;
    width: 80px !important;
    height: auto;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
	cursor: pointer;
	z-index:1000;
}

.challenge-wrap .movie-player {
    padding-top: 40px;
}

/******************************
★ Media Queries タブレット・スマフォ表示の設定(1000px以下で読み込むcss)
******************************************************************************************************************************/

@media screen and (max-width: 1000px) {
/* 構造 */

body {
    min-width: 320px;
    overflow-x: hidden;
}
.wrapper {
    z-index: 10;
    width: 100%;
}
.wrapper_head {
    margin: 0px auto;
    width: 100%;
    z-index: 1000;
    position: relative;
}
#header .header_logo img {
    margin: 0;
    width: 300px;
    height: auto;
}
header .res-wrap {
    display: none;
}
.h-sub {
    font-size: 0.8em;
}

#content #side {
	display:block;
    width: 90%;
    margin: 50px auto 0;
    float: none;
    max-width: 700px;
}
#content #side h3 {
    width: 100%;
}

#pc-nav {
    display:none;
}

#sp-nav {
    display:block;
}

#content #main {
    margin:0 auto;
        width: 94%;
    float:none;
}

#submain img {
    top: -250px;
}

#content img {
    max-width: 100%;
    height: auto;
}
#content {
padding-top: 0;
    width: auto;
}
#pan {
    width: auto;
    margin-left: 10px;
}
#content .sec {
    width: 90%;
    margin: 0 auto;
    text-align: center;
}

/* ヘッダー */

#header {
    width: 100%;
	padding: 20px 20px 0px;
}
#header .header_logo {
    display: block;
    position: relative;
    margin-bottom: 0;
}

#pc_button {
    display: none;
}

a#sidr-menu-button {
}

/*サイドバー*/

#mobile_side {
    display: block;
    width: 100%;
    margin: 0 auto;
}
.side_area img {
    display: block;
    margin: 0 auto;
}
#mobile_side .side_area h3 {
    width: 100%;
}
/* テーブル */

.tablestyle {
    border-collapse: collapse;
    width: 100% !important;
    border-top: none;
}

.tablestyle td {
    display: block;
    width: 100%;
    border-top: 0;
    border-bottom: none;
    padding-top: 20px;
    text-align: center;
}
.tablestyle ul {
    text-align: center;
}

.tablestyle .tdstyle {
    background-color: #ffffff;
    padding: 8px 10px;
    width: 100%;
    text-align: center;
    font-weight: normal;
    padding-bottom: 10px;
    border-bottom: 1px solid #d0d0d0;
}
.tdstyle2 {
    border-bottom: none;
}
/* 固定ページ */

.alignright, .alignleft, .alignnone {
    float: none;
    display: block;
}
.alignright.pc_only, .alignleft.pc_only, .alignnone.pc_only { /* caption分岐の際、余白防止 */
    display: none;
}
/* コンタクトフォーム */

textarea.wpcf7-form-control.wpcf7-textarea {
    width: 100%;
}
.wpcf7-text {
    width: 90%;
}
.k-year .wpcf7-form-control {/*年号のテキスト*/
    width: 5rem;
}
.wpcf7 td {/* フォームの行を縦に並べる */
    display: block;
    width: 100%;
    font-weight: bold;
}
.wpcf7 .tdstyle {/* フォームの項目を左寄せ */
    text-align: left;
}

.footer_top {
    width: 100%;
    margin: 0px auto 0px;
    justify-content: center;
}

.footer_left {
    width: 100%;
	    text-align: center;
}
.footer_right {
    width: 100%;
    margin-top: 40px;
    border-top: 1px solid #9fd79d;
}
#footer-nav {
    justify-content: space-evenly;
    text-align: center;
    height: 100px;
    margin: 20px 0 30px;
}
#footer-nav li {
    width: auto;
    margin: 4px 0px;
}
#footer-nav a {
    font-size: 0.6rem;
    padding: 10px 18px;
}
#footer-nav li#f-nav-sub-wrap {
    width: 20%;
}
ul#footer-nav-sub li {
    display:none;
}
.footer_info dt {
    width: 50%;
    line-height: 2;
    text-align: right;
    padding-right: 5px;
}
.footer_info dd {
    width: 50%;
    text-align: left;
    padding-left: 5px;
}

.footer_btm_wrap {
    width: 100%;
    float: none;
}
.footer_com {
}
#logo_footer {
    float: none;
    display: inline-block;
}

#footer .footer_btm {
    width: 100%;
    text-align: center;
}

#footermenu {
    text-align: center;
}
#copyright {
    text-align: center;
}


/*コンテンツ装飾
ここから*/

.rd-wrap {
    height: auto;
	    background-position: right 30% bottom;
}
.rd-txt-inner {
    width: 100%;
    margin: 30px 0px;
    text-align: center;
}
.rd-en-txt {
    text-align: center;
}
.rd-btn-wrap a {
    width: 33%;
    margin: 3% 2%;
}
.rd-btn-wrap a:before {
    width: 60px;
    height: 60px;
    background-size: 60px;
    top: -30px;
}
.top-about-ob-wrap,
.top-cha-inner.flexwrap,
.top-topics-inner {
    width: 94%;
    margin: 0 auto;
}
.top-about-ob-bg:before {
    left: -60%;
}
.top-about-ob-bg:after {
    right: -70%;
}
.top-topics-bg:before {
    left: -40%;
}

.guidelines-box {
    padding: 40px 40px 20px;
}

.lineup-box {
    width: 48%;
	    max-width: 400px;
}
.lineup-box img {
    margin: 0;
}
.lu-sub-box-wrap dl dt {
    width: 32%;
    font-size: 0.8rem;
}
p.lu-title {
    line-height: 1.4;
}
.gw-btn {
    margin: 0 1%;
    width: 22%;
}

.q-s-img {
    order: 1;
    margin-bottom: 20px;
}
.q-s-img.mt-60 {
    margin-top: 0 !important;
}

.logi-wrap img {
    width: 90%;
    margin: 0px auto;
    padding: 30px 0;
}

#content #main.main-2 {
    width: 94%;
    float: none;
}

input.wpcf7-form-control.wpcf7-date {
    width: 42%;
}

.bg-g-y-wrap2 .wrap-inner {
    width: 94%;
}


.top-yt-ytjs {
    height: 26vw;
}
.movie-inner img.thumb {
    width: 100%;
}
.challenge-wrap .yt-wrap {
    height: 57vw;
}

}/*end*/

/******************************
★ Media Queries スマフォ表示の設定(599px以下で読み込むcss)
******************************************************************************************************************************/
@media screen and (max-width: 599px) {

.sp_only {/* スマホにだけ表示させたいものに使用する */
    display: block;
}
.pc_only {/* pc・タブレットにだけ表示させたいものに使用する */
    display: none;
}

#header .header_logo img {
    width: 200px;
}

#navbutton {
    top: 10px;
    right: 10px;
}

#ibox-in {
    width: 100%;
}
#ibox-in p {
    font-size: 2em;
    line-height: 1.4;
    background: rgb(255 255 255 / 70%);
    padding: 20px 6px;
    display: block;
}
#ibox-in .ibox-big {
    background: none;
    padding: 0;
}

#content #main {
    width: 90%;
    float:none;
}
#content #main h1.singletitle, #content #main h1 {
    font-size: 2em;
}

#submain .h1wrap {
    margin: 0;
    text-align: center;
}

.footer_tel {
    padding: 10px 0;
}
.f_telbtn {
    display: block;
}
#logo_footer {
    float: none;
    text-align: center;
    display: inline-block;
}

#footer .footer_btm {
    margin-bottom: 0px;
}
.footer_btm_wrap {
    margin-top: 0px;
    float: none;
    width: auto;
}
.telnum {
    display: none;
}

.footer_right {
    display: none;
}
.footer_left {
    margin-bottom: 50px;
}
.footer_info dt {
    width: 100%;
    line-height: 1.4;
    text-align: center;
    padding: 0;
    font-weight: bold;
}
.footer_info dd {
    width: 100%;
    line-height: 1.4;
    margin-bottom: 10px;
    text-align: center;
    padding: 0;
}

#footer-nav li {
    width: 40%;
}

#logo_footer img {
    margin-top: 40px;
}

.two_box,.three_box,.four_box {
  width: 100%;
  float: none;
  margin: 0 auto;
}

a.link, a.link2 {
    width: 90%;
}

.responsedevise {
    width: 100%;
}

/*コンテンツ装飾
ここから*/

.rd-btn-wrap.flexwrap {
    margin-bottom: 30px;
}
.rd-btn-wrap a {
    width: 300px;
    margin: 10px 0;
}
.rd-btn-wrap a:before {
    width: 50px;
    height: 50px;
    background-size: 50px;
    top: -20px;
}
p.rd-lead-txt {
    line-height: 1.6;
}

.top-about-ob-wrap, .top-cha-inner.flexwrap, .top-topics-inner {
    width: 90%;
    margin: 0 auto;
}
.top-about-us-txt,.top-about-us-img {
    width: 100%;
}
.top-about-us-img {
    margin-top: 20px;
}

.top-ob-txt,.top-ob-img {
    width: 100%;
}
.top-ob-img {
    margin-bottom: 20px;
}
.top-ob-inner.flexwrap {
    padding-top: 40px;
}

.top-cha-inner.flexwrap {
    position: relative;
}
.top-cha-txt {
    width: 100%;
    z-index: 1;
}
.top-cha-img {
    width: 47%;
}
.top-cha-img {
    position: absolute;
    right: 0;
    top: -20px;
    z-index: 0;
    opacity: 0.6;
}

.topics_box {
    width: 47.5%;
}

dl.com-dl dt {
    width: auto;
    text-align: left;
    padding: 10px;
}
dl.com-dl dd {
    width: 100%;
    margin-bottom: 20px;
    padding: 20px 10px;
}
dl.com-dl dt.dl-no-b {
    border-bottom: 1px solid #00c400;
}
dl.com-in-dl dt {
    padding: 0;
    font-weight: bold;
}
dl.com-in-dl dd {
    padding: 10px 0;
}
dl.com-dl dd.dl-no-b {
    margin-bottom: 0;
}
.map-3wrap {
    margin: 0;
}
.map-box {
    width: 100%;
}
.map-box p {
    line-height: 1;
}

.guidelines-box {
    padding: 30px 30px 10px;
}

#submain.sub-business, #submain.sub-lineup, #submain.sub-area, #submain.sub-quality-and-safety {
    background-position: right -98% bottom;
}

.circle-wrap {
    justify-content: center;
}
.circle-box {
    margin-right: 2vw;
    width: 20vw;
    height: 20vw;
}

.gw-btn-wrap.tab-area.gw-btn-4 {
    flex-wrap: wrap;
}
.gw-btn-4 .gw-btn {
    width: 44%;
    margin: 0 5px 10px;
}
.gw-btn {
    width: 106px;
    line-height: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 5px;
}
.tab-box2.gw-btn {
    margin-bottom: 10px;
    width: 44%;
}
.lineup-box {
    width: 100%;
    margin: 0 auto 20px;
}
.lu-sub-box-wrap dl dt {
    font-size: 1rem;
}

span.sp-space-h {
    margin-left: 0;
    display: block;
}

.q-s-img {
    margin: 0 auto 20px;
}

.post_box {
    width: 47.5%;
}

.g-btn-wrap.g-btn-con-wrap a {
    margin: 0 10px;
    justify-content: center;
}
.g-btn-wrap.g-btn-con-wrap a:first-child {
    margin-left: 10px;
}

.c-form-wrap {
    padding: 30px 30px 50px;
}
table.table-form th {
    width: 100%;
    display: block;
}
table.table-form td {
    width: 100%;
    display: block;
}
table.table-form th p span {
    float: none;
    margin-left: 10px;
}

.bg-g-y-wrap2 .wrap-inner {
    width: 90%;
}

.h-i-inner {
    padding: 0 10px;
}

.grecaptcha-badge {
bottom: 10px;
right: 10px;
transform: scale(0.85);
opacity: 0.6;
}

.top-yt-ytjs, .top-catch-txt {
    width: 100%;
}
.top-yt-ytjs {
    height: 51vw;
    margin-bottom: 16px;
}
.challenge-wrap .yt-wrap {
    height: 61vw;
}
#content #main .top-catch-wrap .en-txt {
    font-size: 2rem;
}

}/*end*/
