@charset "utf-8";

/* ===============================================
   common
=============================================== */
@font-face {
  font-family: "NotoSansCJKjp-Regular";
  font-style: normal;
  font-weight: normal;
  src: url('https://aomori-syukuhakuplan.jp/assets/css/fonts/NotoSansCJKjp/NotoSansCJKjp-Regular.eot');
  src: url('https://aomori-syukuhakuplan.jp/assets/css/fonts/NotoSansCJKjp/NotoSansCJKjp-Regular.eot#iefix') format('embedded-opentype'),
  url('https://aomori-syukuhakuplan.jp/assets/css/fonts/NotoSansCJKjp/NotoSansCJKjp-Regular.woff') format('woff'),
  url('https://aomori-syukuhakuplan.jp/assets/css/fonts/NotoSansCJKjp/NotoSansCJKjp-Regular.otf') format('opentype')
}

html {
	/* -webkit-text-size-adjust: 100%; */
	/* overflow-y: scroll; */
	font-size: 6.25%;
}
body{
	-webkit-box-sizing: border-box;
	        box-sizing: border-box;
	font-family: 'Noto Sans JP', sans-serif;
	line-height: 1.6;
}
img{
	width:100%;
	height: auto;
}

section{
	position: relative;
	margin: 0;
	padding: 0;
}
section .inner,
footer .inner{
	width:1080px;
	max-width:100%;
	margin: 0 auto;
	padding: 50px;
}
section .inner-wide{
	width:1300px;
	max-width:100%;
	margin: 0 auto;
	padding: 50px;
}

.bg-yellow {
	background:#e9d153;
}
.bg-gray {
	background:#dfe4e8;
}


p,
ul li,
ol li{
	font-size:16rem;
}
.em-1{
	font-size:28rem;
	font-weight:bold;
}

.text {
	line-height: 1.8;
}

.ib {
	display: inline-block;
}

hr{
	height: 0;
	margin: 80px auto;
	padding: 0;
	border: 0;
	border-top: 1px dashed #666;
}

@media screen and (max-width:767px){
	.em-1{
		font-size: 24rem;
	}

	p,
	ul li,
	ol li{
		font-size:15rem;
	}

	.text {
		line-height: 1.6;
	}
}

.button-next.wide{
	width:500px;
}
.button-next.wide a{
	color:#fff;
	text-decoration:none;
}
@media screen and (max-width:767px){
	.button-next.wide{
		width:100%;
	}
	.button-next.wide a{
		font-size:80%;
	}
}

/* section-1 */
#section-1{
	/* aspect-ratio: 1920 / 923; */
	width:100%;
	position:relative;
	background-color: #e7e266;
}
#section-1::after {
	content:'';
	display: block;
	width: 100%;
	height: 20px;
	background: url("../images/bg-wave-top-wht.svg") repeat-x top left / 1850px auto;
	position: absolute;
	bottom: -1px;
	left: 0;
}
#section-1::before{
	width:114vw;
	height: 140vw;
	max-height: 1280px;
	content:"";
	margin: auto;
	background: url('../images/bg-header.png') top center no-repeat;
	background-size: contain;
	position:absolute;
	top:0;
	left: 50%;
	-webkit-transform: translateX(-50%);
	    -ms-transform: translateX(-50%);
	        transform: translateX(-50%);
	z-index: 1;
}

