@charset "utf-8";
/*
Theme Name: iroiro theme7
Theme URI: https://iroirostyle.com
Version: 7.0
*/

/*  
---------------------------------------------------------------------------*/
html {
	overflow-y: scroll;
}

body {
	color: #335273;
	font-size: 14px;
	font-family: '游明朝', 'YuMincho', 'ヒラギノ明朝 ProN', 'Hiragino Mincho ProN', 'ＭＳ Ｐ明朝', 'MS PMincho', serif;
	line-height: 1;
	font-feature-settings: 'pkna' 1;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	font-feature-settings: 'palt' 1;
}

.wrap {
	background: #FFFFFF;
	width: 100%;
	max-width: 1320px;
	margin: 0 auto;
}

body.top .wrap {
	background: none;
	max-width: inherit;
}

::-moz-selection { background: #CCCCCC; color: #333333; }
::selection { background: #CCCCCC; color: #333333; }

.clearfix { display: block; }
.clearfix:after {
	visibility: hidden;
	display: block;
	font-size: 0;
	content: '';
	clear: both;
	height: 0;
}

body#pc .sp_view { display: none !important; }
body#sp .pc_view { display: none !important; }

p {
	font-size: 16px;
	line-height: 2.1;
	letter-spacing: 0.1em;
}

.sec-lead p {
	line-height: 2.0;
	letter-spacing: 0.08em;
}

address,i { font-style: normal; }
img { max-width: none; }

/* #loading
------------------------------------*/
#loading {
	display: inline-block;
	position: fixed;
	top: 50%;
	left: 50%;
	border: 1px solid #43597C;
	border-top-color: transparent;
	border-radius: 50%;
	width: 20px;
	height: 20px;
	margin: -10px 0 0 -10px;
	z-index: 9999;
	animation: spin 0.4s infinite linear;
/*
	display: none;
	opacity: 0;
*/
}

@keyframes spin {
  from { transform: rotate(0deg); }
  to { transform: rotate(360deg); }
}

/* txt
-----------------------------------*/
.txt-min { font-family: '游明朝', 'YuMincho', 'ヒラギノ明朝 ProN', 'Hiragino Mincho ProN', 'ＭＳ Ｐ明朝', 'MS PMincho', serif; letter-spacing: 0.1em;}
.txt-sans { font-family: 'futura-pt', sans-serif; }
.txt-serif { font-family: 'Adobe Garamond Pro', 'Garamond Premier Pro', 'EB Garamond', serif; letter-spacing: 0.1em;}

.txt-num,
.wp-pagenavi a.page,
.wp-pagenavi .current {
  font-family: 'Crimson Text', serif;
  letter-spacing: 0.06em;
  font-size: 20px;
}

/* link
------------------------------------*/
a { color: #43597B; text-decoration: none; transition: .15s ease-out; -webkit-transform: translateZ(0); }
a:hover { text-decoration: none; opacity: 0.6; }

/* header
---------------------------------------------------------------------------*/
header {
	width: 1100px;
	margin: 0 auto;
	z-index: 998;
	opacity: 0;
}

header .inner {
	position: relative;
	overflow: hidden;
	padding: 110px 50px 0;
}

header .logo {
	float: left;
}

header .logo-top {
	display: none;
	float: none;
}

/* footer
---------------------------------------------------------------------------*/
footer {
	box-sizing: border-box;
	width: 1100px;
	margin: 0 auto;
	padding: 140px 50px 60px 50px;
	opacity: 0;
}

.copyright {
	font-size: 16px;
	letter-spacing: 0.15em;
}

/* .gnav
---------------------------------------------------------------------------*/
.gnav {
	float: right;
	margin: 34px -5px 0 0;
}

.gnav li {
	position: relative;
	float: left;
	margin-right: 18px;
}

.gnav li:last-of-type {
	margin-right: 0;
}

.gnav li a {
	display: block;
	padding: 10px 1px 3px 0px;
	font-size: 18px;
	letter-spacing: 0.09em;
}

body.news #gnav-news,
body.about #gnav-about,
body.collection #gnav-collection,
body.shopping-guide #gnav-shoppingguide,
body.contact #gnav-contact,
body.stockist #gnav-stockist {
	border-bottom: 1px solid #C6CDD7;
}

/* .sns
------------------------------------*/
.sns {
	overflow: hidden;
	position: absolute;
	top: 50px;
	right: 45px;
}

.sns-top {
	display: none;
	position: inherit;
	top: inherit;
	right: inherit;
}

.sns li { float: left; margin-right: 10px; }
.sns li:last-of-type { margin-right: 0; }

/* .wp-pagenavi
------------------------------------*/
.wp-pagenavi {
	font-size: 16px;
	text-align: center;
}

.wp-pagenavi a,
.wp-pagenavi .extend {
	padding: 8px 10px;
}

.wp-pagenavi .current {
	display: inline-block;
	border-bottom: 1px solid #666666;
	margin: 0 11px;
	padding: 5px 0 0 1px;
	letter-spacing: 0;
}

/* contents
---------------------------------------------------------------------------*/
#mainContents {
	position: relative;
	box-sizing: border-box;
	width: 1000px;
	margin: 0 auto;
	padding-top: 130px;
	text-align: left;
	opacity: 0;
}

