/*
Theme Name: Linkage Theme
Author: J.V.A
Description: 「」
Version: 1.0.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Tags: bootstrap, LESS, bower, gulp
Text Domain: oracle

This theme, like WordPress, is licensed under the GPL.
Use it to make something cool, have fun, and share what you've learned with others.
*/

:root {
	--c_red: #e30200;
	--c_blu: #07335d;
	--c_ylw: #ffbf00;
}

@media (min-width: 1200px) {
	.container {
		max-width: 1375px;
	}
}

body {
	font-family: 'Open Sans', sans-serif;
}

a {
	text-decoration: none;
	transition: all .3s;
}

a:hover, a:focus {
	text-decoration: none;
}

#page-wrap {
	overflow: hidden;
}

.btn-custom {
	display: table;
	font-size: 21px;
	font-weight: 600;
	color: #fff;
	background-color: var(--c_red);
	padding: 19px;
	border: none;
	border-radius: 0;
	min-width: 290px;
	transition: all .3s;
}

.btn-custom:hover, .btn-custom:focus {
	color: #ffffff;
	background-color: var(--c_blu);
}

.video-container {
	position: relative;
	padding-bottom: 59.73%;
}

.video-container iframe {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	margin-bottom: 30px;
}

.pre_title {
	font-size: 25px;
	color: var(--c_red);
	margin: 0;
	line-height: 1;
}

.s_title {
	font-size: 45px;
	color: var(--c_blu);
	margin-bottom: 20px;
}

#main_header .header_top {
	background-color: var(--c_blu);
	position: relative;
	padding: 15px 0;
}

#main_header .header_top .site_info {
	padding: 0;
	margin: 0;
	list-style: none;
}

#main_header .header_top .site_info > li {
	display: inline-block;
	vertical-align: middle;
	color: #ffffff;
	font-size: 16px;
}

#main_header .header_top .site_info > li:not(:last-child)::after {
	content: '';
	margin: 0 1em;
	border-right: solid 1px #fff;
}

#main_header .header_top .site_info > li > a {
	color: #ffffff;
}

#main_header .header_top .site_info > li > a:hover, #main_header .header_top .site_info > li > a:focus {
	color: var(--c_ylw);
}

#main_header .header_top .top_right {
	text-align: right;
}

#main_header .header_top .top_right p {
	display: inline-block;
	vertical-align: middle;
	margin: 0;
	color: #ffffff;
	font-size: 16px;
	margin-right: 10px;
}

#main_header .header_top .top_right a {
	position: relative;
	display: inline-block;
	vertical-align: middle;
	font-size: 16px;
	font-weight: 600;
	color: #ffffff;
	padding: 0 10px;
}

#main_header .header_top .top_right a:hover, #main_header .header_top .top_right a:focus {
	color: var(--c_ylw);
}

#main_header .header_top .top_right a:before {
	content: '';
	position: absolute;
/*	top: -15px;*/
/*	left: 0;*/
/*	bottom: -15px;*/
inset: -15px auto -15px 0;
width: 100vw;
background-color: var(--c_red);
}

#main_header .header_top .top_right a span {
	position: relative;
}

#main_header .header_body {
	padding: 30px 0;
}

#main_header .header_body .site_logo {
	display: table;
	width: 200px;
	max-width: 100%;
	margin: auto;
}

#main_header .header_body .site_logo:hover, #main_header .header_body .site_logo:focus {
	transform: scale(.96);
}

#main_header .header_body .meta {
	text-align: right;
	display: flex;
	justify-content: end;
	align-items: center;
	margin-bottom: 1em;
}

#main_header .header_body .meta .account {
	font-size: 17px;
	font-weight: 600;
	color: var(--c_blu);
	margin-right: 15px;
}

#main_header .header_body .meta .account i {
	width: 34px;
	height: 34px;
	border: solid 3px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border-radius: 100%;
}

#main_header .header_body .meta .account:hover, #main_header .header_body .meta .account:focus {
	color: var(--c_red);
}

#main_header .header_body .meta .socials {
	padding: 0;
	margin: 0;
	list-style: none;
}

#main_header .header_body .meta .socials > li {
	display: inline-block;
	vertical-align: middle;
}

#main_header .header_body .meta .socials > li:not(:last-child) {
	margin-right: 15px;
}

#main_header .header_body .meta .socials > li > a {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 37px;
	height: 37px;
	background-color: #a3a3a3;
	border-radius: 100%;
	font-size: 18px;
	color: #ffffff;
}

