/*
Theme Name:Neve child
Theme URI:
Description:Neveの自作子テーマです。金額表示と送料の削除
Template:neve
Author:
Author URI:
Version:1.0.0
*/
.product-price,
.product-subtotal,
.cart-subtotal,
body.woocommerce-cart .product-name img,
.order-total,
.cart_totals > h2,
.product-total,
.woocommerce-Price-amount,
.woocommerce-order-overview__total,
.order_details .row,
.woocommerce-column--billing-address,
.product_meta > .tagged_as,
.builder-item,
/*blockテーマのカート*/
.wc-block-cart-item__total,
.restore-item,
.wc-block-cart-item__prices,
.wp-block-woocommerce-cart-order-summary-subtotal-block,
.wc-block-cart__totals-title,
.wc-block-cart-items__header-total,
.wc-block-components-totals-item__label,
.wc-block-components-totals-item__value,
.wc-block-components-totals-shipping,
.wc-block-components-totals-footer-item,
.woocommerce-info,
.woocommerce-billing-fields >h3,
.product-quantity,
.product_meta .sku,
.sku_wrapper,
.product_meta .posted_in,
.dgwt-wcas-suggestion-cat .dgwt-wcas-st-breadcrumbs,
.woocommerce-cart .return-to-shop,
.component-wrap,
#order_review_heading,
#billing_country_field,
#shipping_country_field,
/*カートページの不要なボタン*/
#billing_yomigana_first_name_field .optional,
#billing_yomigana_last_name_field .optional,
#shipping_yomigana_last_name_field .optional,
#shipping_yomigana_first_name_field .optional,
#order_comments_field .optional,
.woocommerce-shipping-totals,
/* .woocommerce-message .restore-item, */
/* .woocommerce-message .button.wc-forward, */
.yith-wcwl-share,
.item-details-table,
.cart-discount > td,
.wishlist-title-container,
/*wp管理画面*/
.submitdelete,
button[name="update_cart"]  {
	display: none !important;
}
.woocommerce .woocommerce-error {
    display: flex;
    flex-direction: column;
}
.woocommerce-form-coupon {
    height: 0px;
    opacity: 0;
    position: absolute;
    z-index: -100;
}
@media (min-width: 768px) {
.woocommerce .col2-set .col-1, .woocommerce .col2-set .col-2, .woocommerce .u-columns .col-1, .woocommerce .u-columns .col-2, .woocommerce form .col-1, .woocommerce form .col-2, .woocommerce-page .col2-set .col-1, .woocommerce-page .col2-set .col-2 {
	width:100%;
	max-width:100%;
}
}
.cart-empty {
    display: block!important;
    background: #e8eaeb!important;
    border: 0;
    color: #000!important;
}
#wp-block-search__input-1,
.wp-block-search__button {
	height:40px;

}
#bulk-sync-cancel-button {
    visibility: hidden!important;
}

.wc-block-product-categories select {
    padding: 0 10px;
		height:40px;
}
.wc-block-product-categories__button {
    padding: 0 14px;
}
.cart_item img {
    width: 60px;
}
@media (min-width: 769px) {
    .product-thumbnail:not([class^=elementor]) img {
        min-width: 30px !important;
    }
}
@media screen and (max-width: 768px) {
    .woocommerce table.shop_table_responsive tbody th, .woocommerce-page table.shop_table_responsive tbody th {
        display: table-cell;
    }
}

.btn, .button.button-primary, .is-style-primary .wp-block-button__link, .wp-block-search .wp-block-search__button, button, input[type=button], input[type=reset], input[type=submit] {
	padding:0 12px;
}

.theme-twentytwenty .wc-block-grid.has-4-columns .wc-block-grid__product, .wc-block-grid.has-4-columns .wc-block-grid__product {
    margin-bottom: 60px;
}
.wc-block-components-formatted-money-amount {
    display: none;
}

.nv-post-cover,
.woocommerce-table tfoot,
/* .lft header_left,
.neve-site-logo, */
/* .site-logo, */
#wcfm_store_header{
	display:none;
}
.header-category ul {
    display: block;
}

.header-category ul h4 {
    font-weight: 300;
    font-size: 16px;
    margin-bottom: 10px;
}
.header-category ul img {
    display: none;
}
.wp-block-heading{
	margin-top:40px;
}
.Logo {
	    top: -340px;
}
@media screen and (max-width:940px){
	.Logo {
		    top: -240px;
	}
}
	@media screen and (max-width:781px){
	.Logo {
		      left: -100%;
	}
}
article {
    margin-bottom: 120px;
}
.wcfm_dashboard_stats > div:nth-child(1),
.wcfm_dashboard_stats > div:nth-child(2),
.wcfm_dashboard_wc_reports_pie,
.banner_text,
.wcfm_dashboard_wcfm_product_stats,
.woocommerce-shipping-totals {
	display:none;
}

.wcfm_dashboard_wc_reports_sales,
.woocommerce-shipping-methods{
position:absolute;
	top:0;
	z-index:-100
}
/*配送先情報*/
.woocommerce-checkout form.checkout {
    grid-template-columns: auto!important;
    display: block!important;
}

.table-container {
	height: 500px;
	overflow-y: auto;
}
.table-container td {
	border-bottom: 1px solid #8C8C8C;
	padding: 10px;
}
/*サブメニュー*/
.submenu {
	position: fixed;
    top: -24px;
    right: 80px;
    z-index: 999;
}
.submenu-icons {
	display: flex;
    margin-top: 40px;
}
.submenu-icons li{
    margin: 0 10px;
}
.submenu-icons > li > a,
.search {
	display: inline-block;
    position: relative;
    padding: 10px;
    background-color: #fff;
    border-radius: 50%;
    text-align: center;
    width: 40px;
    height: 40px;
}
.submenu-icons li a i {
	color: #000;
    line-height: 1px;
}
@media screen and (max-width:700px) {
    .submenu {
        transform: scale(.9);
    }
}
/*検索*/
#coupon-search-form {
    display: flex;
    position: fixed;
    width: 400px;
    top: 80px;
    right: 20px;
    z-index: 999;
}
#coupon-search-form input {
    width: 80%;
}
#search-results {
    background: #fff;
    padding: 20px;
    width: 400px;
    max-height: 100vh;
    position: fixed;
    overflow-y: scroll;
    text-align: left;
    top: 160px;
    right: 20px;
    cursor: default;
    z-index: 999;
}
#search-results li {
    border-bottom: 1px solid #ddd;
    display: flex;
}
#search-results li a {
    display: flex;
    width: 100%;
    height: 70px;
    margin: 4px 0;
    align-items: center;
}
#search-results li a img {
    max-width: 70px;
    margin-right: 10px;
    vertical-align: middle;
}
#search-results-background {
    position: absolute;
    left: 0;
    width: 100%;
    height: 100%;
    background: #3b3b3b38;
    z-index: 998;
}
#close-search-results {
    background: #f00;
    color: #fff;
    border: none;
    padding: 10px;
    cursor: pointer;
    position: absolute;
    top: 10px;
    right: 10px;
}
@media screen and (max-width:959px) {    
    #coupon-search-form,
    #search-results {
        left: 50%;
        transform: translate(-50%);
    }
}