#titlelogo{
	position: relative;
	width: 46%;
	max-width: 800px;
	height:auto;
	margin: 0 auto;
	padding: 195px 0 100px;
	z-index: 1000;
	opacity: 0;
	transition: opacity 1.0s;
}
#titlelogo.show {
	opacity: 1;
}
#titlelogo .txt-1 {
	color: #c33;
	font-size: 32rem;
	font-weight: bold;
	text-align: center;
}
#titlelogo .txt-1 span {
	margin: 0 5px;
	font-size: 52rem;
}

	@media screen and (max-width:1800px){
		#titlelogo {
			padding: 10.83vw 0 5.55vw;
		}
	}

	@media screen and (max-width:767px){
		/* sp */
		#section-1{
			width:100%;
			height: 100vw;
			background: url('https://aomori-syukuhakuplan.jp/assets/images/bg-header-sp.png') top center no-repeat;
			background-size:cover;
		}
		#section-1::before{
			display: none;
		}
		#section-1::after {
			height: 12px;
			background: url("https://aomori-syukuhakuplan.jp/assets/images/bg-wave-top-wht-sp.svg") repeat-x top left / 510px auto;
		}
		#titlelogo{
			margin: 0 auto;
		}
	}


/* section-2 */
#section-2{
	width:100%;
	padding: 40px 0;
	z-index: 1;
}
#section-2::after {
	content:'';
	display: block;
	width: 100%;
	height: 20px;
	background: url("../images/bg-wave-top-gre.svg") repeat-x top left / 1850px auto;
	position: absolute;
	bottom: -1px;
	left: 0;
}
#section-2 h2.heading02{
	width: 420px;
	max-width: 100%;
	line-height: 1;
	margin: 0 auto 40px;
}
#section-2 .text {
	font-size: 18rem;
	line-height: 2;
	-webkit-font-feature-settings: "palt";
	font-feature-settings: "palt";
	max-width: 800px;
	margin: 0 auto;
}
	@media screen and (max-width:767px){
		/* sp */
		#section-2 {
			padding: 0 0 40px 0;
		}

		#section-2::after {
			height: 12px;
			background: url("https://aomori-syukuhakuplan.jp/assets/images/bg-wave-top-gre-sp.svg") repeat-x top left / 510px auto;
		}
		#section-2 h2.heading02{
			width: 255px;
			margin:25px auto;
		}
		#section-2 .text {
			font-size: 16rem;
			line-height: 1.7;
			text-align: left;
		}
	}