#main_header .header_body .meta .socials > li > a:hover, #main_header .header_body .meta .socials > li > a:focus {
	background-color: var(--c_red);
}

#main_header .header_body .header_nav {
	text-align: right;
	padding: 0;
	margin: 0;
	list-style: none;
}

#main_header .header_body .header_nav > li {
	display: inline-block;
	vertical-align: middle;
}

#main_header .header_body .header_nav > li:not(:last-child) {
	margin-right: 20px;
}

#main_header .header_body .header_nav > li > a {
	display: table;
	font-size: 17px;
	font-weight: 600;
	color: var(--c_blu);
	padding: 6px;
	border-bottom: solid 3px transparent;
}

#main_header .header_body .header_nav > li > a:hover, #main_header .header_body .header_nav > li > a:focus, #main_header .header_body .header_nav > li.active > a {
	color: var(--c_red);
	border-color: #d6d6d6;
}

#banner_section {
	/* padding: 100px 0; */
	background-size: cover;
	background-position: center;
}

#banner_section:after {
	content: '';
	padding-top: 35%;
	display: block;
}

#banner_section .banner_title {
	font-size: 50px;
	color: var(--c_red);
	line-height: 1;
	margin-bottom: 30px;
	font-weight: 100;
}

#banner_section .banner_title strong {
	display: block;
	font-size: 155px;
	color: var(--c_blu);
	line-height: 1;
}

#banner_section .banner_content {
	font-size: 21px;
	line-height: 1.5;
	margin-bottom: 30px;
}

#about_section {
	margin-bottom: 100px;
}

#about_section .quick_links {
	background-color: #e6e6e6;
	margin-bottom: 100px;
	overflow: hidden;
}

#about_section .quick_links .box {
	position: relative;
	display: flex;
	align-items: center;
	padding: 30px 0;
}

#about_section .quick_links .box:before {
	content: '';
	position: absolute;
	top: 0;
	bottom: 0;
	width: 100vw;
	background-color: transparent;
	transition: all .3s;
}

#about_section .quick_links .row > div:first-child .box:before {
	right: -15px;
}

#about_section .quick_links .row > div:last-child .box:before {
	left: -15px;
}

#about_section .quick_links .box:hover:before {
	background-color: var(--c_blu);
}

#about_section .quick_links .box .icon {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 132px;
	max-width: 132px;
	border: solid 10px var(--c_red);
	border-radius: 100%;
	margin-right: 30px;
	transition: all .3s;
	position: relative;
	padding: 15px;
}

#about_section .quick_links .box:hover .icon {
	border-color: #ffffff;
}

#about_section .quick_links .box .icon svg {
	height: auto;
	fill: var(--c_red);
	transition: all .3s;
}

#about_section .quick_links .box:hover .icon svg {
	fill: #ffffff;
}

#about_section .quick_links .box .meta {
	position: relative;
}

#about_section .quick_links .box .meta p {
	font-size: 25px;
	margin: 0;
	color: var(--c_red);
	transition: all .3s;
}

#about_section .quick_links .box:hover .meta p {
	color: #ffffff;
}

#about_section .quick_links .box .meta .title {
	font-size: 45px;
	border-bottom: solid 1px var(--c_red);
	color: var(--c_red);
	transition: all .3s;
}

#about_section .quick_links .box:hover .meta .title {
	color: #ffffff;
	border-color: #ffffff;
}

#about_section .quick_links .box .meta a {
	font-size: 25px;
	font-weight: 800;
	color: var(--c_red);
}

#about_section .quick_links .box:hover .meta a {
	color: #ffffff;
}

#about_section .quick_links .box .meta a:hover, #about_section .quick_links .box .meta a:focus {
	color: var(--c_ylw);
}

#about_section .btn-custom {
	margin: auto;
}

#about_section .about_content {
	font-size: 21px;
	line-height: 1.5;
	margin-bottom: 2em;
}

#services_section {
	background-color: #ffffff;
	padding: 50px 0;
}

#services_section .box {
	background-color: #d8eafc;
	padding: 50px;
	margin-bottom: 100px;
	height: 100%;
}

#services_section .box .icon {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 132px;
	max-width: 132px;
	border: solid 10px var(--c_red);
	border-radius: 100%;
	margin: auto;
	margin-bottom: 30px;
	position: relative;
	padding: 15px;
	transition: all .3s;
}

#services_section .box:hover .icon {
	transform: scale(1.1);
}

#services_section .box .icon .fake_image {
	width: 100%;
	padding-top: 100%;
	background-size: contain;
	background-position: center;
	background-repeat: no-repeat;
}