@media screen and (max-width:559px) {    
    #coupon-search-form,
    #search-results {
        width: calc(100% - 20vw);
        max-height: 60vh;
    }
}
/*ハンバーガーメニュー*/
/* ヘッダーを常にハンバーガーメニュー化するためのスタイル */
/* ハンバーガーメニューのアイコン */
.hamburger-menu {
    position: fixed;
    top: 20px;
    right: 20px;
    z-index: 1000;
    cursor: pointer;
}

.hamburger-menu-icon {
    width: 30px;
    height: 1.6px;
    background: #333;
    margin: 6px 0;
    transition: background 0.3s;
}

/* オーバーレイ背景 */
.menu-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.3); /* #000の30%オーバーレイ */
    z-index: 999;
    display: none;
    opacity: 0;
    transition: opacity 0.3s ease-in-out;
}

/* スライドメニュー */
.menu-content {
    position: fixed;
    top: 0;
    right: -100%; /* 初期は画面外 */
    width: 30%; /* PCサイズ */
    height: 100%;
    background: #fff;
    box-shadow: -2px 0 5px rgba(0, 0, 0, 0.2);
    z-index: 1000;
    transition: right 0.3s ease-in-out;
    padding: 20px;
    overflow-y: auto;
}

/* スマホ用に全画面表示 */
@media (max-width: 768px) {
    .menu-content {
        width: 100%; /* スマホでは全画面表示 */
    }
}

/* メニューが表示状態 */
.menu-content.active {
    right: 0; /* 画面内にスライド */
}

.menu-overlay.active {
    display: block;
    opacity: 1;
}
/* 閉じるボタン */
.close-menu-button {
    position: absolute;
    top: 15px;
    right: 15px;
    font-size: 34px;
    color: #9a9a9a;
    cursor: pointer;
    z-index: 1001;
    font-weight: 100;
    transition: color 0.3s;
}

.close-menu-button:hover {
    color: #000;
}
.menu-content >ul {
    margin: 40px 0 ;
}
.menu-category-list {
    display: flex;
    flex-wrap: wrap;
}
.menu-category-list li {
    width: calc(100% / 2);
}
.menu-content a{
    font-weight: 300;
    color: #000;
}
.social {
    display: flex;
    align-items: center;
}
.social li {
    margin: 0 10px;
}
.social img {
    width: 24px;
}
/*ツールチップ*/
.tooltip {
	position: relative;
    display: inline-block;
    cursor: pointer;
    font-weight: bold; /* 太字にする */
	color: #74A0B8;
    border: 2px solid #74A0B8;
    border-radius: 50%;
    width: 22px;
    height: 22px;
    text-align: center;
    line-height: 20px;
}

.tooltip .tooltip-text {
    line-height: 1.4;
    visibility: hidden;
	width: 300px;
    background-color: #EFEFEF;
	text-align: left;
    color: #8B8B8B;
    border-radius: 6px;
    padding: 10px;
    font-size: 12px;
    position: absolute;
    z-index: 1;
    bottom: 125%; /* ツールチップの位置 */
    left: 50%;
    margin-left: -100px; /* 左にずらす */
    opacity: 0; /* 初期状態は非表示 */
    transition: opacity 0.3s; /* アニメーション */
    z-index: 100;
}

.tooltip:hover .tooltip-text, .tooltip:focus-within .tooltip-text {
    visibility: visible;
    opacity: 1; /* ホバーまたはフォーカス時に表示 */
}
.php-alert {
    position: absolute;
    left: 50%;
    top: 160px;
    transform: translate(-50%);
    text-align: center;
    color: red;
    text-align: left;
}

/* 注文詳細情報のスタイル */
.order-details {
    background-color: #f9f9f9;
    padding: 10px;
    display: none;
}
.order-container{
	height: 500px; 
}
.order-container .tooltip {
	border: none;
}
.order-container tbody td {
    font-size: 12px;
}
.approve-button {
    font-size: 12px;
}
.table-scroll {
	overflow-x: hidden; 
	margin-top: 20px;
	font-size: 12px;
	/* 横方向のスクロールバーを非表示にする */
}

.table-header th {
	position: sticky; /* ヘッダーを固定する */
	top: 0; /* 上端に固定 */
	background-color: #F2F5F6;
	padding: 10px;
	font-size: 12px;
	min-width: 120px;
    z-index: 50;
}

.modal-ui {
	z-index: 10 ;
	display: none;
	max-width: 500px;
    width: calc(100% - 40px);
    position: fixed;
    top: 100px;
    left: 50%;
    transform: translateX(-50%);
    background-color: #fff;
    padding: 20px;
    border-radius: 10px;
	transition: ease-in-out .3s;
}
#modal-overlay {
	z-index: 5 ;
	display: none ;
	position: fixed ;
	top: 0 ;
	left: 0 ;
	width: 100% ;
	height: 120% ;
	background-color: rgba(0, 0, 0, 0.5) ;	
	transition: ease-in-out .3s;
}
/* モーダルの基本スタイル */
.modal {
    display: none; /* デフォルトでは非表示 */
    position: fixed;
    z-index: 1000;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.5); /* 背景の半透明黒 */
}

/* モーダルコンテンツのスタイル */
.modal-content {
    background-color: #fff;
    margin: 15% auto;
    padding: 20px;
    border: 1px solid #888;
    width: 30%;
    border-radius: 10px;
    position: relative;
    min-width: 280px;
}

/* 閉じるボタンのスタイル */
.close {
    position: absolute;
    top: 10px;
    right: 15px;
    color: #aaa;
    font-size: 24px;
    font-weight: bold;
    cursor: pointer;
}

.close:hover,
.close:focus {
    color: #000;
    text-decoration: none;
    cursor: pointer;
}
/* OKボタン */
#ok {
    padding: 10px 20px;
    font-size: 16px;
    cursor: pointer;
    background-color: #749cd7;
    color: white;
    border: none;
    border-radius: 5px;
}

#ok:hover {
    background-color: #749cd7;
}
.duplicate-cell {
    color: red; /* 赤字に設定 */
    font-weight: bold; /* 必要であれば太字にも設定 */
}

.debug {
	position: relative;
}

.invoice_dl {
	position: relative;
}
.invoice_dl a {
	position: absolute;
	content: '';
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}

.form-container {    
	display: inline-block;
    position: relative;
    left: 50%;
    transform: translate(-50%);
	margin-top: 120px;
}
.order-details h6 {
	margin-bottom: 0;
    margin-top: 10px;
}
.order-details li,
.order-details p {
	font-size: 14px;
    margin-bottom: 0;
}
.order-details li a {
	font-size: 18px;
}
.order-details img {
    width: 60px;
    height: 60px;
	border: 1px solid #ddd;
}
.view-details-btn {
	font-size: 14px;
    padding: 4px 10px;
    background: none;
    color: #74A0B8;
}
.view-details-btn:hover {
	background: none;
	color: #292929;
}
/* .form-container form {
	width: calc(100% / 2 - 20px);
	margin: 40px 10px;
} */
.login-img {
    position: relative;
    left: 50%;
    top: 5%;
    transform: translate(-50%);
    padding: 20px;
    width: 40vh;
    max-width: 200px;
}
@media screen and (max-width:700px) {
    .login-img {
        width: 30vh;
    }
}
/*ローディング*/
#loading-image {
    position: fixed;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 9999;
}
#loading-image img {
	width: 60px;
}