.box-em-1{
	margin:50px auto;
}
.box-em-1.bg-1 {
	width: 85%;
	padding: 15px;
	border: 4px solid #c33;
}
.box-em-1 .txt-1{
	color:#c33;
	font-size:36rem;
	font-weight:bold;
	text-align:center;
	letter-spacing: 2px;
}
.box-em-1 .txt-1 span{
	position:relative;
	z-index:10;
	background:-webkit-gradient(linear, left top, left bottom, color-stop(60%, transparent), color-stop(60%, #fff));
	background:-o-linear-gradient(transparent 60%, #fff 60%);
	background:linear-gradient(transparent 60%, #fff 60%);
}
.box-em-1 .txt-2{
	margin-top:15px;
	color:#c33;
	font-size:44rem;
	font-weight:bold;
	text-align:center;
	letter-spacing: 4px;
}
.box-em-1 .txt-2 span{
	font-size:64rem;
}

	@media screen and (max-width:767px){
		/* sp */
		.box-em-1 .txt-1{
			font-size:26rem;
		}
		.box-em-1 .txt-2{
			font-size:24rem;
		}
		.box-em-1 .txt-2 span{
			font-size:44rem;
		}
	}

.list-1{
	width:81%;
	margin: 0 auto;
}
.list-1 li{
	margin-bottom:10px;
	list-style:disc;
}

.icon-button{
	width: 163px;
	height: 30px;
	background: url('https://aomori-syukuhakuplan.jp/assets/images/icon-button.png') center center no-repeat;
	background-size: auto;
	background-size: contain;
	display: inline-block;
	position: relative;
	top: 8px;
}

.shape-arrow{
	width:100%;
	height:50px;
	position:relative;
}
.shape-arrow::before{
	width:50px;
	height:30px;
	content:"";
	margin:auto;
	background:#ffffff99;
	position:absolute;
	top:20px;
	left:0;
	right:0;
}
.shape-arrow::after{
	width: 0;
	height: 0;
	content:"";
	margin:auto;
	border-style: solid;
	border-right: 50px solid transparent;
	border-left: 50px solid transparent;
	border-top: 45px solid #ffffff99;
	border-bottom: 0;
	position:absolute;
	top:50px;
	left:0;
	right:0;
}


.layout-flex-1{
	width:100%;
	display:flex;
	gap:20px;
	justify-content:center;
}

	@media screen and (max-width:767px){
		/* sp */
		.layout-flex-1{
			flex-wrap:wrap;
		}
	}

.box-red-1{
	border: 4px solid #c33;
	background:#fff;
}
.box-inner{
	padding:15px;
}

.box-red-1 .txt-1{
	margin-bottom:25px;
	color:#c33;
	font-size:24rem;
	font-weight:bold;
	text-align:center;
	letter-spacing: 2px;
}
.box-red-1 .txt-1 span{
	position:relative;
	background:-webkit-gradient(linear, left top, left bottom, color-stop(60%, transparent), color-stop(60%, #e9d153));
	background:-o-linear-gradient(transparent 60%, #e9d153 60%);
	background:linear-gradient(transparent 60%, #e9d153 60%);
	z-index:10;
}
.box-red-1 .txt-2{
	font-size:24rem;
	letter-spacing: 1px;
	text-align: center;
	line-height: 160%;
}
.box-red-1 .txt-2 span{
	font-size:36rem;
	letter-spacing: 1px;
	font-weight: bold;
}
.box-red-1 .txt-3{
	font-weight: bold;
	letter-spacing: 1px;
	text-align: center;
	line-height:140%;
}

.list-note-1{
	margin: 0 0 0 20px;
}
.list-note-1 li{
	margin-bottom:5px;
	position:relative;
	font-size: 19rem;
}
.list-note-1 li::before{
	content:"※";
	margin-left: -1.0em;
}
.layout-flex-present {
	display: flex;
	gap: 20px;
	justify-content: center;
}
.layout-flex-present div {
	width: calc(50% - 10px);
	font-weight: bold;
	text-align: center;
}
.layout-flex-present div img{
	max-width:210px;
	margin: 0 auto;
}
	@media screen and (max-width:767px){
		/* sp */
		.box-red-1{
			width:100%;
			flex-wrap:wrap;
		}
		.box-red-1 .txt-1{
			font-size:22rem;
		}
		.box-red-1 .txt-2{
			font-size:18rem;
		}
		.box-red-1 .txt-2 span{
			font-size:22rem;
		}
		.box-red-1 .txt-3{
			font-size:15rem;
		}
		.box-inner {
			padding: 7px;
		}
		.layout-flex-present{
			flex-wrap:wrap;
		}
		.layout-flex-present div{
			width:100%;
			line-height:1.6;
		}
		.layout-flex-present div img{
			max-width:100%;
		}
	}


/* section-3 */
#section-3 {
	background-color: #e7e266;
	padding: 70px 0 100px;
}
#section-3 .heading02-sub {
	font-size: 24rem;
	font-weight: bold;
	text-align: center;
	margin-bottom: 15px;
}
#section-3 h2.heading02 {
	text-align: center;
}
#section-3 h2.heading02{
	line-height: 1;
	margin-bottom: 30px;
}
#section-3 h2.heading02 > span {
	display: inline-block;
	position: relative;
	max-width: calc(100vw - 290px);
}
#section-3 h2.heading02 img {
	display: inline-block;
	width: 618px;
	max-width: 100%;
}
#section-3 h2.heading02 > span::after {
	content: '';
	width: 120px;
	height: 74px;
	background: url("../images/pick-up-text.svg") no-repeat center center / contain;
	position: absolute;
	top: 12px;
	right: -135px;
}
.top-slider {
	display: flex;
	justify-content: space-between;
}
.top-slider .item {
	display: flex;
	flex-direction: column;
	margin: 0 10px;
	position: relative;
}
.slick-track {
	display: flex;
	justify-content: space-between;
	height: 100%;
}
.slide-date {
	color: #036eb8;
	font-size: 15rem;
	font-weight: bold;
	height: 34px;
	display: inline-block;
	background-color: #fff;
	padding-left: 1em;
	position: relative;
	display: inline-flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	border-radius: 5px 0 0 0;
	width: 190px;
}
.slide-date::after {
	content: '';
	width: 40px;
	height: 36px;
	background: url("../images/bg-slide-date.svg") no-repeat center center / contain;
	position: absolute;
	bottom: -1px;
	right: -40px
}
.slide-date .fs-l {
	font-size: 1.2em;
}
.slide-img {
	border: 10px solid #fff;
	border-bottom: none;
	overflow: hidden;
	cursor: pointer;
}
.slide-img img {
	aspect-ratio: 600 / 300;
	-o-object-fit: cover;
	   object-fit: cover;
	width: 100%;
	height: 100%;
}
.slide-text {
	color: #036eb8;
	font-weight: bold;
	font-size: 22rem;
	line-height: 1.3;
	letter-spacing: 0.07em;
	word-break: break-all;
	margin-bottom: 1em;
	flex-grow: 1;
}
.slide-body {
	background-color: #fff;
	padding: 15px 30px;
	flex-grow: 1;
	display: flex;
	flex-direction: column;
	cursor: pointer;
}
.slide-bottom {
	display: flex;
	justify-content: space-around;
	align-items: center;
    flex-wrap: wrap;
	gap: 20px;
}
.slide-name {
	display: flex;
	flex-grow: 1;
	align-items: center;
	font-size: 15rem;
	line-height: 1.3;
	letter-spacing: 0.04em;
	width: calc(100% - 180px);
	min-width: 150px;
}
.slide-name > span {
	padding: 0 1em;
	display: inline-block;
	border-left: 1px solid currentColor;
	border-right: 1px solid currentColor;
}
.slide-link {
	flex-grow: 1;
	line-height: 1;
	white-space: nowrap;
	min-width: 150px;
	text-align: right;
}
.slide-link a {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}
.slide-link span {
	display: inline-block;
	font-size: 15rem;
	line-height: 1.3;
	letter-spacing: 0.07em;
	color: #000;
	text-decoration: none;
	position: relative;
	padding-right: 1.2em;
}
.slide-link span::after {
	content: '';
	width: 8px;
	height: 13px;
	background: url("../images/icon-arrow-r.svg") no-repeat center center / contain;
	position: absolute;
	top: 50%;
	right: 0;
	-webkit-transform: translateY(-50%);
	    -ms-transform: translateY(-50%);
	        transform: translateY(-50%);
}

	@media screen and (max-width:767px){
		/* sp */
		#section-3 {
			padding: 30px 0;
		}
		#section-3 .heading02-sub {
			font-size: 20rem;
		}
		#section-3 h2.heading02 {
			width: 98%;
			max-width: 360px;
			margin: 0 auto 20px;
		}
		#section-3 h2.heading02 > span {
			max-width: 100%;
			padding-top: 30px;
		}
		#section-3 h2.heading02 > span::after {
			content: '';
			width: 120px;
			height: 16px;
			background: url("https://aomori-syukuhakuplan.jp/assets/images/pick-up-text-sp.svg") no-repeat center center / contain;
			position: absolute;
			top: 0;
			left: 50%;
			-webkit-transform: translateX(-50%);
			    -ms-transform: translateX(-50%);
			        transform: translateX(-50%);
		}
		.top-slider .item {
			margin-left: 5px;
			margin-right: 5px;
		}
		.top-slider li {
			margin: 0 5px;
		}
		.slide-img {
			aspect-ratio: 267 / 142;
			border-width: 5px;
		}
		.slide-body {
			padding: 10px 12px;
		}
		.slide-text {
			font-size: 15rem;
		}
		.slide-bottom {
			flex-direction: column;
			align-items: flex-start;
			gap: 10px;
		}
		.slide-link {
			width: 100%;
			align-self: flex-end;
		}
		.slide-link span {
			font-size: 12rem;
		}
		.slide-name {
			font-size: 13rem;
			width: 100%;
		}
		.slide-date {
			font-size: 11rem;
			width: 140px;
		}
		.slide-link a::after {
			width: 6px;
			height: 9px;
		}
	}