#mainContents .pagetitle {
	display: none;
}

/* .address
------------------------------------*/
.address p {
  font-size: 15px;
	letter-spacing: 0.1em;
}

.address p.post {
	margin: 0 0 2px;
	font-size: 13px;
	line-height: 1.4;
	letter-spacing: 0.06em;
}

/* .address p:nth-of-type(3) { letter-spacing: 0.06em; } */

/* .table-common
------------------------------------*/
.table-common {
	width: 100%;
	font-size: 14px;
	line-height: 1.6;
	letter-spacing: 0.1em;
}

.table-common.txt-l {
	font-size: 15px;
}

.table-common th {
	box-sizing: border-box;
	background: #F2F5F8;
	border-right: 1px solid #E5E5E5;
	padding: 15px 15px 14px;
	font-weight: normal;
	vertical-align: middle;
	text-align: center;
	letter-spacing: 0.15em;
}

.table-common th:first-of-type { width: 160px; }

.table-common th:last-of-type,
.table-common td:last-of-type { border-right: none; }

.table-common.txt-l th { font-size: 16px; }

.table-common th span {
	padding-left: 3px;
	font-size: 12px;
}

.table-common td {
	border-right: 1px solid #E5E5E5;
	border-bottom: 1px solid #E5E5E5;
	padding: 18px 15px 17px;
	vertical-align: middle;
	text-align: center;
}

.table-common strong { font-size: 16px; }

.table-common td span {
	display: block;
	margin-top: 2px;
	font-size: 12px;
}

.table-common td span.in {
	display: inline-block;
	margin: 0 0 0 2px;
}


/* error
---------------------------------------------------------------------------*/
#errorContents {
	padding: 0 0 0 100px;
}

.error-title {
	margin-bottom: 45px;
}

.error-title h2 {
	font-size: 16px;
	letter-spacing: 0.1em;
}

.error-txt p {
	margin-bottom: 15px;
	line-height: 2;
}

.error-txt p a,
.error-txt p a span { text-decoration: underline; }


/* .grecaptcha-badge
---------------------------------------------------------------------------*/
.grecaptcha-badge {
	pointer-events: none;
	z-index: -999;
	opacity: 0;
}

/* body.collection-single .grecaptcha-badge.active, */
body.contact .grecaptcha-badge {
	pointer-events: auto;
	z-index: 999;
	opacity: 1;
}


/* .category-list
---------------------------------------------------------------------------*/
.category-list {
	position: relative;
	box-sizing: border-box;
	width: 100%;
	margin-bottom: 45px;
	z-index: 10;
}