/*step*/
.step-img {
    width: 600px;
    position: relative;
    left: 50%;
    transform: translate(-50%);
}
.label-ms {
    margin-left: 14px;
    font-size: 10px;
    color: red;
}
.step-img.step3 {
    left: 0;
    transform: translate(-0%);
}
img.step-img {
    margin-bottom: 60px;
}
/*カタログページ*/
.catalog-products {
    display: flex;
    flex-wrap: wrap;
    justify-content: start; /* Adjusts the spacing between columns */
    /* gap: 20px; Adds space between items */
}
#category-sidebar {
    width: 200px;
    float: left; /* サイドバーを左側に固定 */
}

.parent-category {
    width: calc(100% / 4 - 28px);
    margin: 10px 14px ;
    border: 1px solid #fff;
    padding: 10px 20px;
}

.parent-category-button {
    font-size: 16px;
    font-weight: bold;
    margin-bottom: 10px;
    display: block;
}
.parent-category h6 {
    margin-bottom: 0;
}
.parent-category p {
    color: #48565E;
}
.parent-category > img {
    height: 180px;
    width: 100%;
    object-fit: cover;
}
.catalog-link {
    font-size: 13px;
    font-weight: 500;
}
.child-categories {
    margin-left: 20px; /* 子カテゴリーを少し右にずらす */
}

.category-button {
    display: block;
    margin-bottom: 5px;
}

.product-item {
    float: left;
    width: 25%;
    margin-bottom: 20px;
}


.product-item {
    /* flex: 1 1 calc(100% / 4 - 20px); 5 columns - 20% width minus gap */
    box-sizing: border-box;
    margin-bottom: 20px; /* Add space at the bottom */
    padding: 10px; /* Optional: Add padding to each product */
}
/* 
.product-item img {
    max-width: 100%;
	height: 200px;
    object-fit: cover;
} */

@media screen and (max-width: 959px) {
    .product-item {
        flex: 1 1 calc(100% / 3 - 20px); /* 4 columns */
    }
}

@media screen and (max-width: 700px) {
    .product-item {
        flex: 1 1 calc(100% / 2 - 20px); /* 3 columns */
    }
}

@media screen and (max-width: 559px) {
    .product-item {
        flex: 1 1 calc(100% - 20px); /* 2 columns */
    }
}
.entry-form-content {
	display: flex;
}
.entry-form-content form {
	border: 1px solid #ddd;
    width: 500px;    
	padding: 20px;
}
.entry-form-content form label {
	width: 140px;
}


/*テンプレート１*/
.page-temp img {
	width: 100%;
	object-fit: cover;
	height: 600px;
}
.wc-multistore-bulk-sync-advanced-container.open {
	height: 120px!important;
    overflow-y: clip!important;
}

#loading-screen {
	background: #fff;
    position: absolute;
    top: 0;
    width: 100%;
    height: 100%;
    z-index: 99;
	opacity: .5;
}

.loadhing-contents {
	 margin-top: 500px;
}

.wc-multistore-product-sync-container {
	height: 0;
}

#bulk-sync-start-new-button {
	display: none;
}

.wp-block-post-featured-image img {
    height: 240px;
}
.comments-area,
.author-name {
	display: none;
}
/*メール*/
.m_8797803201813156208viwec-responsive-center,
.viwec-product-price,
.woocommerce-Price-amount,
.wc-block-components-quantity-selector { 
	display: none !important;
}
.wp-block-woocommerce-cart-totals-block {
	margin-top: 38px;
}

/*子カテゴリーのスタイル*/
.category-item {
    margin: 10px;
    display: inline-block;
    text-align: center;
}

.category-item img {
    width: 100px;
    height: auto;
}

.category-item h3 {
    margin-top: 5px;
    font-size: 16px;
}
.category-item:hover,
.product-item:hover {
    opacity: .6;
    transition: ease .2s;
}
.category-item,
.product-item {
    transition: ease .2s;
}

/*仮ログイン*/
.pa-loss {
	display: block;
	color: #3b91ee;
	margin-top: 20px;
}
.main-pre-regi-log {
    position: relative;
}
.form-pre-regi {
	width: 680px;
	text-align: center;
    background: #fff;
    border: 10px;
    padding: 20px;
	box-shadow: 5px 5px 17px 0 rgba(0, 0, 0, 0.1);
}
.form-wrap {
    display: flex;
    flex-direction: row-reverse;
}
.form-wrap > div{
    background: #fff;
    padding: 20px;
	box-shadow: 5px 5px 17px 0 rgba(0, 0, 0, 0.1);
    width: 460px;
    margin: 0 20px;
}
.button-dark {
	background: #48565E !important;
    color: #fff !important;
    width: 200px;
    padding: 10px 0 !important;
	position: relative;
	margin-top: 20px;
}
.button-light {
	background: #74A0B8 !important;
    color: #fff !important;
    width: 200px;
    padding: 10px 0 !important;
	position: relative;
	margin-top: 20px;
}
.btn-flex {
    display: flex;
}
.pre-reg {
	background: #D6E7F0 !important;
	border: 2px solid #74A0B8;
	color: #000 !important;
}
.form-flx {
	display: flex;
	position: relative;
    left: 20%;	
    text-align: left;
}
.form-flx label {
	font-size: 14px;
    /* font-weight: 800; */
    width: 160px;
}
.form-flx input {
	height: 40px;
}
.form-flx .form-colm {
    display: flex;
    flex-direction: column;
    margin-bottom: 10px;
}
.b-bottom {
	text-align: center;
    position: relative;
    margin-top: 40px;
    color: #8C8C8C;
	z-index: 5;
}
.b-bottom::before {
	position: absolute;
	content: '';
	top: 50%;
	left: 0;
	height: 1px;
	width: 100%;
	background: #8C8C8C;
	z-index: -2;
}
.b-bottom::after  {
	position: absolute;
    content: '';
    top: 50%;
    width: 80px;
    height: 20px;
    background: #fff;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: -1;
}
@media screen and (max-width:780px) {
	.maxW700 img {
		width: 100%;
		height: 200px;
		object-fit: cover !important;
	}
	.maxW700 figure {
		width: 100%;
	}	
}
#login-form {
	width: calc(100% - 20px);
}
.required-icon {
	position: relative;
    color: #fff;
    background: red;
    padding: 4px 6px;
    margin-left: 4px;
    border-radius: 3px;
    font-size: 12px;
    font-weight: 600;
}
/* .required::before {
	position: absolute;
    left: -10px;
    top: 0;
    content: "*";
    color: red;
} */
/* .site-main {
	margin: 60px 0;
} */
.search-houjin {
    text-align: left;
    font-size: 12px;
    position: absolute;
    top: 0;
    left: 120px;
}
.search-houjin a {
	color: #3b91ee;
}
/*本登録前のページ*/
body.page-id-68,
body.page-id-70 {
	background:#F2F5F6;
}
body {
    padding-bottom: 120px;
}
.content .login-img,
.form-img {
    position: absolute;
    left: 50%;
    top: 20px;
    transform: translate(-50%);
    padding: 20px;
    width: 24vh;
    max-width: 200px;
}
#password-reset-form {
	position: absolute;
    background: #fff;
    box-shadow: 1px 1px 20px 0 #ddd;
    top: 50%;
    padding: 20px;
    width: 600px;
    border-radius: 5px;
    left: 50%;
    transform: translate(-50%, -50%);
	z-index: 30;
}
#password-reset-form p {
	margin-bottom: 4px;
	font-size: 12px;
}
#password-overlay {
	position: fixed;
	top: -80px;
    left: -300%;
    width: 1000%;
    height: 1000%;
    background: rgb(182 182 182 / 50%);
    z-index: 10;
}
.error-ms {
    position: absolute;
    top: 60px;
    font-size: 16px;
    z-index: 9;
    padding-left: 40px;
    left: 50%;
    transform: translate(-50%);
}
.error-ms a {
	color: #3b91ee;
}
.error-ms::before {
	position: absolute;
	content: '';
	width: 22px;
	height: 28px;
	left: 10px;
	background-image: url(img/atten-d.png);
	background-position: center;
	background-size: contain;
	background-repeat: no-repeat;
}
.login-ms {
	position: relative;	
	color: #74A0B8;
    font-size: 16px;
    left: 310px;
    margin: 20px 0 0 32px;
}
.login-ms::before {
	position: absolute;
	content: '';
	width: 22px;
	height: 28px;
	left: -30px;
	background-image: url(img/check-b.png);
	background-position: center;
	background-size: contain;
	background-repeat: no-repeat;
}
.scroll-600 {
	position: relative;
	/* overflow-y: scroll;
    max-height: 600px;
    width: 1000px;
    border: 1px solid #74A0B8; */
}
#category-buttons {
	display: flex;
    flex-wrap: wrap;
    max-width: 840px;
	width: 84vw;
    position: relative;
    left: 50%;
    transform: translate(-50%);
}
.parent-category-button {
	padding: 10px;
	width: 100px;
	margin: 0 3px;
	background-color: #48565E;
    border-radius: 5px 5px 0 0;
}
#child-category-buttons{
	position: sticky;
    top: 0;	
    background: #F2F5F6;
}
#child-category-buttons button {
	background-color: #00000000;
	color: #333;
}
#child-category-buttons button:hover {
	background-color: #00000000;
	color: #74A0B8;
}
#child-category-buttons button.selected {
	background-color: #00000000;
	color: #74A0B8;
}
.catalog-prev-step2 {    
    width: 100vw;
    position: relative;
    right: 0;
}
.catalog-prev-step2 #category-buttons {
    max-width: none;
    width: 90vw;
    /* flex-wrap: nowrap; */
    left: 0;
    transform: translate(0);
    overflow-x: scroll;
    border: 1px solid #ddd;
    margin-bottom: 40px;
}
.catalog-prev-step2 .scroll-600 {
	height: 300px;
    /* width: 40vw; */
}