/* section-4 */
#section-4{
	width:100%;
	background: #036eb8 url("../images/bg-blue-wave.png") repeat left top / 205px auto;
}
#section-4 h2.heading02{
	margin:25px 0;
	color:#fff;
	font-size:32rem;
	font-weight:bold;
	line-height: 1.4;
	text-align:center;
	position:relative;
}

.layout-flex-2{
	width: 80%;
	margin: 40px auto 15px;
	display:flex;
	gap: 15px;
	align-items:center;
	justify-content:center;
}
.layout-flex-2 .select_wrapper {
	border: 2px solid #333;
	border-radius:6px;
	overflow: hidden;
	position: relative;
}
.layout-flex-2 .select_wrapper::after {
	content: '';
    width: 8px;
    height: 12px;
	background: url("../images/icon-arrow-r-s-blk.svg") no-repeat center center / contain;
    position: absolute;
    top: 50%;
    right: 10px;
	-webkit-transform: translateY(-50%);
	    -ms-transform: translateY(-50%);
	        transform: translateY(-50%);
}
.layout-flex-2 div select{
	width: 360px;
	max-width: 100%;
	padding:0 20px;
	height: 50px;
	font-size:16rem;
	font-weight:bold;
	border: none;
	color: initial;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
}
.layout-flex-2 div select option {
	padding:15px 20px;
}
.layout-flex-2 div .button-submit{
	width: 160px;
	max-width: 100%;
	padding: 10px 1em;
	background:#141414;
	color:#fff;
	font-size:20rem;
	font-weight:bold;
	text-align: center;
	border: none;
	border-radius:100vh;
	letter-spacing: 0.5em;
	text-indent: 0.5em;
}
.layout-flex-2 div .button-submit:hover{
	cursor:pointer;
}

