@charset "utf-8";
main{
    overflow: hidden;
}
/*--------------------------------------------
ページ上部
---------------------------------------------*/
#sub_head{
    background-repeat: no-repeat;
    background-size: cover;
    background-image: url(../images/sub/sub_head_bg.png);
    width: 100%;
    height: 400px;
}
#sub_head h2{
    font-size: clamp(1.5rem, 5vw, 5rem) !important;
}
@media screen and (max-width:575px) {
	#sub_head{
		height: 200px;
	}
    #sub_head h2 {
        font-size: 2rem !important;
    }
}
/*パンクズ*/
.breadcrumb-area span{
	color: #0053a5;
	font-weight: 500;
}
.breadcrumb-area span.current-item{
    color: #2a2b31;
}

/*--------------------------------------------
ページ共通
---------------------------------------------*/
/*見出し*/
.sub_title h3{
    font-size: clamp(1.5rem, 3vw, 3rem) !important;
}
.sub_title h3{
	font-size: 2rem !important;
	position:relative;
	padding-left: 1.5rem;
	font-weight: normal !important;
	font-family: "Shippori Mincho", serif !important;
}
.sub_title h3::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	width: 5px;
	height: 100%;
	background: linear-gradient(
		to bottom,
		#009ce6,
		#0053a5
	);
}
@media screen and (max-width:575px){
	.sub_title h3{
		padding-left: 1rem;
		font-size: 1.5rem !important;
	}
}

/*ページネーション*/
.pagination {
    display: flex;
    justify-content: center;
    align-items: center;
}
.nav-links{
    display: flex;
    align-items: center;
}
.pagination .page-numbers {
    display: inline-flex;
    width: 40px;
    height: 40px;
    justify-content: center;
    align-items: center;
    border: 1px solid #0053a5;
    color: #0053a5 !important;
    text-decoration: none;
    transition: background 0.2s, color 0.2s;
    margin-right: .5rem;
    border-radius: 5px;

}
.pagination .page-numbers.current {
    background: #0053A5;
    background: linear-gradient(180deg,rgba(0, 83, 165, 1) 0%, rgba(0, 156, 230, 1) 100%);
    color: #fff !important;
    border: 1px solid #0053a5;
    font-weight: bold;
}
.pagination .page-numbers:hover:not(.current) {
    background: #0053A5;
    background: linear-gradient(180deg,rgba(0, 83, 165, 1) 0%, rgba(0, 156, 230, 1) 100%);
    color: #fff !important;
    border: 1px solid #0053a5;
}
/*--------------------------------------------
お知らせ
---------------------------------------------*/
#info .info_content_wrapper{
	width:800px;
	margin: 0 auto;
}
#info .info_img{
    height: 200px !important;
    object-fit: cover;
    width: 100%;
}
#info .info_tax {
    background-color: #0053a5;
    border-radius: 2rem;
    color: #fff;
    text-align: center;
}
/*見出し*/
#info .info_content_wrapper h2{
	font-size: 2.5rem !important;
	font-weight: normal !important;
	font-family: "Shippori Mincho", serif !important;
}
#info .info_content_wrapper h3{
	font-size: 2rem !important;
	position:relative;
	padding-left: 1.3rem;
	font-weight: normal !important;
	font-family: "Shippori Mincho", serif !important;
}
#info .info_content_wrapper h3::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	width: 5px;
	height: 100%;
	background: linear-gradient(
		to bottom,
		#009ce6,
		#0053a5
	);
}
@media screen and (max-width:991px){
    #info .info_tax{
        border-radius: 1rem;
        min-width:unset;
    }
	#info .info_content_wrapper{
		width:100%;
	}
}
@media screen and (max-width:575px){
	#info .info_content_wrapper h3{
		padding-left: 1rem;
		font-size: 1.5rem !important;
	}
}