.catalog-prev-step2 .product-item {
	width: calc(100% / 3);
}
.catalog-prev-step2 .product-item img {
    /* height: 100px; */
    object-fit: cover;
}
/*本登録フォーム*/
.form-registration div {
    display: flex;
}
.form-registration p,
.form-registration label {    
    font-size: 12px;
}
.form-registration p {
    display: flex;
    flex-direction: column;
    margin-bottom: 14px;
    width: 100%;
}
.form-registration {
    max-width: 600px;    
    position: relative;
    left: 50%;
    transform: translate(-50%);
}
.form-registration input{  
    padding: 4px 10px !important;
}
.form-left {
    left: 0;
    transform: translate(0);
}
/* 選択されたボタンのスタイル */
.parent-category-button.selected {
    background-color: #74A0B8; /* 選択されたボタンの背景色 */
}
.parent-category-button:hover {
	background: #82888b !important;
}
/*お気に入りボタン yith*/
.yith-wcwl-icon {
	font-family: 'FontAwesome'!important;
	margin-right: 0!important;
}
/* .yith-wcwl-add-button a {
	position: absolute!important;
    top: 0!important;
    margin-left: 10px!important;
} */
/*本登録フォーム*/
.step {
	color: #74A0B8;
	font-weight: 100;
	margin: 40px 0 10px 0;
}
#step2-form {
	background: #F2F5F6;
    padding: 20px;
    max-width: 600px;
}
#sample-image {
	margin-top: 10px;
    position: relative;
    /* left: 620px;
    top: -240px; */
    /* height: 30vw;
    overflow-y: scroll;
    border: 1px solid; */
    width: 40vw;
}
.success-message {
    color: #74A0B8;
    font-weight: bold;
    margin-top: 10px;
}

.product-thumbnails {
    display: flex;
    gap: 8px;
    margin-bottom: 10px;
    flex-wrap: wrap;
}

.product-thumb {
    width: 60px;
    height: 60px;
    object-fit: cover;
    border: 1px solid #ddd;
    border-radius: 4px;
}
.product-thumbnails img {

}


/* .wc-multistore-bulk-sync-advanced-container.open {
    height: 300px !important;
    overflow-y: auto;
} */
/*thanks*/
.thanks-reg {
	position: relative;
    text-align: center;
}

/*プライバシーポリシー*/
.privacy-main {
    width: calc(100% - 2rem);
    max-width: 900px;
    position: relative;
    left: 50%;
    transform: translate(-50%);
}
.privacy-main div {
    margin-bottom: 60px;
}
.privacy-main div h5 {
    margin-bottom: 4px;
}
.privacy-main div ul {
    list-style: disc;
    margin-left: 20px;
}
/* ポップアップの全体のスタイル */
.popup {
    position: fixed; /* 固定位置 */
    top: 50%; /* 親要素から50%の位置 */
    left: 50%; /* 親要素から50%の位置 */
    transform: translate(-50%, -50%); /* 完全に中央に配置 */
    width: 80%; /* ポップアップの幅 */
    max-width: 600px; /* 最大幅 */
    padding: 30px; /* 内側の余白 */
    background-color: #fff; /* 背景色 */
    border-radius: 10px; /* 角を丸く */
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1); /* 影を付けて浮き上がらせる */
    z-index: 9999; /* 他の要素より前に表示 */
    display: none; /* 初期状態では非表示 */
}

/* ポップアップのヘッダー部分 */
.popup .popup-header {
    font-size: 24px; /* ヘッダーのフォントサイズ */
    font-weight: bold;
    margin-bottom: 20px; /* 下の余白 */
}

/* ポップアップ内のコンテンツ */
.popup .popup-content {
    font-size: 16px; /* コンテンツのフォントサイズ */
    line-height: 1.5; /* 行間 */
}

/* ポップアップを閉じるボタン */
.popup .popup-close {
    position: absolute; /* 絶対位置 */
    top: 10px;
    right: 10px;
    font-size: 20px;
    cursor: pointer;
    color: #333;
}

/* 背景が暗くなるオーバーレイ */
.overlay {
    position: fixed; /* 固定位置 */
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.5); /* 半透明の黒背景 */
    z-index: 9998; /* ポップアップより下に表示 */
    display: none; /* 初期状態では非表示 */
}

/* 画像にマウスオーバー時にタイトルを表示しない */
img[title] {
    pointer-events: none;
}

/*管理画面のstyle*/
/*管理画面のヘッダー*/
/* ユーザーダッシュボード用のカスタムヘッダー */
.userdash-header {
    background-color: #f7f7f7;
    padding: 10px;
    border-bottom: 2px solid #ddd;
	margin-bottom: 60px;
    position: fixed;
    width: 100%;
    top: 0;
    z-index: 999;
    display: flex;
    justify-content: space-between;
}