.area-text {
	margin-bottom: 50px;
}
.area-text a {
	font-size: 20rem;
	color: #fff;
}

	@media screen and (max-width:767px){
		/* sp */
		#section-4 .inner-wide {
			padding: 15px 10px;
		}
		.layout-flex-2{
			width: 100%;
			max-width: 500px;
			flex-wrap:wrap;
			gap: 7px;
			margin: 25px auto 15px;
		}
		.layout-flex-2 .select_wrapper {
			width: calc(100% - 87px);
		}
		.layout-flex-2 > div:last-child{
			width:auto;
		}
		.layout-flex-2 > div select{
			width:100%;
			height: 38px;
		}
		.layout-flex-2 div .button-submit {
			font-size: 16rem;
			width: 80px;
			height: 40px;
			padding: 0.5em;
			border-radius: 5px;
			display: flex;
			flex-direction: column;
			align-items: center;
			justify-content: center;
		}

		#section-4 h2.heading02 {
			font-size: 25rem;
		}

		.area-text {
			margin-bottom: 30px;
		}
		.area-text a {
			font-size: 16rem;
		}

	}

.layout-flex-3{
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	grid-template-rows: 1fr;
	width: 100%;
	margin: 25px auto;
	gap: 20px;
}
.layout-flex-3 .button-wrapper {
	width: 100%;
}
.layout-flex-3 .box-plan-1{
	background:#fff;
	overflow: visible;
	display: grid;
	grid-template-rows: subgrid;
	grid-row: span 4;
}
.layout-flex-3 .box-plan-1 .box-inner{
	display: inherit;
	grid-template-rows: inherit;
	grid-row: inherit;
	font-size: 0;
}
.layout-flex-3 .box-plan-1 .photo{
	position: relative;
	width: 100%;
	height: 214px;
	overflow: hidden;
}
@media screen and (max-width:1300px){
	.layout-flex-3 .box-plan-1 .photo{
		height: 16.4615vw;
	}
}
.layout-flex-3 .box-plan-1 .photo img{
	-o-object-fit: cover;
	   object-fit: cover;
	width: 100%;
	height: 100%;
	/* aspect-ratio: 366 / 220; */
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	right: 0;
}
@media screen and (max-width:767px){
	.layout-flex-3 {
		grid-template-columns: repeat(2, 1fr);
	}
	.layout-flex-3 .box-plan-1 .photo {
		/* max-height: initial; */
		height: 25.066vw;
	}
}
.layout-flex-3 .box-plan-1 .name{
	font-size:18rem;
	font-weight: bold;
	-webkit-font-feature-settings: "palt";
	font-feature-settings: "palt";
	padding: 0 0 0.5em;
}

