/* おしゃれ看板特集ページ用 CSS */
.bg-beige{
  background:#E6E5E4;  /* ベースカラー */
}
.bg-brown{
  background:#769CBF;  /* アクセントカラー */
}
.bg-brown a{ color:#fff; }

.visually-hidden {
	position: absolute;
	width: 1px;
	height: 1px;
	margin: -1px;
	padding: 0;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
}

#osharesign{
	h1, h2, h3{
		margin:0;
		padding:0;
		background:none;
		border:none;
		&::after{
			content:none;
		}
	}
	h2{
		text-align:center;
	}

    /* ▼ ここに追加 ▼ */
	#select-wrap p.title {
  font-family: "Hiragino Mincho ProN","Hiragino Mincho Pro",
               "游明朝","Yu Mincho","MS PMincho",serif;
  font-weight: 600;
  letter-spacing: 0.05em;
  line-height: 1.4;
}

    h3 {
      font-family: "Hiragino Mincho ProN", "Hiragino Mincho Pro",
                   "游明朝", "Yu Mincho", "MS PMincho", serif;
      font-weight: 600;
      letter-spacing: 0.05em;
    }

/* おしゃれ看板カテゴリー見出しとリストを明朝に */
#select-wrap h2,
#select-wrap h3 {
  font-family: "Hiragino Mincho ProN", "Hiragino Mincho Pro",
               "游明朝", "Yu Mincho", "MS PMincho", serif;
  font-weight: 600; /* 見出しはやや細め */
  letter-spacing: 0.05em;
}


    /* ▲ ここまで ▲ */

	.border-dashed{
		padding-bottom:40px;
		background:url(../img/page/cafesign/line_dashed.png) repeat-x left bottom;
		margin-bottom:40px;
	}
	#select-wrap{
		.menu-list{
			display:flex;
			flex-wrap: wrap; 
			a{
				display:block;
				border:1px solid #769CBF;
				text-align:center;
				padding:8px;
				color:#769CBF;
				background-color:#fff;
				font-family:"Hiragino Mincho ProN","Hiragino Mincho Pro","游明朝","Yu Mincho","MS PMincho",serif;
				font-weight:700;
				letter-spacing:0.05em;
				transition: background-color .25s ease, color .25s ease, border-color .25s ease;
				text-decoration:none;
				width:100%;
				height:100%;
				&:hover{
					color:#ffffff;
					background-color:#769CBF;
					border-color:#769CBF;

				}
			}
		}
	}
	#merit-wrap{
		h3{
			img{
				vertical-align:middle;
			}
		}
		.intro-merit{
  		background:url(../img/page/osyaresign/img_cafe.png) no-repeat;
		}
		.merit-group{
			position:relative;
			&::before,&::after{
				content:"";
				position:absolute;
				height:2px;
				width:100%;
				background:url(../img/page/cafesign/line_dashed.png) repeat-x left bottom;
				left:0;
			}
			&::before{
				top:0
			}
			&::after{
				bottom:0
			}
			padding-top:40px;
			margin-top:40px;
			padding-bottom:40px;
			margin-bottom:40px;
		}
	 /* ▼ ここに追加 ▼ */
    .list-merit {
      margin-top: 20px; /* リストの前に余白 */
    }
    /* ▲ ここまで ▲ */

	}
	#design-wrap{
		h3{
			img{
				vertical-align:middle;
			}
		}
		.design-group{
			color:#25271F;
		}
	}
	.pickup-group{
		h3{
			background:#769CBF;
			text-align:center;
			color:#fff;
		}
	}
	
	  /* ▼ ここに追加：特集 → まとめ の間隔 ▼ */
  #summary-wrap{
    margin-top: 64px;
  }
  /* ▲ ここまで ▲ */

}
.pickup-group{
	.list-tag{
		display:flex;
		flex-wrap:wrap;
		margin-bottom:10px;
		li{
			white-space: nowrap;
			border:1px solid #769CBF;
			&::before {
				content: '#';
			}
		}
	}
	.lead-product{
		.title{
			font-weight:bold;
			margin-bottom:15px;
			line-height:1.5;
			a{
				text-decoration:none;
				color:#769CBF;
				&:hover{
					text-decoration:underline;
				}
			}
		}
		.list-tag{
			gap:10px;
			li{
				font-size:15px;
				padding: 2px 10px;
			}
		}
		.label-price{
			background:#769CBF;
			color:#fff;
			font-weight:normal;
			min-width:auto;
			padding:0 5px 0 15px;
			margin-right:40px;
			height:22px;
			line-height: 22px;
			display:inline-block;
			position:relative;
			&::before,
			&::after {
			    position: absolute;
			    right: -15px;
			    width: 50%;
			    height: 50%;
			    background: #769CBF;
			    content: '';
			    z-index: -1;
			}
			&::before {
			    top: 50%;
			    transform: skew(-45deg);
			}
			&::after {
			    top: 0;
			    transform: skew(45deg);
			}
		}
		.btn-detail{
			display:block;
			color:#769CBF;
			font-weight:bold;
			border-bottom:2px solid #769CBF;
			text-decoration:none;
			padding:10px 20px 5px;
			background-image:url(../img/page/osyaresign/ico_arr.png);
			background-repeat:no-repeat;
			background-position:right 10px center;
			&:hover{
				color:#fff;
				background-color:#769CBF;
				background-image:url(../img/page/osyaresign/ico_arr_o.png);
			}
		}
	}
	.list-product{
		display:flex;
		flex-wrap:wrap;
		a{
			color:#000;
			text-decoration:none;
			.img-top{
				text-align:center;
			}
			.tit-product{
				font-weight:bold;
				white-space: nowrap;
				overflow: hidden;
				text-overflow: ellipsis;
				line-height:1.2;
			}
			.list-tag{
				gap:6px;
				li{
					font-size:11px;
					padding: 0 6px;
				}
			}
			.price{
				color:#818181;
				font-size:16px;
				.label-price{
					position:relative;
					&::after {
						content:"：";
					}
				}
				.text-zei{
					font-size:12px;
				}
			}
			&:hover{
				.tit-product, .price{
					text-decoration:underline;
				}
			}
		}
	}
}
#osharesign .oshare_btn {
    display: block;
    border: 1px solid #769CBF;
    text-align: center;
    padding: 8px;
    color: #769CBF;
    background: #fff;
    font-weight: bold;
    text-decoration: none;
    width: 100%;
    height: 100%;
    max-width: 600px; /* 最大幅を600pxに設定 */
    margin: 0 auto; /* 左右のマージンを自動にして中央に配置 */
}

