@media screen and (max-width: 767px) {
  body {
    min-width: unset !important;
  }
}

#main {
  width: 100% !important;
  padding: 0 !important;
}

body {
	font-family:'メイリオ',Meiryo, 'ヒラギノ角ゴシック',"Hiragino Kaku Gothic ProN",sans-serif!important;
	margin:0;
}

.sp {
  display: none !important;
}
@media screen and (max-width: 767px) {
  .sp {
    display: inherit !important;
    }
 .p-mainVisual_text .sp img {
    max-width: 248px;
    width: 100%;
    height: auto;
  } 
}

img{
	width:100%;
	height:auto;
}

@media screen and (max-width: 767px) {
  .pc {
    display: none;
  }
}
img{
	width:100%;
}
a{
	transition:.3s ease;
}


.p-mainVisual {
	height:450px;
	background-image: url(../../images/mv_bg_pc.png);
	background-position:center;
	background-repeat: no-repeat;
	background-size: cover;
	min-width: 1200px;

}
.p-mainVisual_text {
	width:100%;
	max-width:1500px;
	text-align: center;
	margin-left: auto;
	margin-right: auto;
}
@media screen and (max-width: 767px) {
	.p-mainVisual {
		background-image: url(../../images/mv-bg-sp.png);
		background-repeat: no-repeat;
		background-size: cover;
		min-width: 100%;
		height:231px;
		padding-top: 22px;
	}
}
.inner{
	width:88%;
	max-width: 1130px;
	margin: 0 auto;
	box-sizing: border-box;
}
@media screen and (max-width: 767px) {
	.inner{
		max-width: 100%;
		min-width: 100%;
		padding: 0 5%;
	}
}

/* //====================================
//トップセクション
//==================================== */
.p-top {
	min-width:1130px;
	padding-bottom:50px;
	margin-top: -8px;
}

.p-top_text {
	font-size: 20px;
	line-height: 1.8;
	text-align: center;
	letter-spacing: 0.08em;
	margin:20px;
}
.p-top_text span {
	font-weight: bold;
	color:#00AAEB;
	border-bottom:4px solid #ffe00d;
}
@media screen and (max-width: 767px) {
.p-top{
	padding-top: 25px;
	padding-bottom: 20px;
	min-width: 100%;
}
.p-top_text {
	font-size: 15px;
	line-height: 1.7;
}
}
/* //====================================
//検討リストとは？
//==================================== */
.p-top-btn {
  	width: 180px;
	margin: 4px 0 0 auto;
}
.p-top-btn a {
	display: block;
	background: #fff; /* 28変更 */
	width: 100%;
	padding: 5px 0;
	box-sizing: border-box;
	color: #3088f3; /* 28変更 */
	font-size: 16px;
	font-family: 'メイリオ', Meiryo, sans-serif;
	text-align: center;
	text-decoration: none!important;
  transition: 0.3s ease;
	cursor: pointer;
	border-radius:100px; /* 28追加 */
	border:1px solid #b0b0b0; /* 28追加 */
}
.p-top-btn a:hover {
	color: #00aaeb;
  opacity: 0.7;
  filter: alpha(opacity=70);
  -ms-filter: "alpha(opacity=70)";
}
.p-top-btn img {
	display: inline-block;
	vertical-align: top;
	width: 22px;
	margin: 0 5px 0 0;
}
@media screen and (max-width: 767px) {
	.p-top-btn {
		width: 40%;
		min-width:130px;
		margin: 10px 0 0 auto;
	}
	.p-top-btn a {
		font-size: 13px;
	}
	.p-top-btn img {
		width: 20px;
		margin: 0 5px 0 0;
	}
}
/* //====================================
//モーダル
//==================================== */
#modal {
	background: #fff;
	width: 780px;
	margin: 0 auto;
	padding: 40px 70px;
	box-sizing: border-box;
	border: 4px solid #0aa9ea;
	border-radius: 8px;
	position: relative;
}
#modal .modal-title {
	color: #0aa9ea;
	font-size: 22px;
	font-weight: bold;
	letter-spacing: 0.08em;
}
#modal .modal-title img {
	display: inline-block;
	vertical-align: top;
	width: 28px;
	margin: 0 10px 0 0;
}
#modal .modal-block {
	display: flex;
	justify-content: space-between;
	margin: 20px 0 0;
}
#modal .img-box {
	width: 320px;
	box-sizing: border-box;
}
#modal .img-box img {
	width: 100%;
}
#modal .txt-box {
	width: calc(100% - 320px);
	padding: 30px 0 0 30px;
	box-sizing: border-box;
}
#modal .txt {
	font-size: 16px;
	line-height: 1.8;
}
#modal .txt span {
	font-weight: bold;
}
#modal .txt span.underline{
	text-decoration: underline;
}
#modal .txt .u-line {
	text-decoration: underline;
}
@media screen and (max-width: 767px) {
	#modal {
		width: 100%;
		padding: 30px 20px;
		border-radius: 4px;
	}
	#modal .modal-title {
		font-size: 18px;
	}
	#modal .modal-title img {
		width: 26px;
		margin: 0 8px 0 0;
	}
	#modal .modal-block {
		display: block;
		margin: 15px 0 0;
	}
	#modal .img-box {
		width: 80%;
		margin: 0 auto;
	}
	#modal .txt-box {
		width: 100%;
		margin: 10px 0 0;
		padding: 0 0 0 0;
	}
	#modal .txt {
		font-size: 14px;
	}
}

