@charset "UTF-8";

body {display: block;}
body::after {content: ''; position: fixed; top: 0; left: 0; width: 100%; height: 100%; background: #fff; z-index: 9999; pointer-events: none; opacity: 0; transition: opacity .5s ease;}
body.fadeout::after {opacity: 1;}

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

/*コンティナ*/
.container {position: relative;}

/*汎用flex*/
.flex {display: flex; align-items: flex-start; justify-content: space-between;}

.yellow {background: url(../img/common/yellow-back.png);}

.mincho {font-family: YakuHanMP,"Hiragino Mincho ProN","Hiragino Mincho Pro","Noto Serif JP","Yu Mincho",YuMincho,serif;}

/*汎用ヘッダー*/
.h-g {text-align: center; background: url(../img/common/general_icon.svg) center top/auto auto no-repeat;}
.h-g span {display: block; text-align: center;}
.h-g span.big {line-height: 1.25;}
.h-g span.sml {font-size: .8rem; color: #808080; line-height: 1.25;}

/*more*/
.more {text-align: center; margin: 25px auto 0;}
.more a {position: relative; display: inline-block; background: #fff; padding: 5px 15px; border: 1px solid #c9c9c9;}
.more a i {margin-left: 5px; transition: .3s ease;}
.more a:hover {color: #fff; background: #333; opacity: 1;}
.more a:hover i {color: #fff;}

/*ギザギザ*/
.gagg {position: relative; z-index: 2;}
.gagg::before,
.gagg::after {content: ""; position: absolute; left: 0; width: 100%;}

/*戻るボタン*/
.back_button {position: relative; display: block; text-align: center; border: 1px solid #c9c9c9;}
.back_button i {margin-left: 8px; transition: .3s ease;}
.back_button:hover {color: #fff; background: #333; opacity: 1;}
.back_button:hover i {color: #fff;}

/*ページャー*/
#pagination {display: flex; justify-content: center; align-items: center;}
#pagination span,
#pagination a {display: inline-flex; justify-content: center; align-items: center; color: #fff; background: #684d3c; line-height: 1; border: 1px solid #684d3c; border-radius: 50%; opacity: 1;}
#pagination a {color: #684d3c; background: #fff;}
#pagination a:hover {color: #fff; background: #684d3c;}

/*--------------------------------------------------------------------------
ローディング
--------------------------------------------------------------------------*/
#loader {position: fixed; width: 100vw; height: 100vh; left: 0; top: 0; background: #fff; opacity: 1; visibility: visible; overflow: hidden; transition: .75s ease; z-index: 9999;}
#loader.fade {opacity: 0; visibility: hidden;}
#loader img {visibility: hidden; position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); opacity: 0; transition: .75s ease;}
#loader img.vis {visibility: visible; opacity: 1;}

/*--------------------------------------------------------------------------
ヘッダー
--------------------------------------------------------------------------*/
header {position: fixed; top: 0; width: 100%; background: #fff; z-index: 1000;}

/*--------------------------------------------------------------------------
フッター
--------------------------------------------------------------------------*/
footer {margin-top: auto; padding: 10px 0;}
footer .logo {display: block; width: 140px;}
footer .logo img {width: 100%;}
footer .copyright {display: block; letter-spacing: .25em; text-indent: .25em; text-align: center; background: #fff;}
footer.border {border-top: 1px solid #c9c9c9;}

#scroll {display: flex; justify-content: center; align-items: center; position: fixed; background: rgba(0,0,0, .3); opacity: 0; visibility: hidden; z-index: 1000;}
#scroll i {font-size: 1.5rem; color: #fff;}
#scroll.active {opacity: 1; visibility: visible;}

/*------------------------------------
お気軽にお問合せください
------------------------------------*/
.contact-cta {overflow: hidden;}
.contact-cta h2 {justify-content: center;}
.contact-cta h2 img {width: auto;}
.contact-cta .contact-list {position: relative; margin: 0 auto; z-index: 2;}
.contact-cta .contact-list li {background: #fff; border: solid #754c24;}
.contact-cta .contact-list li img {width: auto;}
.contact-cta .touroku {position: relative; display: block; color: #fff; font-weight: 700; text-align: center; background: #f00; box-shadow: 5px 5px 0 0 #d0c764;}
.contact-cta .touroku:hover {box-shadow: 0 0 #d0c764; transform: translate3d(5px, 5px, 0); transform-origin: top; opacity: 1;}
.contact-cta .random-img {position: absolute; z-index: -1;}

/*--------------------------------------------------------------------------
----------------------------------------------------------------------------
----------------------------------------------------------------------------
フロントページ
----------------------------------------------------------------------------
----------------------------------------------------------------------------
--------------------------------------------------------------------------*/
/*------------------------------------
TOP
------------------------------------*/
#home .top #top-slider {position: relative; z-index: 1;}
#home .top #top-slider li {position: relative; width: 100%;}
#home .top #top-slider li a {position: relative; width: 100%; height: 100%;}
#home .top #top-slider li img.sub_img {display: inline-block; position: absolute; top: 50%; z-index: 2;}
#home .top #top-slider li img.main_img {width: 100%; height: 100%; object-fit: cover; object-position: 50%; font-family: 'object-fit: cover; object-position: 50%;';}

/*------------------------------------
NEWS
------------------------------------*/
#home .news {position: relative; background: #ffeb46 url(../img/home/home_news_back.png) 50% 50%/100% auto; z-index: 1;}
#home .news .news-list .entry a {display: block;}
#home .news .news-list .entry a .img {width: 100%; background: #fff; border: 1px solid #969696;}
#home .news .news-list .entry a .img img {width: 100%; height: 100%; object-fit: cover; object-position: 50%; font-family: 'object-fit: cover; object-position: 50%;';}
#home .news .news-list .entry a .txt {justify-content: flex-start; align-items: center;}
#home .news .news-list .entry a .cat {color: #fff; line-height: 1; margin: 0 0 0 12px; padding: 4px 6px; background: #ff901e;}
#home .news .news-list .entry a h3 {width: 100%; margin-top: 5px;}

/*------------------------------------
BISINESS
------------------------------------*/
#home .business .catch {font-weight: 900; text-align: center; line-height: 1.325; margin-top: -.33125em;}
#home .business .catch em {color: #ff1d25; font-size: inherit; font-weight: inherit;}
#home .business .desc {text-align: center;}

#home .business .biz-list {flex-wrap: wrap;}
#home .business .biz-list > li h3 {display: flex; align-items: center;}
#home .business .biz-list > li h3 img {margin-right: 15px;}
#home .business .biz-list > li h3 span {line-height: 1.25; font-weight: 700;}
#home .business .biz-list > li:nth-child(1) h3 span {color: #a91417;}
#home .business .biz-list > li:nth-child(2) h3 span {color: #283250;}
#home .business .biz-list > li:nth-child(3) h3 span {color: #766151;}
#home .business .biz-list > li:nth-child(4) h3 span {color: #ef5440;}
#home .business .biz-list > li img.img {width: 100%; height: 196px; object-fit: cover; object-position: 50%; font-family: 'object-fit: cover; object-position: 50%;';}
#home .business .biz-list > li a.link {display: block; font-weight: 700; text-align: center; padding: 2px 0; border-style: solid; border-width: 2px; border-radius: 1.5em;}
#home .business .biz-list > li:nth-child(1) a.link {color: #a91417; border-color: #a91417;}
#home .business .biz-list > li:nth-child(2) a.link {color: #283250; border-color: #283250;}
#home .business .biz-list > li:nth-child(3) a.link {color: #766151; border-color: #766151;}
#home .business .biz-list > li:nth-child(4) a.link {color: #ef5440; border-color: #ef5440;}
#home .business .biz-list > li a.link:hover {color: #fff; opacity: 1;}
#home .business .biz-list > li:nth-child(1) a.link:hover {background: #a91417;}
#home .business .biz-list > li:nth-child(2) a.link:hover {background: #283250;}
#home .business .biz-list > li:nth-child(3) a.link:hover {background: #766151;}
#home .business .biz-list > li:nth-child(4) a.link:hover {background: #ef5440;}

/*--------------------------------------------------------------------------
----------------------------------------------------------------------------
----------------------------------------------------------------------------
テンプレ＆固定ページ
----------------------------------------------------------------------------
----------------------------------------------------------------------------
--------------------------------------------------------------------------*/

/*--------------------------------------------------------------------------
会社理念 (philosophy.php)
--------------------------------------------------------------------------*/

/*会社理念*/
#philosophy .philo h3 {font-weight: 900; text-align: center;}
#philosophy .philo h3 em {color: #ff1d25; font-size: inherit; font-weight: inherit;}
#philosophy .philo p {line-height: 2; text-align: center;}
#philosophy .philo .random-img {position: absolute;}

/*ビジョン*/
#philosophy .vision .vision-list li {font-weight: 700;}

/*会社概要*/
#philosophy .outline table a:hover u {text-decoration: none;}
#philosophy .outline table a.link:hover {text-decoration: underline;}
#philosophy .outline table a.link {position: relative; color: #ff901e; font-weight: 700;}
#philosophy .outline table a.link:after {font-family: "Font Awesome 5 Free"; font-weight: 900; content: "\f14d"; position: relative; top: 0; right: -5px;} 

/*--------------------------------------------------------------------------
事業概要
--------------------------------------------------------------------------*/
#about .mv img {width: 100%; margin: 0 auto;}

#about .g-h {color: #4d4d4d; font-weight: 700; text-align: center;}
#about .desc {text-align: center; line-height: 2;}

#about .cut-img {width: 100%;}
#about .cut-img img {width: 100%; height: 100%; object-fit: cover; object-position: 50%; font-family: 'object-fit: cover; object-position: 50%;';}

#about .dev-case {background: #f9faf0;}
#about .dev-case .case-list {flex-wrap: wrap;}
#about .dev-case .case-list li img {width: 100%; object-fit: cover; object-position: 50%; font-family: 'object-fit: cover; object-position: 50%;';}
#about .dev-case .case-list li dl {display: flex; align-items: baseline; margin-bottom: 2px;}
#about .dev-case .case-list li dl dd {font-weight: 700;}

/*------------------------------------
観光促進 (tourism.php)
------------------------------------*/
#about.tourism .about .member h3 {color: #4d4d4d; font-weight: 700; text-align: center;}
#about.tourism .about .member .member-list {position: relative;}
#about.tourism .about .member .member-list > li {position: relative; border: 4px solid #e0e0e0; border-radius: 10px; box-sizing: border-box;}
#about.tourism .about .member .member-list > li h4 {text-align: center; font-weight: 700;}
#about.tourism .about .member .member-list > li ol li {text-indent: -1.25em; padding-left: 1.25em;}
#about.tourism .about .development {position: relative; color: #fff; font-weight: 700; text-align: center; background: #b5141a;}
#about.tourism .about .development:after {content: ""; position: absolute; display: block; background: url(../img/tourism/tourism_about_arrow_02.svg) 0 0/100% auto;}
#about.tourism .about .example {text-align: center; background: #efefef;}
#about.tourism .about .example img {max-width: 100%;}
#about.tourism .about .example .info {display: inline-block;}
#about.tourism .about .example .info h3 {font-weight: 700; text-align: center; margin-bottom: 6px;}
#about.tourism .about .example .info .open {color: #fff; text-align: center; background: #000; padding: 4px 0;}
#about.tourism .about .outlook {text-align: center;}
#about.tourism .about .outlook .outlook-list {position: relative; display: inline-block;}
#about.tourism .about .outlook .outlook-list li {font-weight: 700; text-align: left;}
#about.tourism .about .outlook .outlook-list li .marker {display: inline; color: inherit; font-size: inherit; font-weight: inherit; position: relative;}
#about.tourism .about .outlook .outlook-list li .marker:after {content: ""; position: absolute; left: 0; bottom: -.25em; width: 100%; background: #b5141a;}
#about.tourism .about .outlook .outlook-list .charge {position: absolute; color: #fff; font-weight: 700; text-align: left; background: #b5141a; box-sizing: border-box;}
#about.tourism .about .outlook .outlook-list .charge:before {content: ""; position: absolute; border-style: solid; border-color: transparent transparent #b5141a transparent;}

#about.tourism .reqreate {background: #ffeb0a;}
#about.tourism .reqreate .g-h {margin-top: 0;}
#about.tourism .reqreate .link {display: block; color: #4d4d4d; font-weight: 700; text-align: center; border: 3px solid #4d4d4d; margin: 0 auto;}
#about.tourism .reqreate .link:hover {color: #fff; background: #4d4d4d; opacity: 1;}

#about.tourism .scheme .flow img {max-width: 100%; margin: 0 auto;}

/*------------------------------------
感動本舗 (trading.php)
------------------------------------*/
#about.trading .mall h2 {text-align: center;}
#about.trading .mall p {line-height: 2;}

#about.trading .chart {background: #f9faf0;}
#about.trading .chart img {max-width: 100%; margin: 0 auto;}

#about.trading .mall-list li img {max-width: 100%;}

/*------------------------------------
ペット事業 (pet.php)
------------------------------------*/
#about.pet .about .logo {height: auto; margin: 0 auto;}

#about.pet .shop h2 {text-align: center;}
#about.pet .shop p {line-height: 2;}
#about.pet .shop .shop-list li img {width: auto; margin: auto;}
#about.pet .shop .shop-list li .link {display: block; font-weight: 700; line-height: 1.25; text-align: center; border: 1px solid #333;}
#about.pet .shop .shop-list li .link:hover {color: #fff; background: #333; opacity: 1;}

/*------------------------------------
システム (system.php)
------------------------------------*/
#about.system .service h2 {color: #4d4d4d; font-weight: 700; text-align: center; letter-spacing: .25em; text-indent: .25em;}

#about.system .service .service-list li h3 {justify-content: flex-start; align-items: center;}
#about.system .service .service-list li h3 .num {display: flex; justify-content: center; align-items: center; color: #fff; font-weight: 700; line-height: 1; background: #041f46; border-radius: 50%;}
#about.system .service .service-list li h3 .title {color: #041f46; font-weight: 700; line-height: 1.25;}
#about.system .service .service-list li p {line-height: 1.75; text-align: justify;}

/*--------------------------------------------------------------------------
採用情報 (recruit.php)
--------------------------------------------------------------------------*/
#recruit #single table {width: 100%;}

/*--------------------------------------------------------------------------
会員登録 (touroku.php)
--------------------------------------------------------------------------*/
#touroku {background: url(../img/touroku/touroku_back.png);}

/*--------------------------------------------------------------------------
お問い合わせ (contact.php)
--------------------------------------------------------------------------*/
#contact .image {width: 100%; background-image: url(../img/contact/contact.jpg); border-bottom: solid #00356e;}

/*--------------------------------------------------------------------------
投稿ページ・固定ページ (single.php,page.php)
--------------------------------------------------------------------------*/

/*--------------------------------------------------------------------------
フォーム汎用
--------------------------------------------------------------------------*/
#form h3 {border-bottom: 2px solid #00356e; margin-bottom: 15px; padding-bottom: 5px;}
#form p {margin: 10px 0;}
#form a.link {position: relative; color: #00356e; font-weight: 700; padding-left: 5px;}
#form a.link:before {font-family: "Font Awesome 5 Free"; font-weight: 900; content: "\f14d"; position: relative; top:0; left: -2px;} 
#form span.ast {display: inline-block; color: #ee5a24; font-size: .85em; line-height: 1; margin-left: 14px; padding: 2px 10px; border: 1px solid #ee5a24; box-sizing: border-box;}

#form form > dl {width: 100%;}
#form form > dl > dt {color: #00356e; font-weight: 700;}
#form form > dl > dd {min-width: 200px; height: 100%; vertical-align: top;}
#form form > dl > dd.file-up {justify-content: flex-start; align-items: center;}
#form form > dl > dd.radio {padding-left: 1em;}
#form form > dl small {display: block; font-size: .85rem; text-align: right; margin-top: 10px;}
#form dl.notice {margin: 15px 0 0;}
#form dl.notice dt,
#form dl.notice dd {font-size: .925em;}

#form input[type="text"],
#form input[type="email"],
#form input[type="tel"],
#form textarea {display: block; background: #fff!important; width: 100%; border: 1px solid #c9c9c9; border-radius: 5px; resize: vertical; box-sizing: border-box;}
::placeholder {color: #c9c9c9; font-weight: 700;}

#form label.file {display: inline-block; color: #00356e; white-space: nowrap; margin: 5px 0; background: #fff; border: 1px solid #00356e; border-radius: 5px; transition: .3s ease;}
#form label.file:hover {color: #fff; background: #00356e; cursor: pointer;}
#form label.file input[type="file"] {display: none;}
#form input#file-name {display: inline-block!important; width: auto; margin-left: 12px; padding: 0; border: none; cursor: default; background: transparent!important;}

#form .cheak {text-align: center;}
#form .cheak label {position: relative; display: inline-block; cursor: pointer;}
#form .cheak .wpcf7-radio {display: flex; margin: 0 -35px 0 35px;}
#form .cheak .wpcf7-radio .wpcf7-list-item-label {display: block; margin-right: 35px; cursor: pointer;}
#form .cheak input[type="radio"],
#form .cheak input[type="checkbox"] {display: none;}
#form .cheak span.wpcf7-list-item-label {display: block; position: relative; font-weight: 700;}
#form .cheak span.wpcf7-list-item-label:before {content: ''; position: absolute; left: -34px; top: -4px; width: 21px; height: 21px; border: 2px solid #ccc; background: #fff;}
#form .cheak span.wpcf7-list-item-label:after {width: 12px; height: 6px; border: 3px solid #00356e; content: ''; position: absolute; transform: rotate(-45deg); left: -29px; top: 4px; border-top: none; border-right: none; transition: .3s ease; opacity: 0;}
#form .cheak span.wpcf7-list-item-label:before {top: 0;}
#form .cheak span.wpcf7-list-item-label:after {top: 6px;}

#form input[type="checkbox"]:checked + span.wpcf7-list-item-label:after,
#form input[type="radio"]:checked + span.wpcf7-list-item-label:after {opacity: 1;}
#form input[type="submit"] {position:relative; top: 0; display: block; color: #fff; font-weight: 700; letter-spacing: 0; width: 280px; margin: 0 auto; padding: 10px 0; background: #00356e; border: 2px solid #00356e; border-radius: 70px; opacity: 1; transition: .3s ease;}
#form input[type="submit"]:hover {color: #00356e; background: #fff;}

#form .wpcf7-radio .wpcf7-list-item {display: block; font-size: 1.125em;}
#form .wpcf7-radio .wpcf7-list-item input {margin-bottom: 1px;}
#form .wpcf7-radio .wpcf7-list-item .wpcf7-list-item-label {font-size: 1em;}

.wpcf7-not-valid-tip {color: #ee5a24;}
.wpcf7-response-output {border: 1px solid #00356e!important; color: #00356e!important; text-align: center!important; background: transparent!important; margin-top: 40px!important;}

/*--------------------------------------------------------------------------
404.php
--------------------------------------------------------------------------*/
#notfound {position: relative; width: 100%; background: url(../img/common/yellow-back.png) 0/100% 100% no-repeat;}
#notfound .container {position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); display: flex; flex-direction: column; justify-content: center; align-items: center;}
#notfound h1 {display: flex; justify-content: center; align-items: center; font-weight: 700; line-height: 1; z-index: 2;}
#notfound h1 span {font-size: .25em; font-weight: 700; line-height: 1.25; color: inherit; z-index: 2;}
#notfound p {z-index: 2;}
#notfound a {display: block; color: #fff; text-align: center; background: #333; padding: 8px 0; border: 2px solid #333; opacity: 1; z-index: 2;}
#notfound a:hover {color: #333; background: #fff;}