.layout-flex-3 .box-plan-1 .label{
	margin:0 auto 15px auto;
	display:flex;
	gap: 5px;
}
.layout-flex-3 .box-plan-1 .label span{
	display: flex;
	justify-content: center;
	align-items: center;
	flex-basis: 50%;
	padding: 5px 5px;
	border-radius:100vh;
	font-size:14rem;
	font-weight: bold;
	text-align: center;
}
.layout-flex-3 .box-plan-1 .label .label-theme{
	background: #f9cbcb;
}
.layout-flex-3 .box-plan-1 .label .label-area{
	background: #f3e4c3;
}

.layout-flex-3 .box-plan-1 .plan{
	color: #036eb8;
	font-size:22rem;
	font-weight: bold;
	word-break: break-all;
	-webkit-font-feature-settings: "palt";
	font-feature-settings: "palt";
	padding: 0.5em 0;
	border-bottom: 1px solid #bdbdbd;
}
.layout-flex-3 .box-plan-1 .lead{
	margin:0 auto 15px auto;
	font-size:15rem;
	line-height: 1.5em;

	display: -webkit-box;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 7;
	height: 10.5em !important;
	overflow: hidden;
}


.layout-flex-3 .box-plan-1 .button a{
	padding: 0.45em 0.5em;
	background:#c33;
	color:#fff;
	display:block;
	font-size:16rem;
	font-weight: bold;
	line-height: 1.3;
	text-align:center;
	text-decoration:none;
}
.layout-flex-3 .box-plan-1 .button a > span {
	position: relative;
	display: inline-block;
	padding: 0 1.7em;
}
.layout-flex-3 .box-plan-1 .button a > span::before{
	content: '';
	width: 8px;
	height: 12px;
	background: url("../images/icon-arrow-r-s-wht.svg") no-repeat center center / contain;
	position: absolute;
	top: 50%;
	right: 0;
	-webkit-transform: translateY(-50%);
	    -ms-transform: translateY(-50%);
	        transform: translateY(-50%);
}
.layout-flex-3 .box-plan-1 .button a > span > span {
	display: inline-block;
}
@media screen and (max-width:1000px){
	.layout-flex-3 .box-plan-1{
		/* width: calc((100% / 2) - 10px); */
		min-width: initial;
		max-width: initial;
	}
}

	@media screen and (max-width:767px){
		.layout-flex-3 {
			gap: 10px;
		}
		.layout-flex-3 .box-plan-1{
			/* width: calc((100% / 2) - 5px); */
			min-width: initial;
			max-width: initial;
		}
		.layout-flex-3 .box-plan-1 .plan {
			font-size: 14rem;
		}
		.layout-flex-3 .box-plan-1 .name {
			font-size: 13rem;
			padding: 0.5em 0 1.5em;
		}
		.layout-flex-3 .box-plan-1 .button a {
			font-size: 12rem;
		}
	}