.userdash-header ul {
    display: flex;
}
.userdash-header ul li{
    margin: 0 10px;
}
.userdash-header ul img {
    height: 40px;
    width: auto;
    object-fit: contain;
}
.userdash-header ul a {
    display: flex;
    flex-direction: column;
}
.userdash-breadcrumb {
    position: relative;
    top: 100px;
    left: 40px;
    font-size: 12px;
}

.order-warnings li {
    margin: 10px 0;
    padding: 10px;
    max-width: calc(100% - 80px);
    position: relative;
    left: 40px;
}
.header-container {
    display: flex;
    align-items: center;
}

.header-container .home-link {
    display: flex;
    align-items: center;
    flex-direction: column;
    text-decoration: none;
    color: #333;
}

.header-container .home-link img {
    width: 70px;
    height: auto;
    margin-right: 8px;
}

.header-container .home-link span {
    font-size: 16px;
    font-weight: bold;
}
.mar-t-120px {
    margin-top: 120px;
}
/*ダッシュボード*/
.dashbord-contents {    
	min-height: 90vh;
	max-width: 900px;
    position: relative;
    left: 50%;
    transform: translate(-50%);
    width: calc(100% - 6rem);
}
.dashbord-contents > ul {
	display: flex;
    justify-content: space-between;
}

.dashbord-contents > ul li{    
	position: relative;
	width: calc(100% / 3 - 20px);
    text-align: center;
    background: #F2F5F6;
    box-shadow: 5px 5px 17px 0 rgba(0, 0, 0, 0.05);
    padding: 20px;
}

.dashbord-contents > ul li a {
	position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    width: 100%;
}

.dashbord-contents ul img {
    height: 80px;
}
.dashbord-contents p {
	color: #48565E;
    text-align: left;
}
.dashbord-contents .tooltip {
	position: absolute;
    right: 0;
    top: -24px;
}
.dashbord-contents .content {
    border: 1px solid #ddd;
    padding: 20px;
    background: #fff;
    margin-top: 10px;
}
.dashbord-contents .order-warnings ul {
    margin-top: 40px;
    border: 1px solid #ddd;
    max-height: 200px;
    overflow-y: scroll;
    scroll-behavior: smooth;
}
.dashbord-btn {
	background: #48565E;
    margin-top: 80px;
    min-width: 400px;
    padding: 18px;
    position: relative;
    left: 50%;
    transform: translate(-50%);
}
.btn-dark {	
	background: #48565E!important;
	padding: 10px 30px!important;
}
.mar-l-4 {
	margin-left: 40px;
}
@media screen and (max-width:559px) {
	.mar-l-4 {
		margin-left: 20px;
	}
}
.setup-checklist {
    display: flex;
    text-align: left;
    flex-basis: fit-content;
    flex-direction: column;
    justify-content: left;
}
.setup-checklist li {
    width: 100%;
    text-align: left;
    background: #fff;
}
.go-to-settings-button,
.go-to-giftcode-button,
.go-to-order-button {
    margin-left: 0px;
    background: none;
    color: #888;
    padding: 4px;
    font-size: 15px;
}
.go-to-settings-button:hover,
.go-to-giftcode-button:hover,
.go-to-order-button:hover {
    background: none;
    color: #74a0b8;
}
.header {
    position: relative;
    min-height: 70px;
}
.site-logo {
    align-items: center;
    display: flex;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
}
.site-logo img {
	max-height: 70px;
    max-width: 140px!important;
    width: 100%;
    object-fit: contain;
    margin-left: 20px;
}
.setting-logo {
    position: relative;
    top: 0;
    transform: translateY(-0%);
}
@media screen and (max-width:700px) {
    .site-logo img {
        max-height: 50px;
        margin-left: 10px;
    }
}
/*クーポン*/
.coopon-setting {
    background-color: #F2F5F6;
    width: calc(100% - 4rem);
    max-width: 600px;
    padding: 20px;
	margin-top: 20px;
}
.coopon-setting h5 {
	margin-bottom: 4px;
    display: inline-block;
}
.coopon-setting span {
	/* width: 40px; */
    position: relative;
    display: inline-block;
}
.coopon-setting p {
    margin-bottom: 0;
}
.modal-c .close-modal {
    font-size: 30px;
    position: absolute;
    right: 40px;
    cursor: pointer;
}
.coupon-code {
    cursor: pointer; /* クーポンコードをクリック可能に見せる */
    color: #0073aa;  /* 色を変更して強調 */
    text-decoration: underline;
}

.coupon-description {
    margin-left: 10px; /* 少し余白を追加して見やすく */
    display: none;     /* 初期状態で非表示 */
}
#popup-form label {
    font-size: 14px;
    width: 200px;
}
#popup-form input, 
#popup-form select, 
#popup-form textarea {
    padding: 4px 10px;
    width: 500px;
    font-size: 14px;
}
#preview-dialog h3 {
    width: 500px;
}
#popup-form textarea {
    vertical-align: top;
    height: 300px;
}
.ui-dialog {
    width: auto !important;
}
#default-image-dialog img.selectable-image {
    width: 200px;
    height: 120px;
    object-fit: cover;  /* 自動調整 */
    margin: 5px;      /* 余白 */
    cursor: pointer;  /* ポインターアイコン */
    border: 1px solid #ddd; /* 枠線 */
    border-radius: 5px; /* 角丸 */
    transition: transform 0.2s; /* 拡大のアニメーション */
}

#default-image-dialog img.selectable-image:hover {
    transform: scale(1.1); /* ホバー時に少し拡大 */
    border-color: #0073aa; /* ホバー時に枠線を変更 */
}

.use-coupon-button {
    font-size: 12px;
    padding: 6px;
    background: #e65d5d;
}
#open-modal-btn {
    left: 0;
    transform: translate(0);
    margin: 20px 0 40px 40px;
}
.modal-c {
    width: 80%;
    margin: 1% auto;
    max-height: 80vh;
    overflow-y: scroll;
}
.generate_coupons {
    left: 0;
    transform: translate(0);
}
/* ボタンが非活性化された状態 */
.generate_coupons:disabled {
    background-color: #ddd; /* 背景色 */
    color: #666; /* テキスト色 */
    cursor: not-allowed; /* カーソルを禁止マークに変更 */
}

/* ホバー時のスタイル（:disabledに対しては通常ホバーは効かないが、念のため定義） */
.generate_coupons:disabled:hover {
    background-color: #ddd; /* ホバー時も背景色は同じ */
    color: #666; /* テキスト色も同じ */
    cursor: not-allowed; /* 禁止マーク */
}

/*注文管理*/
/*オーバーレイ*/
#overlay {
    display: none; /* 初期状態では非表示 */
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.5); /* 半透明の背景 */
    z-index: 9999; /* 最前面に表示 */
}

#overlay-message {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    color: #fff;
    padding: 20px;
    border-radius: 8px;
    font-size: 18px;
    text-align: center;
}