/*--------------------------------------------
会社概要
---------------------------------------------*/
#business .business_product_list ul{
    display: flex;
    flex-wrap: wrap;
}
#business .business_product_list li{
    list-style: disc;
    margin-left: 1.5rem;
    margin-right: 2rem;
	min-width: 185px;
}
/*ボタン*/
#business .business_button a{
    background-color: #fff;
    border: 1px solid #0053a5;
    border-radius: .3rem;
    box-shadow: 7px 4px 8px -5px #ccc;
    padding: clamp(1.2rem, 1.2vw, 1.9rem) clamp(1.5rem, 1.5vw, 2.3rem);
    min-width: 300px;
	transition: all 0.3s ease;
}
#business .business_button a:hover{
	box-shadow: none;
  transform: translateY(4px);
}
#business .business_button a::after {
    font-family: "Font Awesome 5 Free";
    content: '\f105';
    color: #0053a5;
    font-weight: 600;
    font-size: 1rem;
    position: absolute;
    top: 50%;
    right: 1.2rem;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    transition: right .8s ease;
}
#business .business_list_btn .business_button a{
	min-width: unset;
}
@media screen and (max-width:991px){
	#business .business_list_btn li{
        width: 50%;
    }
    #business .business_list_btn li:nth-child(even){
        padding-left: .5rem;
    }
    #business .business_list_btn li:nth-child(odd){
        padding-right: .5rem;
    }
    #business .business_button a{
        padding: 1rem;
    }
    #business .business_button a::after{
        font-size: .875rem;
        right:.5rem;
    }
}
@media screen and (max-width:575px){
	#business .business_button a{
		min-width: 300px;
	}
}

/*--------------------------------------------
製品情報
---------------------------------------------*/
/*一覧*/
#product .product_tax_img{
    width: 100%;
    aspect-ratio: 1 / 1;
    object-fit: cover;
    display: block;
    position: relative;
    z-index: -1;
    border-radius: .3rem 0 0 .3rem;
}
#product .product_tax_list a{
    border: 1px solid #0053a5;
    border-radius: .3rem;
    box-shadow: 7px 4px 8px -5px #ccc;
}
#product .product_tax_list a::after {
    font-family: "Font Awesome 5 Free";
    content: '\f105';
    color: #0053a5;
    font-weight: 600;
    font-size: 1rem;
    position: absolute;
    top: 50%;
    right: 2rem;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    transition: right .8s ease;
}
#product .product_tax_list li{
    width: 35%;
}
#product .product_tax_list li:last-child{
    width: 65%;
}
@media screen and (max-width:575px){
	#product .product_tax_list li {
	  width: 25%;
	}
}
/*詳細*/
#product .product_post_img{
    width: 170px;
    aspect-ratio: 1 / 1;
    object-fit: cover;
    display: block;
    position: relative;
    z-index: -1;
}
#product .product_post_list_img{
    aspect-ratio: 1 / 1;
    object-fit: cover;
    display: block;
    position: relative;
    z-index: -1;
    width: 100%;
}
#product .product_post_list_inner li .product_post_list01{
    width: 18%;
}
#product .product_post_list_inner li .product_post_list02{
    width: 82%;
}
#product .product_item_new p{
    background-color: #8fc43d;
}
#product .product_item_renewal p{
    background-color: #00ada9;
}
#product .product_item_second p{
    background-color: #00a0e9;
}
@media screen and (max-width:575px){
	#product .product_post_list_inner li .product_post_list01{
		width: 25%;
	}
	#product .product_post_list_inner li .product_post_list02{
		width: 75%;
	}
	#product .display-24 {
		font-size: 1.2rem;
	}
}
/*検索*/
#product .search-form-container form {
    position: relative;
    display: inline-block;
    min-width: 600px;
}
#product .search-form-container input[type="search"] {
    flex: 1;
    padding : .8rem 2rem .8rem 1rem;
    border: 1px solid #0053a5;
    border-radius: 25px;
}
#product .search-form-container input[type="search"]:focus {
    border-color: #007cba;
}
#product .search-form-container input[type="submit"] {
    border: unset;
    background: unset;
    color: #0053a5;
    cursor: pointer;
    white-space: nowrap;
    position: absolute;
    right: 0;
    top: 0;
    padding: 0;
}
#product .search-form-container button.search-btn {
    border: unset;
    background: unset;
    color: #0053a5;
    cursor: pointer;
    position: absolute;
    right: 1rem;
    top: 50%;
    transform: translateY(-50%);
    padding: 0;
}
#product .search-results-info {
    background: #e3f2fd;
}
#product .no-results {
    background: #f8d7da;
    color: #721c24;
}
@media screen and (max-width:575px){
	#product .search-form-container form{
		min-width: unset
	}
	#product .search-form-container input[type="search"]{
		font-size: .875rem;
	}
}
/*--------------------------------------------
form
---------------------------------------------*/
.form__row {
    display: flex;
    flex-wrap: wrap; 
    align-items: center;
    justify-content: space-between;
    border-bottom: 1px solid #afc0d2;
	padding: 1.5rem 0;
}
.form__row .form__label,
.form__row .form__body {
    margin: 0;
    box-sizing: border-box;
}
.form__row .form__label {
    width: 32%;
}
.form__row .form__body{
    width: 66%;
}
.form__row .form__label label {
    position: relative;
    margin: 0;
}
.form__row .form__label p{
    position: relative;
}
.form__row .form__label.is-required p::after {
	content: "必須";
	background-color: #0053a5;
	color: #fff;
	padding: .1rem .3rem;
	font-size: .75rem;
	right: 0;
	position: absolute;
}
.form__row .form__label.nofree p::after{
    content: unset;
}
.form__row .form__label.is-required label {
    position: relative;
    margin: 0;
    text-align: justify;
}
.submit-btn{
    display: flex;
    justify-content: center;
}
.submit-btn input[type="submit"] {
	background: #0053a5;
	font-weight: 500;
	color: #fff;
	font-size: clamp(1rem, 1.5vw, 1.5rem);
	border: unset;
	padding:1.2rem 2.5rem;
	min-width: 380px;
}
/*項目*/
input[type="text"],
input[type="password"],
input[type="datetime"],
input[type="date"],
input[type="month"],
input[type="time"],
input[type="week"],
input[type="number"],
input[type="email"],
input[type="url"],
input[type="search"],
input[type="tel"],
input[type="color"],
select,
textarea,
.field {
    display: block;
    width: 100%;
    padding: 0.55em 1em;
    border: 1px solid #C1C1C1;
    background-color: #fff;
    color: rgba(0, 0, 0, 0.7);
    transition: ease;
    border-radius: .1rem;
}
.wpcf7-list-item{
    display: flex;
	align-items: center;
}
.wpcf7-list-item.first{
	margin: 0;
}
.wpcf7-checkbox{
	display: flex;
}
.wpcf7-radio{
	margin-right:5px;
	display: flex;
	flex-wrap: wrap;
}
.wpcf7 form .wpcf7-response-output{
    padding: 1em 1em;
    text-align: center;
}
.wpcf7 label{
	margin-bottom:0 !important;
}