#search_none {
	display: none;
	width: 100%;
	text-align: center;
	color: #fff;
	font-size: 20px;
}
#search .children {
	display: none;
}

.button-next{
	width:585px;
	max-width: 100%;
	margin:80px auto 50px auto;
	padding: 10px 50px;
	background:#111;
	border-radius:10px;
	color:#fff;
	font-size:24rem;
	font-weight:bold;
	line-height: 1.3;
	text-align:center;
}
.button-next:hover{
	cursor:pointer;
}
	@media screen and (max-width:767px){
		/* sp */
		.button-next{
			width: 200px;
			font-size: 16rem;
			padding: 10px 0;
			margin: 30px auto 20px;
			border-radius: 5px;
		}
	}

/* footer */
footer {
	padding-top: 50px;
}
footer .txt-1{
	margin:10px auto;
	text-align:center;
}
footer .txt-1 span{
	padding:0 25px;
	color:#c33;
	font-size:28rem;
	font-weight:bold;
	text-align:center;
	position:relative;
}
footer .txt-1 span::before,
footer .txt-1 span::after{
	width:2px;
	height: 25rem;
	content:"";
	margin: auto;
	border-left: 2px solid #c33;
	position:absolute;
	top:0;
	bottom:0;
}
footer .txt-1 span::before{
	left:0;
	-webkit-transform:rotate(-45deg);
	    -ms-transform:rotate(-45deg);
	        transform:rotate(-45deg);
}
footer .txt-1 span::after{
	right:0;
	-webkit-transform:rotate(45deg);
	    -ms-transform:rotate(45deg);
	        transform:rotate(45deg);
}

.layout-bnr{
	max-width:850px;
	margin: auto;
	padding:25px 0;
	background: #c33;
	display:flex;
	gap:25px;
	align-items:center;
	justify-content:center;
}
.layout-bnr img{
	width:260px;
	border-radius:2px;
}
.layout-bnr span{
	color:#fff;
	font-size:24rem;
	font-weight:bold;
}

.layout-flex-4{
	width: 100%;
	margin: 25px auto;
	display:-webkit-box;
	display:-ms-flexbox;
	display:flex;
	gap: 35px;
	align-items:center;
	justify-content:center;
}
.layout-flex-4 div {
	width: 520px;
	max-width: 100%;
}
.layout-flex-4 div a img{
	border:2px solid #9a9a9a;
	border-radius:2px;
}

.layout-flex-5{
	width: 100%;
	margin: 25px auto;
	display:flex;
	gap: 0 25px;
	justify-content: space-between;
}
.layout-flex-5 div{
	min-width:30%;
	padding:25px;
	text-align: center;
}
.layout-flex-5 div:nth-child(odd){
	border-right: 1px dashed #ccc;
}

	@media screen and (max-width:767px){
		/* sp */
		footer {
			padding-top: 20px;
		}
		.layout-flex-4,
		.layout-flex-5{
			flex-wrap:wrap;
		}
		.layout-flex-4 div {
			width: 320px;
		}
		.layout-flex-5 div {
			width: 100%;
		}
		.layout-flex-5 div:nth-child(odd){
			border-right: 0px;
			border-bottom: 1px dashed #ccc;
		}
		.layout-bnr{
			flex-wrap:wrap;
			flex-direction:column-reverse;
		}
		.layout-bnr img{
			max-width:90%;
			text-align:center;
		}
		.layout-bnr span{
			width:100%;
			text-align:center;
			font-size:20rem;
		}
	}

.plans {
	text-align:right;
}

@media screen and (min-width:768px){
	/* pc */
}

@media screen and (max-width:767px){
	/* sp */

	section .inner,
	footer .inner,
	section .inner-wide{
		width:95%;
		padding: 15px;
	}
	.plans {
		text-align:left;
		font-size: 15rem;
		margin-bottom: 30px;
	}
}