.explan {
    width: calc(100% - 80px);
    position: relative;
    left: 40px;
    font-size: 14px;
}
.explan span {
    padding: 4px 10px;
}
.col-processing {
    /* background: #FFFDB5; */
    background: #e5c7c7;
    padding: 4px 10px;
    white-space: nowrap;
}
.col-order-ok {
    background: #D6E7F0;
    /* background: #e5c7c7; */
    padding: 4px 10px;
    white-space: nowrap;
}
.col-btn {
    background: #2f5aae;
    color: #fff;
    padding: 4px 10px;
    white-space: nowrap;
}
.tuto-list {
    list-style: disc;
    margin-left: 20px;
}
.col-btn-d {
    background: #48575E;
    color: #fff;
    padding: 4px 10px;
    white-space: nowrap;
}
.col-btn-r {
    background: red;
    color: #fff;
    padding: 4px 10px;
    white-space: nowrap;
}
.col-link {
    color: blue;
    border-bottom: 1px solid blue;
}
/*各種設定*/
.setting-wrap {
    overflow: hidden;
	border: 1px solid #74A0B8;
    border-radius: 5px;
    width: calc(100% - 40px);
    position: relative;
    left: 50%;
    transform: translate(-50%);
}
.tabs {
	background: #F2F5F6;
}
.tabs button {
    background: #F2F5F6;
    color: #000;
    border: none; /* 必要に応じて追加 */
    cursor: pointer;
}

.tabs button.active {
    background: #fff;
    color: #000;
}
.tabcontent {
	padding: 20px 30px;
}
.tabcontent p {
	margin-bottom: 10px;
}
.tabcontent p input,
.tabcontent p textarea {
	width: 100%;
}
.tabcontent p textarea {
    height: 140px;
}
.tabcontent label {
	width: auto;
    font-size: 14px;
}
.tabcontent h5 {
    margin-top: 40px;
    margin-bottom: 0;
}
.flex-item {
	display: flex;
}
.flex-item .site-logo img {
	border: 1px solid #878787;
    border-radius: 5px;
    width: 120px;	
    margin-bottom: 10px;

}
.to-product {
	color: #74A0B8;
	border-bottom: 1px solid #74A0B8;
}
#CatalogSettings h4 {
	margin-bottom: 4px;
}
#CatalogSettings ul h4 {
	display: inline-block;
    font-weight: 300;
}
.wc-multistore-bulk-sync-section label {
	display: contents;
}
.wc-multistore-bulk-sync-section {
    padding: 0!important;
}
.select-default-image {
    background: #74A0B8;
    display: block;
    font-size: 12px;
}
.site-background-image2 img,
.site-background-image img {
width: 140px;
    height: 100px;
    object-fit: cover;
}
.count-mismatch {
    color: red;
}

.count-match {
    color: inherit; /* 通常の文字色 */
}
/* Slickスライダー内の画像の高さを16vwに設定し、object-fit: coverを適用 */
.slick-slider .slick-slide img {
    height: 60px!important; /* 画面幅に対して16%の高さを設定 */
    object-fit: cover; /* 画像がスライド内に収まるように切り取られる */
    width: 100%; /* 横幅は100% */
}
@media screen and (max-width:700px) {
    .slick-slider .slick-slide img {
        height: 20vw!important; /* 画面幅に対して16%の高さを設定 */ 
    }     
}
@media screen and (max-width:700px) {
    .slick-slider .slick-slide img {
        height: 28vw!important; /* 画面幅に対して16%の高さを設定 */ 
    }     
}
.slick-slider-category img {
    height: 10vh!important;
}
.slick-slider-category .slick-prev::before,
.slick-slider-category .slick-next::before {
    color: black;       /* ← ここを任意の色に */
    font-size: 23px;    /* 大きさも調整可 */
    opacity: 1;         /* 非表示対策 */
}
.slick-slider-category .slick-next {
    right: -14px;
}
.slick-slider-category .slick-prev {
    left: -14px;
}
.slick-list {
    height: 60px;
}
.image-url-pair {
    background: #efefef;
    padding: 10px;
    margin: 10px 0;
}
.remove-pair {
    position: relative;
    left: 50%;
    transform: translate(-50%);
    background: none;
    color: #74A0B8;
    border: 1px solid #74A0B8;
    border-radius: 100%;
    padding: 0 10px;
}
.add-pair {
    position: relative;
    left: 50%;
    width: 100%;
    transform: translate(-50%);
    background: none;
    color: #74A0B8;
    z-index: 1;
}
.add-pair::before {
    position: absolute;
    content: '';
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    height: 2px;
    width: 100%;
    background: #74A0B8;
    z-index: -2;
}
.add-pair::after {
    position: absolute;
    content: '';
    height: 100%;
    width: 190px;
    left: 50%;
    transform: translate(-50%);
    z-index: -1;
    background-color: #fff;
}
.add-pair:hover {
    background: none;
    color: #87b3ca;
}

#dialog-image-preview {
    width: 400px;
    height: 300px;
    object-fit: contain;
}
#preview-area {
    border: 1px solid;
    transform: scale(.5);
    transform-origin: left top;
    overflow: hidden;
    pointer-events: none;
    font-family: serif;
    position: absolute;
    left: 800px;
    width: 1200px;
    top: 300px;
}
#preview-area #preview-logo {
    display: block;
    position: relative;
    width: 100px;
    padding: 4px 10px;
}
#preview-area .header-menu {
    position: relative;
    height: 80px;
}
#preview-area .header-menu .menu {
    width: 300px;
    object-fit: contain;
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
}
.atn-test {
    margin-top: -20px;
    padding-bottom: 30px;
    font-size: 14px;
}
input[type="checkbox"]:checked + .label-text {
    text-decoration: line-through;
    color: #888; /* オプション：色も変えたい場合 */
}
.title-flx {
    display: flex;
    align-items: baseline;
}
#reset-tutorial-btn {
    background: none;
    color: #74a0b8;
    font-size: 14px;
}
#reset-tutorial-btn i {
    padding: 10px;
    border: 1px solid;
    border-radius: 100%;
}
/*テンプレートスタイル*/
.top {
	position: relative;
    background-repeat: no-repeat;
    /* background-position: 100% 0%; */
    background-position: 50%, 50%;
    background-size: cover;
    height: 60vh;
    width: calc(100% - 20px);
    position: relative;
    left: 50%;
    transform: translate(-50%);
    /* width: 75%; */
    /* left: 25%; */
  }
  .top nav {
	margin: 60px 0 0 20px;
	position: absolute;
    left: -30%;
  }
  .top nav > ul > li {
	margin-top: 30px;
  }
  .top h1 {
    font-size: 3.6vh;
    /* font-size: 10vw; */
    font-family: serif;
    text-align: center;
    color: #fff;
    line-height: 2;
    position: absolute;
    left: 50%;
    top: 50%;
    /* padding-top: 160px; */
    transform: translate(-50%, -50%);
    line-height: 1;
  }
  .top h1 span {
    font-size: 8.6vh;
  }
  .top .logo {
    position: absolute;
    max-height: 300px;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
  }
  @media screen and (max-width:700px) {    
    .top .logo {
        height: 200px;
      }
  }
  .top-logintitle {
    background: linear-gradient(#D7DEE2 0%, #999999 80%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
  }
  .coupon-input {
    padding-bottom: 100px;
  }
  .contact-menu li {
    font-size: 15px;
    margin: 4px 0 4px 10px;
  }
  #coupon-form {
    position: relative;
    left: 50%;
    transform: translate(-50%);
    display: inline-block;
  }
  #coupon-form label {
    display: flex;
  }
  @media screen and (max-width:700px) {    
    #coupon-form {
        text-align: center;
    }
    #coupon-form input {
        width: 100%;
    }
    #coupon-form label {
        text-align: center;
        width: 100%;
        display: block;
    }
  }
  .bottom-text {
    margin-bottom: 30px;
    font-family: serif;
    width: 100%;
    position: absolute;
    bottom: -20px;
    text-align: center;
    /* left: 50%; */
    color: #435158;
    /* transform: translate(-50%);*/
  }
  /* .temp-1-bgd {
	background-image: url(img/ikea-4048225_1280\ 3.png);
  } */