#services_section .box .title {
	text-align: center;
	font-size: 40px;
	color: var(--c_blu);
	margin-bottom: 30px;
}

#services_section .box .content {
	font-size: 21px;
	line-height: 1.5;
}

#services_section .services_content p {
	font-size: 21px;
	line-height: 1.5;
	margin-bottom: 2em;
}

#services_section .img_container {
	width: 660px;
	max-width: 100%;
	margin: auto;
}

#services_section .img_container .fake_image {
	background-size: cover;
	background-position: center;
}

#gallery_section {
	padding: 50px 0;
}

#gallery_section .box {
	margin-bottom: 50px;
}

#gallery_section .gallery_title {
	font-size: 30px;
	font-weight: 900;
	color: var(--c_red);
}

#gallery_section .img_container {
	display: table;
	width: 100%;
	padding: 10px;
	background-color: #ffffff;
	box-shadow: 3px 3px 6px rgba(0, 0, 0, .25);
}

#gallery_section .img_container .fake_image {
	padding-top: 100%;
	background-size: cover;
	background-position: center;
}

#quiz_section {
/*	padding: 30px 0;*/
}

#quiz_section .img_container {
	transform: translateY(30px);
}

#quiz_section .img_container .fake_image {
	background-size: cover;
	background-position: center;
}

#quiz_section .title {
	text-align: center;
	font-size: 45px;
	line-height: 1.2;
	color: #fff;
	width: 400px;
	max-width: 100%;
	margin: auto;
	margin-bottom: 50px;
}

#quiz_section .btn-custom {
	margin: auto;
}

#blog_section {
	background-color: #ffffff;
	padding-bottom: 50px;
}

#blog_section .group_bg {
	background-size: cover;
	background-position: top center;
	margin-bottom: 50px;
}

#blog_section .group_bg::before {
	content: '';
	width: 100%;
	padding-top: 32.63%;
	display: block;
}

#blog_section .pre_title {
	text-align: center;
}

#blog_section .s_title {
	text-align: center;
}

#blog_section .box {
	width: 430px;
	max-width: 100%;
	margin: auto;
	margin-bottom: 50px;
}

#blog_section .box .img_container {
	margin: auto;
	margin-bottom: 15px;
}

#blog_section .box .img_container .fake_image {
	padding-top: 55.35%;
	background-size: cover;
	background-position: center;
}

#blog_section .box .img_container .date {
	font-size: 21px;
	font-weight: 600;
	background-color: var(--c_blu);
	color: #fff;
	padding: 10px 15px;
}

#blog_section .box .title {
	font-size: 25px;
	line-height: 1.2;
	color: var(--c_blu);
}

#blog_section .box .excerpt {
	font-size: 21px;
	line-height: 1.5;
	margin-bottom: 15px;
}

#blog_section .box .btn {
	min-width: 200px;
}

#testimonials_section {
	padding: 100px 0;
}

#testimonials_section .pre_title, #testimonials_section .s_title {
	text-align: center;
	color: #fff;
}

#testimonials_section .rating {
	text-align: center;
	padding: 0;
	margin: 0;
	margin-bottom: 1em;
	list-style: none;
}

#testimonials_section .rating > li {
	display: inline-block;
	vertical-align: middle;
	margin: 0 4px;
	color: #ffffff;
}

#testimonials_section .rating > li.ylw {
	color: var(--c_ylw);
}

#testimonials_section .content {
	width: 1233px;
	max-width: 100%;
	margin: auto;
	margin-bottom: 2em;
	font-size: 21px;
	color: #ffffff;
	line-height: 1.5;
	text-align: center;
}

#testimonials_section .name {
	text-align: center;
	font-size: 25px;
	font-weight: 900;
	color: #fff;
}

#testimonials_section .slick-dots {
	bottom: -50px;
}

#testimonials_section .slick-dots li button {
	background-color: #ffffff;
	border-radius: 100%;
	transition: all .3s;
}

#testimonials_section .slick-dots li button:hover, #testimonials_section .slick-dots li button:focus, #testimonials_section .slick-dots li.slick-active button {
	background-color: var(--c_red);
}

#testimonials_section .slick-dots li button:before {
	content: none;
}

#contact_section {
	background-image: url(images/contact-bg.jpg);
	background-position: center;
	background-repeat: no-repeat;
	padding: 100px 0;
}

#contact_section .box {
	width: 1381px;
	max-width: 100%;
	margin: auto;
	position: relative;
	padding: 100px 15px 50px;
}

