/*****************************
 *共通仕様
*****************************/
.title {
	margin:0.5rem 0;
}
section #introduction {
	margin-bottom:2rem;
}
section .product {
	background:#E8E3E3;
	padding:1rem;
}
.title h3 {
	position: relative;
	display:flex;
	font-size:150%;
	line-height:1;
	padding:0 0 0.5rem 0;
}
.title h3:after {
	position: absolute;
	bottom: -4px;
	left: 0;
	content: '';
	height: 4px;
	width: 100%;
	background: -webkit-repeating-linear-gradient(45deg, #fff, #fff 2px, #aaa 2px, #aaa 4px);
	background: repeating-linear-gradient(45deg, #fff, #fff 2px, #aaa 2px, #aaa 4px);
}
.title h3 + * {
	padding-top:0.5rem;
}
.title h3 span:last-of-type {
	margin-left:0.5em;
	font-size:80%;
}
.product_img {
	margin:0.5rem 0;
	position:relative;
	height: 390px;
	background: #ffffff;
}
.product_img {
	height:100%;
	width:auto;
}
.product_img p:first-of-type {
	display:block;
	position:absolute;
	top:0;
	left:0;
	width:100%;
	padding:0.5rem;
	background-color:rgba(0,0,0,0.2);
	color:#ffffff;
	font-weight:bold;
	font-size:130%;
}
.product_img p:nth-of-type(2) {
	display:block;
	position:absolute;
	bottom:0.5rem;
	right:0.5rem;
	font-size:70%;
	color:#fff;
	text-shadow:
 #222 1px 0px,  #222 -1px 0px,  #222 0px -1px,  #222 0px 1px,  #222 1px 1px,  #222 -1px 1px,  #222 1px -1px,  #222 -1px -1px,  #222 1px 1px,  #222 -1px 1px,  #222 1px -1px,  #222 -1px -1px,  #222 1px 1px,  #222 -1px 1px,  #222 1px -1px,  #222 -1px -1px;
}
.product_img p:nth-of-type(2):before {
	content:"使用色：";
}
.colo_vari > p {
	display:inline-block;
	display:flex;
	justify-content:space-between;
}
.colo_vari > p span:last-child {
	font-size:75%;
}
.pattern {
	display:inline-block;
	display:flex;
	flex-wrap:wrap;
	justify-content:flex-start;
	margin-bottom:1rem;
	padding:0.5rem 0;
	-webkit-border-radius: 0 0 1rem 1rem / 0 0 1rem 1rem;
	-moz-border-radius: 0 0 1rem 1rem / 0 0 1rem 1rem;
	border-radius: 0 0 1rem 1rem / 0 0 1rem 1rem;
}
label.puSwitch img {
	width:18%;
	height:auto;
}
table, p.c_kakaku02 {
	width:90%;
	margin:0 auto 2rem;
}
/*正方形画像*/
.square {
	position:relative;
}
.square::before {
	padding-top:100%;
	display:block;
	content:"";
}
.square > * {
	position:absolute;
}
/*ページ内リンク用接写インデックス*/
.index {
	display:inline-block;
	display:flex;
	flex-wrap:wrap;
	border:solid 1px #999966;
}
.index > * {
	width:25%;
	display:flex;
}
.index > *:not(:nth-child(4n)) {
 border-right:solid 1px #999966;
}
.index > *:last-child, .index > *:nth-last-child(2), .index > *:nth-last-child(3), .index > *:nth-last-child(4) {
	border-top:solid 1px #999966;
}
.index {
	margin-bottom:5rem;
}
.index > div {
	align-items:center;
	justify-content:center;
	background:#CCC;
	padding:0.5rem;
	font-size:110%;
	font-weight:bold;
}
.index > a {
	align-items:center;
	background:#000;
}
.index > a img {
	top:0;
	bottom:0;
	left:0;
	right:0;
}
.index > a:hover img {
	opacity:0.5;
}
.index > a p {
	display:block;
	bottom:0;
	left:0;
	width:100%;
	padding:0.5rem;
	background:rgba(0,0,0,0.5);
	color:#fff;
	font-weight:bold;
}
/*カラバリ・価格表タイトル*/
.plus_info > .title {
	font-weight: bold;
	margin: 1rem 0;
	padding: 0.5rem;
	border-top: #444 double 3px;
	border-bottom: #444 double 3px;
	font-size: 120%;
	background: #ddd;
}
.plus_info > .title span.tiny {
	font-size:80%;
	font-weight:normal;
}
/*商品内色分け用*/
.color {
	margin-bottom:2rem;
}
.color .title {
	display:inline;
	margin: 0.5rem 0;
	padding: 0.2rem;
	font-weight: bold;
	border: #888 solid 1px;
}
/*価格表示*/
.price_table dl {
	display:inline-block;
	display:flex;
	align-items:center;
	font-size:150%;
	font-weight:bold;
	width:40%;
}
.price_table dd {
	color:#2d6f4e;
}
.price_table dl:first-of-type dt {
	width:5rem;
}
.price_table dl:first-of-type dd {
	width:calc(100% - 5rem);
}
.price_table dl:last-of-type dt {
	width:4rem;
}
.price_table dl:last-of-type dd {
	width:calc(100% - 4rem);
}
.label_box {
	display: block;
	margin-bottom:1rem;
	line-height: 2rem;
	padding:0.5rem;
}
/*接写付商品紹介文（天然イ草で使用）*/
.outline {
	align-items:flex-start;
	justify-content:space-between;
	padding-top:1rem;
}
.outline .square {
	width:25%;
}
.outline .square img {
	width:100%;
	height:100%;
	display:block;
	top:0;
	bottom:0;
	left:0;
	right:0;
}
.outline .square + * {
	width:calc(75% - 0.5rem);
}
/******************************
価格表
******************************/
.price_table table {
	width:100%;
}
.price_table table, .price_table table th, .price_table table td {
	border-collapse: collapse;
	border: 1px solid #ccc;
	box-sizing:border-box;
}
.price_table table th, .price_table table td {
	padding:0.5rem;
	text-align:center;
}
.price_table table th {
	background:#DCDCCD;
}
.price_table table td {
	background:#F1F3E9;
}
.price_table table col:first-of-type {
	width:12%;
}
.jou1 .price_table table col:not(:first-of-type) {
	width:26%;
}
.hanjo .price_table table col:not(:first-of-type) {
	width:22%;
}
/*****************************
 *史・季・彩・再
*****************************/
.shikisaisai {
	background:#fff;
	padding:1rem;
	margin:1rem 0;
}
.shikisaisai > p {
	font-weight:bold;
	font-size:110%;
	border-top:dotted 1px #000000;
	border-bottom:dotted 1px #000000;
	margin-bottom:0.5rem;
	padding:0.2rem 0;
}
.shikisaisai > div {
	display:inline-block;
	display:flex;
}
.shikisaisai img {
	width:80px;
	margin-right:0.5rem;
}
.shikisaisai .text {
	width:calc(100% - 80px - 0.5rem);
}
.shikisaisai .text p.title {
	font-weight:bold;
}
/*****************************
 *ポップアップウィンドウ
*****************************/
.popUp input { /* ラジオボックス非表示 */
	display: none;
}
.popUp > label:first-of-type {
	cursor: pointer;
}
.puWindow { /* 初期設定 ポップアップ非表示 */
	display: none;
}
.popUp > input:nth-child(1):checked + label + input:nth-child(3) + label + input:nth-child(5) + label + .puWindow {/* ラジオ１ チェックでポップアップ表示 */
	display: block;
	z-index: 998;
	position: fixed;
	width: 90%;
	height: 80%;
	border-radius: 20px;
	left: 50%;
	top: 50%;
	margin-top: 30px;
	-webkit-transform: translate(-50%, -50%);
	-ms-transform: translate(-50%, -50%);
	transform: translate(-50%, -50%);
	background: #fff;
	padding: 10px 20px;
	overflow: hidden;
}
@media (min-width: 768px) {/* PCのときはページの真ん中の600x600領域 */
.popUp > input:nth-child(1):checked + label + input:nth-child(3) + label + input:nth-child(5) + label + .puWindow {
	width: 320px;
	height: auto;
	padding: 20px;
}
.popUp > input:nth-child(1):checked + label + input:nth-child(3) + label + input:nth-child(5) + label {
	left: 50% !important;
	top: 50% !important;
	margin-left: 110px !important;
	margin-top: -150px !important;
}
}
.popUp > input:nth-child(1):checked + label + input:nth-child(3) + label + input:nth-child(5) + label + .puWindow > div {/* */
	overflow:auto;
	-webkit-overflow-scrolling:touch;
	display: inline-block;
	width: 100%;
	height: 100%;
}
.popUp > input:nth-child(1):checked + label + input:nth-child(3) + label + input:nth-child(5) + label + .puWindow > div > iframe {
	width: 100%;
	height:100%;
	border:none;
	display:block;
}
.popUp > input:nth-child(1):checked + label + input:nth-child(3) + label + input:nth-child(5) + label + .puWindow > div > img {/* ポップアップの中の要素 */
	max-width: 100%;
}
.popUp > input:nth-child(1) + label ~ label {
 display: none;/* ラジオ１ 以外のラベルを初期は非表示 */
}
.popUp > input:nth-child(1):checked + label + input:nth-child(3) + label {
	width: 100%;
	height: 100%;
	background: rgba(0, 0, 0, 0.70);
	display: block;
	position: fixed;
	left: 0;
	top: 0;
	z-index: 997;
	text-indent: -999999px;
	overflow: hidden;
}
.popUp > input:nth-child(1):checked + label + input:nth-child(3) + label + input:nth-child(5) + label {
	display: inline-block;
	position: fixed;
	left: 10px;
	bottom: 20px;
	z-index: 999;
	width: 40pt;
	height: 33pt;
	font-size: 30px;
	line-height: 44pt;
	text-align: center;
}
.popUp > input:nth-child(1) + label + input:nth-child(3):checked + label + input:nth-child(5) + label + .puWindow, .popUp > input:nth-child(1) + label + input:nth-child(3) + label + input:nth-child(5):checked + label + .puWindow { /* ラジオ２と３ どっちかチェックでポップアップ非表示 */
	display: none;
}
.popUp .modalTitle {
	padding-bottom: .5em;
	margin: .5em 0;
	border-bottom:
 1px solid #ccc;
	font-weight: bold;
}
.popUp .modalMain {
	color:#222;
	text-align: left;
	font-size: 14px;
	line-height: 1.8em;
}
.popUp {
	display:inline-block;
	display:flex;
	justify-content:center;
	align-items:center;
	flex-direction:column;
	width:18%;
	margin-bottom:1.5rem;
}
.popUp:not(:nth-of-type(5n)) {
 margin-right:2.5%;
}
.popUp > label:first-of-type {
	position:relative;
	display:block;
	overflow:hidden;
	width:100%;
	height:100%;
}
.popUp > label:first-of-type p.color_name {
	position: absolute;
	bottom: 0;
	background: rgba(255,255,255,0.5);
	padding: 0.2rem;
	margin: 0;
	width: 100%;
	font-size: 75%;
}
.popUp > label:first-of-type:hover {
	opacity:0.5;
}
.modalPopup3 img {
	width:280px;
	height:auto;
}
/******************************
 タブ切り替え
******************************/
/*ラジオボタンを全て消す*/
input[name="tab_label"] {
	display: none;
}
/*タブ切り替え全体のスタイル*/
.tabs {
	margin-top: 50px;
}
/*タブ横並べ*/
.labels, .tab_label {
	display:inline-block;
	display:flex;
	justify-content:center;
	align-items:center;
}
label.tab_label:hover {
	opacity: 0.75;
}
/*タブ切り替えの中身のスタイル*/
.tab_panel {
	display: none;
	clear: both;
	overflow: hidden;
}
/*選択されているタブのコンテンツのみを表示*/
#tab01:checked ~ #tab01_panel, #tab02:checked ~ #tab02_panel, #tab03:checked ~ #tab03_panel {
 display: block;
}
/******************************
 ドロップボタンバー
******************************/
/*input*/
.switch_input {
	display: none;
}
/*ラベル*/
.switch_btn {
	position: relative;
	display: inline-block;
	display:flex;
	align-items:center;
	width:20%;
	height:4rem;
	border-radius:0.5rem;
	color: #2d6f4e;
	border: #2d6f4e solid 1px;
	line-height: 1;
	cursor :pointer;
	font-weight: bold;
	-webkit-transition: all 0.3s;
	-moz-transition: all 0.3s;
	transition: all 0.3s;
}
/*ラベル内文字*/
.switch_btn span {
	display:inline-block;
	display:flex;
	align-items:center;
	justify-content:center;
	width:calc(100% - 3rem);
	height:100%;
	padding:0.5rem;
}
/*ラベル噴出し*/
.switch_btn::before {
	display:inline-block;
	display:flex;
	justify-content:center;
	align-items:center;
	height: 100%;
	width: 3rem;
	font-family: 'FontAwesome';
	content: "\f1ec";
	font-size: 140%;
	background: #2d6f4e;
	color: #fff;
	border-top-left-radius : 0.3rem;
	border-bottom-left-radius : 0.3rem;
}
.switch_btn:after {
	position: absolute;
	left: 3rem;
	top: 50%;
	z-index: 1;
	content: '';
	width: 1rem;
	height: 1rem;
	margin: -0.5rem 0 0 -0.5rem;
	background: #2d6f4e;
	-webkit-transition: all 0.3s;
	-moz-transition: all 0.3s;
	transition: all 0.3s;
	-webkit-transform: rotate(45deg);
	-moz-transform: rotate(45deg);
	-ms-transform: rotate(45deg);
	transform: rotate(45deg);
}
.switch_btn:hover {
	background:#2d6f4e;
	color:#fff;
}
.switch_input:checked + .switch_btn::before {
	content:"▲";
}
/*パネル*/
.switch_panel {
	display:none;
	height: 0;
	padding:1rem;
}
.switch_input:checked + .switch_panel {
	display:block;
	height: auto;
	-webkit-border-radius: 0 0 1rem 1rem / 0 0 1rem 1rem;
	-moz-border-radius: 0 0 1rem 1rem / 0 0 1rem 1rem;
	border-radius: 0 0 1rem 1rem / 0 0 1rem 1rem;
}
/*****************************
直文字ドロップダウン
*****************************/
/*input*/
.accordion_input {
	display: none;
}
/*ラベル*/
.accordion_label {
	display: inline-block;
	display: flex;
	align-items: center;
	width:100%;
	height: 3rem;
	padding: 0.5rem;
	background: #2d6f4e;
	color: #ffffff;
	line-height: 1;
	cursor: pointer;
	border-radius: 1rem;
	-webkit-border-radius: 1rem;
	-moz-border-radius: 1rem;
	line-height: 2rem;
}
.accordion_label:hover {
	background: #E4EBE2;
	color: #2d6f4e;
	border:solid 1px #2d6f4e;
}
.accordion_input:checked + .accordion_label {
	border-radius: 1rem 1rem 0 0 / 1rem 1rem 0 0;
	-webkit-border-radius: 1rem 1rem 0 0 / 1rem 1rem 0 0;
	-moz-border-radius: 1rem 1rem 0 0 / 1rem 1rem 0 0;
}
.accordion_label::before {
	content: "▼";
	font-family: FontAwesome;
	padding-right: 0.5rem;
	background:none;
}
.accordion_input:checked + .accordion_label:hover::before {
	content: "▲";
}
/*パネル*/
.accordion_panel {
	display:none;
	height: auto;
	padding:1rem;
	border-left:solid 1px #2d6f4e;
	border-rightt:solid 1px #2d6f4e;
	border-bottom:solid 1px #2d6f4e;
	-webkit-border-radius: 0 0 1rem 1rem / 0 0 1rem 1rem;
	-moz-border-radius: 0 0 1rem 1rem / 0 0 1rem 1rem;
	border-radius: 0 0 1rem 1rem / 0 0 1rem 1rem;
}
.accordion_input:checked + .accordion_label + .accordion_panel {
	display:block;
}