/*スマホ*/
@media screen and (max-width:770px) {
    h1 {
        font-size: 20px!important;
    }
    h2 {
        font-size: 20px!important;
    }
    h3 {
        font-size: 20px!important;
    }
}
@media screen and (min-width: 960px) {   
    h2 {
        font-size: 24px!important;
    }
   
}
  .site-text {
    text-align: center;
    margin-top: 4rem;
  }
  .site-text h1 {
    color: #48565E;
    margin-bottom: 0;
    font-size: 40px!important;
  }
  .site-text h2 {
    color: #BDBDBD;
    font-size: 2vh;
  }
  .site-text p {
    width: calc(100% - 40px);
    position: relative;
    left: 50%;
    transform: translate(-50%);
  }
  
@media screen and (max-width:700px) {
      .site-text h1 {
        font-size: 3.6vh!important;
      }
      .site-text h2 {
        font-size: 1.6vh!important;
      }
      .footer-txt {
        font-size: 12px;
      }
}
@media screen and (max-width:559px) {
    .site-text h1 {
      font-size: 2.8vh!important;
    }
    .site-text h2 {
      font-size: 1.8vh!important;
    }
}
  .category-view h3 {
	font-weight: 400;
	margin-bottom: 0;
  }
  .category-view h2 {
    position: absolute;
    width: 84vw;
    max-width: 840px;
    left: 50%;
    transform: translate(-50%);
    margin-top: -60px;
  }
  .category-view ul {
	margin-top: 10rem;
	display: flex;
	flex-wrap: wrap;
	width: 84vw;
	max-width: 840px;
	position: relative;
	left: 50%;
	transform: translate(-50%);
  }
  .category-view ul li {
    width: calc(100% / 3 - 40px);	
    margin: 0 20px 60px;
  }

  .category-view ul li img {
	width: 100%;
	height: 14vw;
	-o-object-fit: cover;
	   object-fit: cover;
  }
  .category-view ul li h4 {
	margin-bottom: 4px;
    color: #000;
    font-weight: 300;
  }
  @media screen and (max-width:595px){
    .category-view ul li {
        width: calc(100% / 2 - 20px);	
        margin: 0 10px 60px;
      }
      .category-view ul li img {
        height: 32vw;
      }
}
@media screen and (max-width:959px){
      .category-view ul li img {
        height: 20vw;
      }
}
  #coupon-form {
	margin-top: 80px;
  }
  #coupon-form .button-dark {
    width: 100px;
  }
  
  .view-button {
	position: relative;
	left: 50%;
	transform: translate(-50%);
	padding: 12px 40px;
	border: none;
  }
  .view-button a {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
  }
.wishlist_view .item-details h3 a {
    --linkdeco: auto;
}
@media screen and (max-width:700px) {
    .wishlist_view .item-details h3 a {
        font-size: 18px;
    }
    .wishlist_table .additional-info {
        width: 120px;
    }
    
  .category-view h2 {
    font-size: 28px !important;
  }
}
.wishlist_table.mobile li {
    border-bottom: 1px solid #ddd;
}

  
  .temp-1-btn {
	background-color: #292929;
	color: #fff;
  }

  .category-list {
    display: flex;
    flex-wrap: wrap;
  }
  .child-category-list {
    width: calc(100% / 3);
  }
  
  /* .parallax_content {
	margin-top: 8vw;
	display: flex;
	height: 100%;
	justify-content: right;
	align-items: end;
	padding-top: 28vw;
	background-attachment: fixed;
	background-position: center;
	background-size: cover;
	background-repeat: no-repeat;
  }
  
  .par-1 {
	background-image: url(img/magazine-2559842_1280\ 2.png);
	color: #fff;
	font-size: 10vw;
	line-height: 0.6;
	font-weight: 700;
  }
   */

   .works-title {
    position: relative;
   }
   .works {
    position: relative;
    padding: 40px 0 20px;
    margin-bottom: 60px;
   }
   .works::before {
    position: absolute;
    content: '';
    width: 100%;
    height: 100%;
    border: 4px solid #EDEFEF;    
    top: 50px;
    left: 30px;
   }
   .works-title {
    position: relative;
    z-index: 1;
    left: 4rem;
    display: inline;
   }
   .works-title::before {
    position: absolute;
    content: '';
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 140%;
    height: 100%;
    background: #fff;
    z-index: -1;
    padding: 20px;
   }

   .slick-slide {
    margin: 0 10px; /* 左右の隙間を10pxに設定（必要に応じて調整） */
}
.works-images-gallery {
    display: flex;
    flex-wrap: wrap;
    /* position: absolute; */
    bottom: 0;
    /* width: 50%; */
    /* left: 540px; */
}
.works-images-gallery img {
    width: 100px;
    cursor: pointer;
    height: 120px;
    object-fit: cover;
}
.work-image-item {
    margin: 0 6px;
}
/* スライダー全体の外側に余白を設定 */
.works-images-slider {
    padding: 0 20px;
    margin-top: 20px;
}

  .footer {
    background: #EDEFEF;
    padding: 40px 4vw;
    /* margin-top: 60px; */
  }
  .footer-wrap {
    display: flex;
    justify-content: space-between;
    position: relative;
  }
  .footer-right {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
  }
  .footer-left {
    display: flex;
  }
  .footer-left ul li {
    padding: 4px 0;
    margin: 10px 0;
  }
  .footer-left ul li a {
    color: #000;
  }
  .left-left {
    margin-right: 40px;
  }
  .footer hr {
    border-top: .2px solid;
  }
  .footer p {
    text-align: center;
    margin-bottom: 0;
    opacity: .6;
  }
  @media screen and (max-width:959px) {
    .footer-wrap {
        display: block; /* 画面幅に対して16%の高さを設定 */ 
    }  
    .footer-wrap .social {
        position: absolute;
        bottom: 10px;
        right: 0;
    }
    .footer-left {
        display: flex;
        padding-bottom: 40px;
    }
    }   

    @media screen and (max-width:559px) {
        .footer-left {
            font-size: 12px;
        }
        .category-list-front h4 {
            font-size: 16px;
        }
    }
    /*カタログ選択モーダル*/
    #shop-manager-modal .modal-content {
        width: calc(100% - 40px);
        max-width: 900px;
        overflow-y: scroll;
        max-height: 600px;
        border-style: none;
    }
    #shop-manager-modal.modal {
        background-color:#fff;
    }
    #selected-categories {
        position: relative;
        display: flex;        
        flex-wrap: wrap;
        max-width: 800px;
        left: 50%;
        transform: translate(-50%);
    }
    #selected-categories li {
        width: calc(100% / 3 - 20px);
        margin: 0 10px;
    }
    #selected-categories li img {
        height: 140px;
        object-fit: cover;
        width: 100%;
    }