#collectionContents.single .category-list {
	margin-bottom: 60px;
}

.category-nav {
	position: relative;
	float: left;
	margin-bottom: 10px;
}

.category-nav.home {
	position: absolute;
	top: -34px;
	left: 0;
}

.category-nav.status {
	margin-right: -2px;
	margin-left: 18px;
}

.category-nav.status .nav-parent {
	position: relative;
}

.category-nav.status .nav-parent:before {
	display: block;
	content: '/';
	position: absolute;
	top: 0;
	left: -22px;
	color: #435A7B;
	font-size: 16px;
}

.category-nav .nav-parent a,
.category-nav .nav-parent > span {
	display: block;
	padding: 0 18px 0 0;
	height: 25px;
}

.category-nav .nav-parent > span {
	cursor: default;
	padding-right: 0;
}

.category-nav:hover .nav-parent a,
.category-nav:hover .nav-parent > span {
	opacity: 0.5;
}

.category-nav .nav-parent a strong,
.category-nav .nav-parent > span strong {
	border-bottom: 1px solid #FFFFFF;
	font-size: 16px;
	letter-spacing: 0.06em;
}

.category-nav.home .nav-parent a strong {
	font-size: 12px;
	letter-spacing: 0.08em;
}

.category-nav:hover .nav-parent a strong,
.category-nav.active .nav-parent a strong,
.category-nav:hover .nav-parent > span strong,
.category-nav.active .nav-parent > span strong {
	border-bottom: 1px solid #AEB9CA;
}

.nav-child {
	position: absolute;
	top: 15px;
	left: -15px;
	padding-top: 15px;
	white-space: nowrap;
	transition: .3s cubic-bezier(0.165, 0.84, 0.44, 1);
	visibility: hidden;
	pointer-events: none;
	opacity: 0;
	z-index: 0;
}

.wrap.tablet .category-nav.parent .nav-parent > a {
	pointer-events: none;
}

.category-nav.parent:hover .nav-child {
	top: 25px;
	visibility: visible;
	pointer-events: auto;
	opacity: 1;
}

.nav-child .inner {
	box-sizing: border-box;
	background: #2C4467;
	box-shadow: 2px 2px 6px 0 rgba(0,0,0,0.12);
	border-radius: 3px;
	min-width: 140px;
	padding: 9px 12px 6px;
}

.nav-child a {
	display: block;
	border-bottom: 1px solid rgba(255,255,255,0.1);
	padding: 12px 16px 12px 7px;
	transition: .1s linear;
}

.nav-child a:last-of-type {
	border-bottom: none;
}

.nav-child a.child-parent { display: none; }
.wrap.tablet .nav-child a.child-parent { display: block; }

.nav-child a strong {
	display: inline-block;
	color: #FFFFFF;
/* 	font-weight: 500; */
	line-height: 1;
	letter-spacing: 0.06em;
	font-size: 14px;
}

.nav-child .uppercase a strong {
	text-transform: uppercase;
}




/* .cart-check
---------------------------------------------------------------------------*/
/*
.cart-check {
	position: fixed;
	bottom: 0;
	right: 0;
	text-align: center;
	z-index: 10000;
}

.cart-check-btn {
	position: relative;
	width: 44px;
	height: 44px;
	cursor: pointer;
}

.cart-check-btn i {
	box-sizing: border-box;
	border: 1px solid #E7E7E7;
	border-radius: 50%;
	width: 12px;
	height: 12px;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%,-50%) !important;
	transition: .1s ease-out;
}

.cart-check-btn:hover i {
	background-color: #E7E7E7;
}
*/