@media screen and (max-width:767px) {
	.submit-btn input[type="submit"] {
		min-width: unset;
		padding: 1rem 2rem;
	}
    .form__row .form__label,
    .form__row .form__body{
        width: 100%;
    }
    .form__row .form__label {
        padding-bottom: .3rem;
    }
    .form__row {
        padding-bottom: 1.5rem;
    }
    .form__row .form__label p::after{
        top:-3px;
    }
	.wpcf7-radio{
		display: block;
	}
	.wpcf7-radio .wpcf7-list-item{
		margin: 0;
	}
}
.wpcf7-exclusive-checkbox input[type="checkbox"] {
	appearance: none;
	width: 18px;
	height: 18px;
	border: 2px solid #ddd;
	border-radius: 50%;
	position: relative;
	margin-right: 5px;
	margin-top: 2px;
}
.wpcf7-exclusive-checkbox input[type="checkbox"]:checked {
	background: #007cba;
	border-color: #007cba;
}
.wpcf7-exclusive-checkbox input[type="checkbox"]:checked::after {
	content: '';
	position: absolute;
	top: 50%;
	left: 50%;
	width: 8px;
	height: 8px;
	background: white;
	border-radius: 50%;
	transform: translate(-50%, -50%);
}

/*--------------------------------------------
店舗情報
---------------------------------------------*/
/*カテゴリ*/
#shop .shop_tax li {
    color: #fff;
    padding: .3rem .8rem;
    border-radius: 1.5rem;
}
#shop .shop_tax li.mobileshop{
    background-color: #FB7D35;
}
#shop .shop_tax li.cafeshop {
    background-color: #107C49;
}
#shop .shop_tax li.salons {
    background-color: #73C2EA;
}
/*iframe*/
#shop .areadata-iframe iframe {
    width: 100% !important;
    height: 327px !important;
    display: block;
    border: 0;
}
/*table*/
.table02 th,.table02 td{
    background-color: unset;
}
.table02 th{
    border-bottom: 2px solid;
}
.table02 td{
    border-top: unset !important;
    border-bottom: 1px solid #C1C1C1;
}
@media screen and (max-width:480px) {
    .table02 td{
        width: 45%;
        }
}
#shop .business_list li {
    border: 1px solid #0053a5;
    border-radius: 3rem;
    padding: .3rem .8rem;
}