#contact_section .box::before {
	content: '';
	position: absolute;
	inset: 0;
	background-color: #464646;
	mix-blend-mode: multiply;
}

#contact_section .box .title {
	position: relative;
	text-align: center;
	font-size: 45px;
	color: #fff;
	margin: 0;
}

#contact_section .box .subtitle {
	position: relative;
	text-align: center;
	font-size: 30px;
	color: #fff;
	margin-bottom: 50px;
}

#contact_section .box .excerpt {
	position: relative;
	text-align: center;
	font-size: 21px;
	color: #fff;
	margin-bottom: 50px;
}

#contact_section .box .gform_wrapper {
	position: relative;
	width: 857px;
	max-width: 100%;
	margin: auto;
}

#contact_section .box .ginput_container input, #contact_section .box .ginput_container select, #contact_section .box .ginput_container textarea {
	padding: 14px;
	border: none;
	border-radius: 0;
	resize: none;
}

#contact_section .box .ginput_container textarea {
	height: 133px;
}

#contact_section .box .gform_wrapper.gravity-theme .gform_footer button {
	margin: auto;
}

#footer {
	border-bottom: solid 26px var(--c_blu);
}

#footer .footer_body {
	padding: 100px 0 50px;
	border-bottom: solid 1px #f0f0f0;
}

#footer .footer_body .top {
	width: 771px;
	max-width: 100%;
}

#footer .footer_body .footer_logo {
	width: 239px;
}

#footer .footer_body .footer_logo:hover, #footer .footer_body .footer_logo:focus {
	transform: scale(.96);
}

#footer .footer_body .socials {
	text-align: right;
	padding: 0;
	margin: 0;
	list-style: none;
	flex: 1;
}

#footer .footer_body .socials > li {
	display: inline-block;
	vertical-align: middle;
}

#footer .footer_body .socials > li:not(:last-child) {
	margin-right: 15px;
}

#footer .footer_body .socials > li > a {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 37px;
	height: 37px;
	background-color: #a3a3a3;
	border-radius: 100%;
	font-size: 18px;
	color: #ffffff;
}

#footer .footer_body .socials > li > a:hover, #footer .footer_body .socials > li > a:focus {
	background-color: var(--c_red);
}

#footer .footer_body .footer_excerpt {
	font-size: 17px;
	line-height: 2;
	margin: 50px 0;
	width: 771px;
	max-width: 100%;
}

#footer .footer_body .newsletter {
	margin-bottom: 30px;
}

#footer .footer_body .newsletter h4 {
	font-size: 25px;
	color: #008131;
	margin-bottom: 1em;
}

#footer .footer_body .newsletter .excerpt {
	font-size: 17px;
	font-weight: 600;
}

#footer .footer_body .newsletter label {
	display: block;
	font-size: 17px;
	margin-bottom: 10px;
}

#footer .footer_body .newsletter .email {
	height: 48px;
	border-radius: 0;
}

#footer .footer_body .newsletter .btn-custom {
	width: 100%;
}

#footer .footer_body .site_info {
	padding: 0;
	margin: 0;
	list-style: none;
}

#footer .footer_body .site_info > li {
	font-size: 16px;
	margin-bottom: 1em;
}

#footer .footer_body .site_info > li i {
	color: var(--c_red);
}

#footer .footer_body .site_info > li > a {
	color: #000000;
}

#footer .footer_body .site_info > li > a:hover, #footer .footer_body .site_info > li > a:focus {
	color: var(--c_red);
}

#footer .colophon {
	padding: 50px 0;
}

#footer .colophon .footer_nav {
	padding: 0;
	margin: 0;
	list-style: none;
}

#footer .colophon .footer_nav > li {
	display: inline-block;
	vertical-align: middle;
}

#footer .colophon .footer_nav > li:not(:last-child) {
	margin-right: 20px;
}

#footer .colophon .footer_nav > li > a {
	color: #000000;
}

#footer .colophon .footer_nav > li > a:hover, #footer .colophon .footer_nav > li > a:focus {
	color: var(--c_red);
}

#footer .colophon .copyright {
	text-align: right;
	margin: 0;
}

/* 4 19 2023 */
#innerpage_banner {
	height: 150px;
	display: flex;
	align-items: center;
	justify-content: center;
	margin-bottom: 30px;
}

#innerpage_banner h1 {
	text-align: center;
	margin: 0;
	font-weight: 900;
	text-transform: uppercase;
	color: #fff;
}