/* .cart-check cart-js
------------------------------------*/
/*
.item-list li .cartjs .cartjs_cart_in,
.item-list li .cartjs .cartjs_product_num {
	display: none !important;
}

.item-list li .cartjs .cartjs_product_name {
	display: block;
	margin-bottom: -7px;
	font-size: 13px;
	line-height: 1.6;
	letter-spacing: 0em;
}

.item-list li .cartjs .cartjs_sales_price td {
	padding-bottom: 10px;
	font-size: 16px;
}

.item-list li .cartjs .cartjs_sales_price td:before {
	top: -3px;
	right: -12px;
	font-size: 14px;
}

.item-list li .cartjs .cartjs_sales_price td:after {
	top: 3px;
	right: -50px;
	font-size: 13px;
}

.item-list li .cartjs .cartjs_stock th,
.item-list li .cartjs .cartjs_stock td {
	font-size: 13px;
	font-weight: normal;
}

.item-list li .cartjs .cartjs_stock td {
	transform: translateX(-14px);
}

.wrap.check-on .item-list li .cartjs {
	width: auto;
	height: auto;
	margin: 0 0 15px;
	pointer-events: auto;
	z-index: 0;
	opacity: 1;
}
*/

/* .cart-check-wordpress
------------------------------------*/
/*
.cart-check-wordpress {
	display: none;
}

.wrap.check-on .cart-check-wordpress {
	display: block;
	margin: 30px 0 7px;
}

.wrap.check-on .cart-check-wordpress > div {
	position: relative;
	margin-bottom: 19px;
	padding-bottom: 22px;
}

.wrap.check-on .cart-check-wordpress > div:after {
	display: block;
	content: '';
	position: absolute;
	bottom: 0;
	left: 0;
	background-color: #335273;
	width: 20px;
	height: 1px;
	opacity: 0.5;
}

.wrap.check-on .cart-check-wordpress h4 {
	margin-bottom: 5px;
	font-size: 11px;
	line-height: 1.6;
	letter-spacing: 0.06em;
}

.wrap.check-on .cart-check-wordpress h5 {
	margin-bottom: 4px;
	font-size: 13px;
	line-height: 1.6;
	letter-spacing: 0em;
}

.wrap.check-on .cart-check-wordpress h6 {
	font-size: 12px;
	letter-spacing: 0.1em;
}

.wrap.check-on .cart-check-wordpress h6 i { display: none; font-size: 14px; }
.wrap.check-on .cart-check-wordpress h6.ok i.ok { display: inline-block; }
.wrap.check-on .cart-check-wordpress h6.ng i.ng { display: inline-block; color: #C00; }
*/


/* .modal-onlineshop-stop
---------------------------------------------------------------------------*/
.modal-onlineshop-stop {
	display: none;
	position: fixed;
	top: 0;
	left: 0;
	background: rgba(217,217,217,0.7);
	width: 100%;
	height: 100vh;
	z-index: 11000;
	opacity: 0;
}

.modal-onlineshop-stop .inner,
.modal-onlineshop-stop .inner a {
	color: #EEF2F7;
}

.modal-onlineshop-stop .inner {
	display: block;
	position: absolute;
	top: 35px;
	left: 35px;
	box-sizing: border-box;
	background-color: #173054;
	width: 540px;
	padding: 22px 22px 25px;
	opacity: 0;
}

.modal-onlineshop-stop .inner h2 {
	margin-bottom: 5px;
	font-size: 17px;
	line-height: 1.7;
	letter-spacing: 0.06em;
}

.modal-onlineshop-stop .inner p {
	font-size: 14px;
	line-height: 1.8;
	letter-spacing: 0.09em;
	text-align: justify;
}

.modal-onlineshop-stop .inner p a {
	text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 0.1em;
}

.modal-onlineshop-stop .inner button {
	margin: 14px 0 0;
	transition: .15s ease-out;
}

.modal-onlineshop-stop .inner button:hover {
	opacity: 0.8;
}

.modal-onlineshop-stop .inner button i {
	display: inline-block;
	margin-right: 14px;
	transform: translateY(2px);
}

.modal-onlineshop-stop .inner button span {
	font-size: 15.5px;
	font-weight: 500;
	letter-spacing: 0.18em;
	text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 0.1em;
}