@charset "UTF-8";

/* ---------------------------------
 links
--------------------------------- */
#linksArea {
	padding: 100px 0;
}
#linksArea__title {
	margin: 0 0 50px;
	text-align: center;
	font-weight: 400;
	font-size: 25px;
	color: var(--dull-blue);
}
#linksArea__links {
	list-style-type: none;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	margin: 0 0 40px;
}
.links {
	flex: 0 0 277px;
	width: 100%;
	height: auto;
	margin: 0 0 18px;
	border:solid 1px var(--silver);
}
.links a {
	display: block;
	line-height: 0;
}
.links img {
	aspect-ratio: 4 / 1;
	width: 100%;
	height: auto;
}

#movieArea {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
.ytWrap {
	position: relative;
	flex: 0 0 360px;
	width: 100%;
}
.ytWrap iframe {
	aspect-ratio: 1 / 0.56388;
	width: 100%;
	height: auto;
}
.ytWrap figcaption {
	display: block;
	text-align: center;
	letter-spacing: 0;
	font-size: 14px;
}

/* ---------------------------------
 footer
--------------------------------- */
#footer__below {
	padding: 100px 20px;
	background-color: var(--water);
}
.companyProfile {
	text-align: center;
}
/* logo */
#footerId {
	text-align: center;
}
#footerId .siteId__link {
	width: 385px;
	height: 40px;
	margin: 0 auto 20px;
}
#footerId .siteId__logo--mark {
	top: 0;
	width: 55px;
	height: 40px;
	margin: 0 7px 0 0;
}
#footerId .siteId__logo--logo {
	width: 320px;
	height: 38px;
}
#footerId .siteId__logo--logo .svg-instance {
	width: 320px;
	height: 38px;
}
#footerId .svg-logo {
	fill: #595656;
}

.companyProfile {
	margin: 0 0 100px;
}
.companyInfo {
	margin: 0 0 30px;
	text-align: center;
}
.companyInfo__title {
	margin: 0 0 7px;
}
.companyInfo__title::before {
	display: inline-block;
	content: "──";
	margin: 0 15px 0 0;
	letter-spacing: 0;
}
.companyInfo__title::after {
	display: inline-block;
	content: "──";
	margin: 0  0 0 15px;
	letter-spacing: 0;
}
.with-dots::before {
	content: "・ ";
}
#copyright {
	padding: 30px 0;
	text-align: center;
	font-size: 15px;
}
.blue-frame-button {
	position: relative;
	display: block;
	width: 240px;
	padding: 11px 0 10px;
	margin: 20px auto;
	border: 3px solid var(--turquoise);
	text-decoration: none;
	font-weight: 600;
	font-size: 20px;
	color: var(--turquoise);
}
.blue-frame-button span::after {
	transition: 0.4s ease;
	position: absolute;
	top: calc( 50% - 8px );
	content: '';
	display: inline-block;
	width: 18px;
	height: 18px;
	margin: 0 0 0 20px;
	background-color: var(--turquoise);
	mask: url("../img/icon/arrow_right_blue.svg") no-repeat 50% 50% / contain;
	-webkit-mask: url("../img/icon/arrow_right_blue.svg") no-repeat 50% 50% / contain;
	vertical-align: 0;
}
/* SNS icon */
.sns {
	margin: 20px 0 0;
}
.sns h4 {
	margin: 0 0 7px;
	color: var(--logo-gray);
}
.sns-icon {
	list-style-type: none;
	display: flex;
	justify-content: center;
}
.sns-icon li {
	flex: 0 0 45px;
	margin: 0 5px;
}

/* Sitemap */
.menu-area {
	margin: 20px 0;
	padding: 0 0;
	border-bottom: 1px dotted var(--dull-blue);
}
.menu-area h5 {
	margin: 0 0 10px;
	font-size: 19px;
}
.menu-area h6 {
	margin: 0 0 5px;
	font-size: 16px;
}
.menu-area ul {
	margin: 0 0 20px 20px;
}

/* ---------------------------------
 width <= 1280px
--------------------------------- */
@media screen and (min-width:1px) and (max-width:1280px) {
#linksArea {
	padding: 100px 20px;
}
/* under 1280 */
}

/* ---------------------------------
 width <= 1139px
--------------------------------- */
@media screen and (min-width:1px) and (max-width:1139px) {
#linksArea__links {
	width: 885px;
	padding: 0;
	margin: 0 auto 40px;
}
#movieArea {
	width: 760px;
	margin: auto;
}
/* under 1139 */
}

/* ---------------------------------
 width <= 930px
--------------------------------- */
@media screen and (min-width:1px) and (max-width:930px) {
#linksArea__links {
	display: grid;
	grid-template-columns: 1fr 1fr 1fr;
	gap: 10px;
	margin: 0 0 40px;
}
#linksArea__links {
	width: 100%;
	padding: 0;
}
.links {
	margin: 0;
}
#movieArea {
	width: 100%;
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 10px;
}
/* under 930 */
}

/* ---------------------------------
 width <= 840px
--------------------------------- */
@media screen and (min-width:1px) and (max-width:840px) {
.sp-break {
	display: block;
}
.with-dots {
	display: block;
}
.with-dots::before {
	display: none;
}
/* under 840 */
}

/* ---------------------------------
 width <= 540px
--------------------------------- */
@media screen and (min-width:1px) and (max-width:540px) {
#linksArea__links {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 10px;
	margin: 0 0 40px;
}
#movieArea {
	max-width: 360px;
	width: 100%;
	display: block;
}
.ytWrap {
	margin: 0 0 20px;
}
.companyInfo__desc {
	font-size: 14px;
}
.all-right-reserved {
	display: block;
}
#copyright {
	font-size: 13px;
}
#footerId .siteId__link {
	aspect-ratio: 385 / 40 ;
	width: 320px;
	height: auto;
	margin: 0 auto 20px;
}
#footerId .siteId__logo--mark {
	top: 1px;
	width: 47px;
	height: 34px;
	margin: 0 7px 0 0;
}
#footerId .siteId__logo--logo {
	width: 270px;
	height: 32px;
}
#footerId .siteId__logo--logo .svg-instance {
	width: 270px;
	height: 32px;
}
/* under 540 */
}
/* --- end of css --- */