#osharesign .oshare_btn:hover {
    color: #ffffff;
    background: #769CBF;
}

/* ----- スマホ向け ----- */
@media only screen and (max-width: 575px){
	#osharesign{
		font-size:16px;
		.bg-beige{
			padding:30px 20px 40px;
		}
		.bg-brown{
			padding:40px 10px;
		}
		h3{
			font-size:22px;
			padding-left:32px;
			text-indent:-32px;
			img{
				width:32px;
				padding-right:5px;
			}
		}
		#select-wrap{
			font-size:18px;
			.menu-list{
				li{
					width:100%;
				}
				li+li{
					margin-top:15px;
				}
			}
		}
		#merit-wrap{
			.intro-merit{
				padding:0 10px 220px;
				background-position:center bottom 20px;
			}
			.merit-group{
				padding:40px 10px;
			}
		}
		.card{
			& + .card{
				margin-top:80px;
			}
			.img-top{
				text-align:center;
				margin-bottom:10px;
				img{
					width:200px;
				}
			}
		}
		.pickup-group{
			h3{
				font-size:24px;
				padding:10px;
			}
		}
	}
	.pickup-group{
		.lead-product{
			.btn-detail{
				background-size:28px 28px;
			}
		}
		.list-product{
			gap:20px;
			.card-product{
				width:calc(50% - 10px);
				.label-price{
					display:none;
				}
			}
		}
	}
}

/* ----- タブレット向け ----- */
@media only screen and (min-width:576px) and (max-width: 1023px){
	#osharesign{
		font-size:18px;
		.bg-beige{
			padding:40px 20px 60px;
		}
		.bg-brown{
			padding:60px 0;
		}
		h3{
			font-size:28px;
			padding-left:40px;
			text-indent:-40px;
			img{
				width:40px;
				padding-right:8px;
			}
		}
		#select-wrap{
			font-size:20px;
			.menu-list{
				gap:20px;
				li{
					width:calc(50% - 10px);
				}
			}
		}
		#merit-wrap{
			.intro-merit{
				padding:0 60px 240px;
				background-position:center bottom 40px;
			}
			.merit-group{
				padding:60px;
			}
		}
		.intro{
			padding-left:20px;
			padding-right:20px;
		}
		.card{
			display:flex;
			align-items: center;
			& + .card{
				margin-top:40px;
			}
		}
		.pickup-group{
			h3{
				font-size:42px;
				padding:20px;
			}
		}
	}
	.pickup-group{
		.lead-product{
			.img-top, .card-body{
				flex:1;
			}
			.btn-detail{
				background-size:28px 28px;
			}
		}
		.list-product{
			gap:20px;
			.card-product{
				width:30%;
				.tit-product{
					font-size:14px;
				}
				.label-price{
					display:none;
				}
			}
		}
	}
}

/* ----- PC向け ----- */
@media only screen and (min-width:1024px){
	#osharesign{
		font-size:20px;
		.bg-beige{
			padding:50px 0 80px;
		}
		.bg-brown{
			padding:80px 0;
		}
		h3{
			font-size:32px;
			img{
				padding-right:10px;
			}
		}
		#select-wrap{
			font-size:24px;
			.menu-list{
				gap:20px;
				li{
					width:calc(50% - 10px);
				}
			}
		}
		#merit-wrap{
			.intro-merit{
				padding-right:280px;
				background-position:right center;
			}
			.merit-group{
				padding:40px;
			}
		}
		.intro{
			text-align:center;
		}
		.card{
			display:flex;
			align-items: center;
			& + .card{
				margin-top:80px;
			}
		}
		.pickup-group{
			h3{
				font-size:48px;
				padding:30px;
			}
		}
	}
	.pickup-group{
		.lead-product{
			.img-top, .card-body{
				flex:1;
			}
			.title{
				font-size:28px;
			}
			.price{
				font-size:32px;
				.text-zei{
					font-size:15px;
					margin-left:5px;
				}
				.label-price{
					font-size:15px;
				}
			}
			.text-guide{
				font-size:20px;
			}
			.btn-detail{
				font-size:24px;
			}
		}
		.list-product{
			gap:30px;
			.card-product{
				width:30%;
				display:block;
				.tit-product{
					font-size:16px;
				}
			}
		}
	}
}