.lity {
	background: rgba(7,22,44,0.7);
}
.lity-close {
	background: url("../../images/close.png") left top no-repeat;
	background-size: 50px auto;
	width: 50px;
	height: 50px;
	position: absolute;
	right: -20px;
	top: -20px;
	font-size: 0;
	line-height: 0;
}
.lity-close:hover,
.lity-close:focus,
.lity-close:active,
.lity-close:visited{
	background: url("../../images/close.png") left top no-repeat;
	background-size: 50px auto;
	width: 50px;
	height: 50px;
	font-size: 0;
	line-height: 0;
}
.lity-close:active{
	top: -20px;
}
@media screen and (max-width: 767px) {
	.lity-container {
		max-width: 100%;
		padding: 30px 20px;
	}
	
	.lity-close {
		background: url("../../images/close.png") left top no-repeat;
		background-size: 30px auto;
		width: 30px;
		height: 30px;
		right: 10px;
		top: 15px;
	}
	.lity-close:hover,
	.lity-close:focus,
	.lity-close:active,
	.lity-close:visited{
		background: url("../../images/close.png") left top no-repeat;
		background-size: 30px auto;
		width: 30px;
		height: 30px;
	}
	.lity-close:active{
		top: 15px;
	}
}

/* //====================================
//コンテンツ
//==================================== */
.p-contents {
	background-color: #F4FAFC;
	width: 100%;
	min-width: 1130px;
	margin: 0 auto;
	padding: 25px 0 121px;
	box-sizing: border-box;
	position: relative;
}
@media screen and (max-width: 767px) {
.p-contents {
	min-width: 100%;
	padding: 15px 0 30px;
}
	
}
/* //====================================
//リンクエリア
//==================================== */
.link-area{
	padding-bottom:60px;
}
.link-area_date{
	display: block;
	text-align: right;
	font-size: 15px;
}
.anchor-links{
	display: flex;
	margin-top: 38px;
	padding-left: 0;
}
.anchor-link:link{
	text-decoration:none!important;
}
.anchor-link{
	background:#fff;
	border:1px solid #00AAEB;
	border-radius:8px;
	position:relative;
	transition:.3s ease;
	list-style: none;
	padding:30px 25px 66px 25px;
	text-decoration:none!important;
	width:calc((100% - 24px * 3) / 4);
	box-sizing:border-box;
}
.anchor-link:not(:first-child){
	margin-left: 24px;
}
.anchor-link:hover{
	background:#fffdee;
	transition:.3s ease;
}
.anchor-link_img{
	height:90px;
	text-align: center;
	display: flex;
	justify-content: center;
}
.anchor-link_img img{
	height:100%;
	width:auto;
}
.anchor-link_title{
	font-size: 22px;
	color:#00AAEB;
	text-align: center;
	font-weight: bold;
	padding-top: 16px;
	letter-spacing:0.08em;
	position:relative;
	line-height:1.4;
	margin:0;
}
.anchor-link_title:after{
	content:'';
	display: block;
	width:40px;
	height:2px;
	border-bottom:2px dashed #FFE00D;
	position:absolute;
	bottom:-17px;
	left:50%;
	transform:translateX(-50%);
}
.anchor-link_detail{
	font-size: 15px;
	letter-spacing:0.08em;
	padding-top: 33px;
	color:#000;
	position: relative;
	line-height:1.6;
	margin:0;
}
.anchor-link:after{
	content:'';
	display: block;
	width:35px;
	height:10px;
	background-image: url(../../images/yellow-arrow.png) ;
	background-repeat: no-repeat ;
	background-position: center ;
	background-attachment: scroll ;
	background-size: cover ;
	position: absolute;
	bottom:36px;
	left:50%;
	transform:translateX(-50%);
}
@media screen and (max-width: 767px) {
	.link-area{
		padding-bottom: 28px;
	}
	.link-area_date{
		font-size: 11px;
	}
	.anchor-links{
		margin-top: 16px;
		flex-wrap:wrap;
	}
	.anchor-link{
		padding:5px 15px 30px 15px;
		width:calc((100% - 12px * 1) / 2);
	}
	.anchor-link:not(:first-child){
		margin-left: initial;
	}
	.anchor-link:nth-child(even){
		margin-left: 12px;
	}
	.anchor-link:nth-child(n+3){
		margin-top: 12px;
	}
	.anchor-link_img{
		height:55px;
	}
	.anchor-link_title{
		font-size: 17px;
		padding-top: 0;
	}
	.anchor-link_title:after{
		width:60px;
		bottom:-12px;
	}
	.anchor-link_detail{
		font-size: 14px;
		padding-top: 21px;
		line-height:1.5;
	}
	.anchor-link:after{
		width:41px;
		height:14px;
		bottom:9px;
	}
}
/* //====================================
//ボックス
//==================================== */
.p-contents_box{
	background:#fff;
	padding:59px 70px;
	box-shadow:0 0 10px rgba(0,85,144,0.1);
}
.p-contents_box + .p-contents_box{
	margin-top: 50px;
}
.box_title{
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 36px;
	letter-spacing:0.06em;
	color:#00AAEB;
	position:relative;
	width:fit-content;
	margin-left: auto;
	margin-right: auto;
	font-feature-settings: 'palt';
}
.box_title img{
	height:50px;
	width:auto;
	margin-right: 15px;
}
.box_title:after{
	content:'';
	display: inline-block;
	width:100%;
	height:2px;
	border-bottom:2px dashed #FFE00D;
	position:absolute;
	bottom:-15px;
	left:50%;
	transform:translateX(-50%);
}
@media screen and (max-width: 767px) {
	.p-contents_box{
		padding:20px 15px;
	}
	.p-contents_box + .p-contents_box{
		margin-top: 25px;
	}
	.box_title{
		font-size: 19px;
		white-space: nowrap;
	}
	.box_title img{
		height:30px;
		margin-right: 8px;
	}
	.box_title:after{
		bottom:-8px;
	}
}
/* //====================================
//カード
//==================================== */
.box-cards{
	display: grid;
	grid-template-columns: repeat(4,1fr);
	gap:20px;
	margin-top: 60px;
}
a.box-card:visited{
	text-decoration:none;
}
.box-card{
	display: flex;
	flex-direction:column;
	transition:.3s ease;
	overflow:hidden;
	text-decoration:none !important;
}
.box-card:hover{
	text-decoration:none;
}
.box-card:hover .box-card_img img{
	transform:scale(1.1);
	transition:.3s ease;
}
.box-card_img{
	overflow:hidden;
	margin:0;
}
.box-card_img img{
	height:100%;
	object-fit:cover;
	transition:.3s ease;
}
.box-card_text{
	background:#00AAEB;
	color:#fff;
	height:68px;
	font-size: 17px;
	font-weight: bold;
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	font-feature-settings: 'palt';
	margin:0;
}
@media screen and (max-width: 767px) {
	.box-cards{
		grid-template-columns: repeat(2,1fr);
		gap:9px;
		margin-top: 23px;
	}
	.box-card_text{
		height:45px;
		font-size: 13px;
	}
	.box-card_text.small{
		font-size: 11px;
	}
}
/* //====================================
//検索エリア
//==================================== */
.search-area{
	margin-top: 70px;
	background-image: url(../../images/mv_bg_pc.png) ;
	background-repeat: no-repeat ;
	background-position: center ;
	background-attachment: scroll ;
	background-size: cover ;
	padding:66px 20px 73px;
}
.search-area_title{
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 36px;
	letter-spacing:0.06em;
	color:#3088f3;
	-webkit-text-stroke: 5px white;
	paint-order: stroke;
	position:relative;
	width:fit-content;
	margin-left: auto;
	margin-right: auto;
	position:relative;
}
.search-area_title img{
	height:35px;
	width:auto;
	margin-right: 15px;
}
.search-area_title:after{
	content:'';
	display: inline-block;
	width:100%;
	height:2px;
	border-bottom:2px dashed #fff;
	position:absolute;
	bottom:-1px;
	left:50%;
	transform:translateX(-50%);
}
.search-area_btn{
	background:#fff;
	display: flex;
	align-items: center;
	justify-content: center;
	max-width:530px;
	width:100%;
	text-align: center;
	text-decoration:none !important;
	margin-left: auto;
	margin-right: auto;
	padding:15px;
	margin-top: 32px;
	box-sizing:border-box;
	transition:.3s ease;
	border-radius:100px;/* 28追加 */
	border:1px solid #b0b0b0; /* 28追加 */
}
.search-area_btn span{
	font-size: 20px;
	letter-spacing:0.08em;
	color:#3088f3;/* 28変更 */
	transition:.3s ease;
	display: flex;
	align-items: center;
	font-weight:700; /* 28追加 */
}
a.search-area_btn:visited{
	color: #00AAEB;
}
.search-area_btn span:before{
	content:'';
	display: inline-block;
	width:28px;
	height:28px;
	background-image: url(../../images/search-icon.png) ;
	background-repeat: no-repeat ;
	background-position: center ;
	background-attachment: scroll ;
	background-size: cover ;
	margin-right: 15px;
	transition:.3s ease;
}
/* hover時 */
.search-area_btn:hover{
	background:#00aaeb;
	transition:.3s ease;
}
.search-area_btn:hover span{
	color:#fff;
	transition:.3s ease;
}
.search-area_btn:hover span:before{
	background-image: url(../../images/search-icon-white.png) ;
	transition:.3s ease;
}
@media screen and (max-width: 767px) {
	.search-area{
		margin-top: 25px;
		padding:25px 15px;
	}
	.search-area_title{
		font-size: 19px;
		white-space:nowrap;
	}
	.search-area_title img{
		height:30px;
		margin-right: 8px;
	}
	.search-area_title:after{
		bottom:-8px;
	}
	.search-area_btn{
		padding:15px;
		margin-top: 20px;
		box-sizing:border-box;
	}
	.search-area_btn span{
		font-size: 15px;
	}
	.search-area_btn span:before{
		width:15px;
		height:15px;
		margin-right: 8px;
	}
	
}