.contact form {
    width: 600px;
    position: relative;
    left: 50%;
    transform: translate(-50%);
}
.form {
    display: flex;
    align-items: center;
}
.form label {
    width: 140px;
}
  /*temp3*/
  .par-3 {
    background-image: url(https://mq3.biz/cptncxs0dv/wp-content/themes/theme-childs/img/temp3-read.png);
    color: #fff;
    font-size: 2.4rem;
    letter-spacing: .5rem;
    font-weight: 800;
}
.temp-3-bgd::before {
	position: absolute;
	content: '';
	top: 10%;
	left: -35%;
	width: 100%;
	height: 100%;
	background: #455643;
	z-index: -1;
}

.temp-3-btn {
    background-color: #4E5B4C;
    color: #fff;
    border: double 4px #f6f2ee;
  }
.rad-3 li {
	background: #fff;
    padding: 10px;
	position: relative;
}
.rad-3 li:not(:nth-of-type(1))::before {
	position: absolute;
    content: '';
    left: -15px;
    top: 50%;
    transform: translateY(-50%);
    height: 90%;
    width: .4px;
    background: #333;
}

/*css分岐できるか*/

.front-page-id-70.home,
/* .front-page-id-70.page, */
.front-page-id-70.tax-product_cat,
.front-page-id-70.woocommerce-cart,
.front-page-id-70.woocommerce-wishlist,
.front-page-id-70.single-product,
.front-page-id-70.woocommerce-cart,
.front-page-id-70.woocommerce-checkout,
.front-page-id-70.woocommerce-order-received,
.front-page-id-70.woocommerce-page a,
.front-page-id-70 .cart-empty woocommerce-info a,
.front-page-id-70.woocommerce-page  button,
.front-page-id-70 .coupon-input .button-dark,
.front-page-id-70 .simple-url-link {
    font-family: math, serif;
}
body.front-page-id-70 .single_add_to_cart_button,
body.front-page-id-70 .checkout-button,
body.front-page-id-70 button[name="woocommerce_checkout_place_order"] {
    background: #435158!important;
}
body.front-page-id-70 button[name="apply_coupon"] {
    border-color: #435158!important;
    color: #435158!important;
}

body.front-page-id-70 .woocommerce .woocommerce-message,
body.front-page-id-70 .woocommerce-page .woocommerce-message {
    background: #74A0B8;
}

.tutorial-modal {
    height: 100%;
    /* background: #00000036; */
    position: fixed;
    z-index: 9999;
    width: 100%;
    top: 0;
    display: none; /* 初期状態では非表示 */
    pointer-events: none; 
}
.tutorial-content {
    width: 600px;
    background: #fff;
    left: 50%;
    top: 50%;
    position: relative;
    transform: translate(-50%, -50%);
    border-radius: 5px;
    padding: 20px;
    border: 1px solid #ddd;
    box-shadow: 0 0 20px 10px #ddd;
    cursor: grab;
    pointer-events: auto;
}

.close-tutorial {
    cursor: pointer;
    position: absolute;
    right: 20px;
    top: 4px;
    font-weight: 400;
    font-size: 30px;
}

.tutorial-buttons button {
    padding: 8px 16px;
    font-size: 16px;
    cursor: pointer;
    border-radius: 5px;
    transition: background 0.2s ease-in-out;
    border: 1px solid #326cd7;
    color: #326cd7;
    background: #fff;
}

/* 無効（disabled）のときのスタイル */
.tutorial-buttons button:disabled {
    cursor: default;
    color: #cfcfcf;
    background: #fff;
    border: 2px solid #cfcfcf;
    font-weight: bold;
}

.product-modal {
    display: none;
    position: fixed;
    z-index: 1000;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0,0,0,0.5);
}

.product-modal-content {
    background-color: white;
    margin: 10% auto;
    padding: 20px;
    width: 60%;
    border-radius: 8px;
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
}

.close-product-modal {
    float: right;
    font-size: 24px;
    cursor: pointer;
}

#modal-back {
    display: none;
    /* margin-top: 10px;
    background: #ddd;
    padding: 5px 10px; */
    border: none;
    cursor: pointer;
    border-radius: 4px;
    background: none;
    color: #000;
    font-size: 24px;
    margin-top: 0;
    padding: 0;
}

#modal-back.active {
    background: none;
    color: #000;
    cursor: pointer;
}
.product-modal #category-list,
.product-modal #product-list {
    overflow-y: scroll;
    max-height: 60vh;
    display: flex;
    flex-wrap: wrap;
}
.product-modal #product-detail {
    overflow-y: scroll;
    max-height: 60vh;
}
.product-modal #category-list li,
.product-modal #product-list li {
    margin: 40px 10px;
    display: inline-block;
    width: calc(100% / 3 - 20px);
    max-width: calc(100% / 3 - 20px);
    text-align: left;
    cursor: pointer;
}
.product-modal .category-item img,
.product-modal .product-item img {
    width: 100%;
    height: 16vh;
    object-fit: cover;
    border: 1px solid #ddd;
}
.preview-detail-flx {
    display: flex;
    align-items: start;
}
.preview-detail-flx span {
    min-width: 50%;
    margin-left: 20px;
}
.pagination {
    margin-top: 20px;
    text-align: center;
}

.pagination button, .pagination .page-number {
    display: inline-block;
    margin: 0 5px;
    padding: 8px 12px;
    border: 1px solid #0073aa;
    color: #0073aa;
    background: #f8f8f8;
    cursor: pointer;
    transition: 0.3s;
}

.pagination .current {
    background: #0073aa;
    color: white;
    font-weight: bold;
    cursor: default;
}

/*チュートリアルのモーダル*/
.login-modal h5 {
    margin-bottom: 0;
}
.login-modal p {
    font-size: 13px;
    margin-bottom: 50px;
}

@media screen and (max-width:770px) {
    .woocommerce div.product .product_title {
        font-size: 22px;
    }
}

.category-button {
    display: inline-block;
    padding: 10px 15px;
    border: 2px solid #0073aa;
    border-radius: 5px;
    background-color: #fff;
    color: #0073aa;
    cursor: pointer;
    transition: all 0.3s ease;
    font-weight: bold;
}
.category-button.selected {
    background-color: #0073aa;
    color: #fff;
}
.category-button .status-label {
    display: block;
    font-size: 0.8em;
    margin-top: 5px;
}
.parent-category.selected {
    background: #f2f5f6;
    border: 1px solid #74a0b8;
}
.st-main {
    width: 900px;
    text-align: center;
    margin-top: 40px;
    position: relative;
    left: 50%;
    transform: translate(-50%);
}
.st-main img,
.form-pre-regi img {
    width: 570px;
}

.parent-category label {
    font-size: 16px;
}
.parent-category-checkbox {
    width: 18px;
    height: 18px;
    margin-right: 4px;
}
.parent-category h4 {
    margin-bottom: 0;
}

/*会社ロゴ目立たせ*/
.company-logo-wrapper {
    background-color: #F2F5F6;
    padding: 15px;
    border-radius: 10px;
    border: 2px dashed #74A0B8;
    display: flex;
    align-items: center;
    gap: 20px;
    margin-bottom: 20px;
}

.company-logo-wrapper label.site-logo {
    display: block;
    max-width: 100px;
    max-height: 100px;
    overflow: hidden;
}

.company-logo-wrapper img {
    width: 100%;
    height: auto;
    border-radius: 8px;
    border: 1px solid #ccc;
}

.company-logo-wrapper input[type="file"] {
    padding: 5px;
    /* background-color: #ffffff;
    border: 1px solid #ccc; */
    border-radius: 5px;
}

