@charset "utf-8";
/* CSS Document */

/*===================================
	.comms.block01
=====================================*/

.comms.block01{
	padding: 58px 0 114px;
}

.comms.block01.bg-color{
	padding: 98px 0 128px;
	background: #fffbee;
	margin-bottom: 140px;
	position: relative;
}

/* ── 上の装飾（29pxはみ出す） ── */
.comms.block01.bg-color::before {
    content: '';
    position: absolute;
    
    /* 天辺から29px上に配置 */
    top: -29px; 
    left: 50%;
    width: 100vw;
    height: 68px; /* 円の直径 */
    transform: translateX(-50%);
    z-index: -1;

    background-image: radial-gradient(#fffbee 70%, transparent 71%);
    background-size: 68px 68px;
    background-repeat: repeat-x;
    background-position: center top;
}

/* ── 下の装飾（42pxはみ出す） ── */
.comms.block01.bg-color::after {
    content: '';
    position: absolute;
    
    /* 底辺から42px下に配置 */
    bottom: -42px; 
    left: 50%;
    width: 100vw;
    height: 68px; /* 円の直径 */
    transform: translateX(-50%);
    z-index: -1;

    background-image: radial-gradient(#fffbee 70%, transparent 71%);
    background-size: 68px 68px;
    background-repeat: repeat-x;
    background-position: center top; 
}

.comms.block01 .sec-inner p{
	font-size: 100%;
	line-height: 1.88;
	letter-spacing: 0.05em;
	text-align: justify;
	color: #333333;
}

.comms.block01 .sec-inner p.center{
	text-align: center;
}

.comms.block01 .sec-inner p.large_txt{
	font-size: 125%;/*20*/
	line-height: 1.5;
	letter-spacing: 0.05em;
	color: #754c24;
	text-align: justify;
}

.comms.block01 .sec-inner p.large_txt.center{
	text-align: center;
}

.comms.block01 .sec-inner p{
	width: 100%;
	max-width: 1000px;
	margin: 0 auto;
}

.comms.block01 .sec-inner p a{
	color: #0056b3;
	text-decoration: underline;
}

/**/

.comms.block01 .sec-inner .large_img{
	width: 50.36%;/*554*/
	margin: 0 auto;
}

.comms.block01 .sec-inner .large_img img{
	width: 100%;
	height: auto;
}

/**/

.comms.block01 .sec-inner .check_list_btn{
	width: 61.82%;/*680*/
	margin: 0 auto;
	position: relative;
}

.comms.block01 .sec-inner .check_list_btn::before{
	content: '';
	background: url("../images/comms/checklist_shadow.webp")no-repeat;
	background-size: 100% auto;
	width: 119.85%;/*815*/
	height: auto;
	aspect-ratio: 815 / 224;
	position: absolute;
	top: calc(50% + 7px);
	left: 50%;
	transform: translate(-50%, -50%);
	z-index: -1;
}

.comms.block01 .sec-inner .check_list_btn a{
	display: flex;
	align-items: center;
	width: 100%;
	height: 125px;
	border-radius: 20px;
	background-image: url("../images/common/link_ico_col06.svg");
	background-repeat: no-repeat;
	background-size: 5.15% auto;/*35*/
	background-position: right 4.71% center;/*32*/
	background-color: #fff;
	font-size: 143.75%;/*23*/
	line-height: 1.24;
	color: #333333;
	text-decoration: none;
	padding-left: 26.47%;/*180*/
	box-sizing: border-box;
	box-shadow: 0 0 10px rgba(0, 0, 0, 0.15);	
	position: relative;
}

.comms.block01 .sec-inner .check_list_btn a::before{
	content: '';
	background: url("../images/comms/checklist_ico.webp")no-repeat;
	background-size: 100% auto;
	width: 18.24%;/*124*/
	height: auto;
	aspect-ratio: 124 / 78;
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	left: 4.41%;/*30*/
	z-index: 1;
}

.comms.block01 .sec-inner .check_list_btn a::after{
	content: '';
	border: 3px solid #f28e1e;
	width: 100%;
	height: 100%;
	border-radius: 20px;
	box-sizing: border-box;
	pointer-events: none;
	position: absolute;
	top: 0;
	left: 0;
	z-index: 10;
/* ★追加：最初は透明にする */
	opacity: 0;
	/* ★追加：0.3秒かけてふんわり変化させる設定（時間は好みで調整してください） */
	transition: opacity 0.3s ease;
}

/* 2. ホバー時：articleがホバーされたら、::after を表示する */
.comms.block01 .sec-inner .check_list_btn a:hover::after,
.comms.block01 .sec-inner .check_list_btn a:focus-within::after {
	opacity: 1;
}

.comms.block01 .sec-inner .check_list_btn a:hover,
.comms.block01 .sec-inner .check_list_btn a:focus-within {
	opacity: 1;
}

.comms.block01 .sec-inner .check_list_btn a p{
	line-height: 1.24;
}

/**/

.comms.block01 .sec-inner .comms_list{
	list-style: none;
	width: 90.91%;/*1000*/
	margin: 0 auto;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	gap: 43px 0;
	position: relative;
	z-index: 1;
}

.comms.block01 .sec-inner .comms_list::before{
	content: '';
	background: url("../images/comms/cl_shadow.webp")no-repeat;
	background-size: 100% auto;
	width: 101.2%;
	height: auto;
	aspect-ratio: 1012 / 390;
	position: absolute;
	top: 64px;
	left: 2.75%;
	z-index: -1;
}

.comms.block01 .sec-inner .comms_list .list01{
	width: 47.3%;
}

.comms.block01 .sec-inner .comms_list .list01 a{
	display: block;
	width: 100%;
	height: auto;
	aspect-ratio: 473 / 247;
	background: #fff;
	border-radius: 20px;
	box-shadow: 0 0 10px rgba(0, 0, 0, 0.15);
	padding: 11px 0 21px;
	box-sizing: border-box;
	text-decoration: none;
	position: relative;
}

.comms.block01 .sec-inner .comms_list .list01 a::after{
	content: '';
	border: 3px solid #f28e1e;
	width: 100%;
	height: 100%;
	border-radius: 20px;
	box-sizing: border-box;
	pointer-events: none;
	position: absolute;
	top: 0;
	left: 0;
	z-index: 10;
/* ★追加：最初は透明にする */
	opacity: 0;
	/* ★追加：0.3秒かけてふんわり変化させる設定（時間は好みで調整してください） */
	transition: opacity 0.3s ease;
}

/* 2. ホバー時：articleがホバーされたら、::after を表示する */
.comms.block01 .sec-inner .comms_list .list01 a:hover::after,
.comms.block01 .sec-inner .comms_list .list01 a:focus-within::after {
	opacity: 1;
}

.comms.block01 .sec-inner .comms_list .list01 a:hover,
.comms.block01 .sec-inner .comms_list .list01 a:focus-within {
	opacity: 1;
}


.comms.block01 .sec-inner .comms_list .list01 a p.link_head{
	display: flex;
	align-items: center;
	width: 86.68%;/*410*/
	height: 106px;
	padding-left: 45.24%;/*213*/
	border-bottom: 1px solid #00a498;
	box-sizing: border-box;
	font-size: 143.75%;/*23*/
	line-height: 1.24;
	color: #333333;
	margin: 0 auto;
	background-image: url("../images/common/link_ico_col06.svg");
	background-repeat: no-repeat;
	background-position: right center;
	background-size: 8.54% auto;/*35*/
	position: relative;
}

.comms.block01 .sec-inner .comms_list .list01:nth-child(2) a p.link_head{
	padding-left: 42.92%;/*203*/
}

.comms.block01 .sec-inner .comms_list .list01:nth-child(3) a p.link_head{
	padding-left: 47.15%;/*223*/
}

.comms.block01 .sec-inner .comms_list .list01:nth-child(4) a p.link_head{
	padding-left: 25.79%;/*122*/
	padding-right: 7.82%;/*37*/
	text-align: center;
}

.comms.block01 .sec-inner .comms_list .list01 a p.link_head::before{
	content: '';
	background: url("../images/comms/comms_ico01.webp")no-repeat;
	background-size: 100% auto;
	width: 23.90%;/*98*/
	height: auto;
	aspect-ratio: 98 / 82;
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	left: 3.66%;/*15*/
	z-index: 1;
}

.comms.block01 .sec-inner .comms_list .list01:nth-child(2) a p.link_head::before{
	background: url("../images/comms/comms_ico02.webp")no-repeat;
	background-size: 100% auto;
}

.comms.block01 .sec-inner .comms_list .list01:nth-child(3) a p.link_head::before{
	background: url("../images/comms/comms_ico03.webp")no-repeat;
	background-size: 100% auto;
}

.comms.block01 .sec-inner .comms_list .list01:nth-child(4) a p.link_head::before{
	background: url("../images/comms/comms_ico04.webp")no-repeat;
	background-size: 100% auto;
}

.comms.block01 .sec-inner .comms_list .list01 a p.link_txt{
	padding: 21px 10.57% 0;/*45*/
	box-sizing: border-box;
}