/*
sm: >= 576px
md: >= 768px
lg: >= 992px
*/

:root {
	--color-faint-cyan: #f6fcfe;
	--color-lightest-cyan: #23aed9;
	--color-light-cyan: #20a4cb;
	--color-cyan: #278ba7;
	--color-dark-cyan: #16718c;
	--color-darkest-cyan: #044154;
	--color-text: #292b2c;
	--color-section-highlight: #f8f9fa;
}

/* --- General styles --- */
html {
	--scroll-padding-top: 1rem;
	scrollbar-gutter: stable;
	scroll-padding-top: var(--scroll-padding-top);
}

body {
	font-family: "Open Sans", Arial, sans-serif;
	color: var(--color-text);
}

a:not(.btn) {
	color: var(--color-dark-cyan);
	text-decoration: none;
}

a:not(.btn):hover,
a:not(.btn):active,
a:not(.btn):focus
{
	color:  var(--color-cyan);
}

a:not(.btn):hover {
	text-decoration: underline;
}

.cta-section h1 {
	font-weight: 900;
}

.cta-section a:not(.btn) {
	color: var(--color-light-cyan);
}

.cta-section a:not(.btn):hover,
.cta-section a:not(.btn):focus,
.cta-section a:not(.btn):active
{
	color: var(--color-lightest-cyan);
}

.img-center {
	margin-left: auto;
	margin-right: auto;
}

.smaller {
	font-size: 0.875rem;
}

.sms-link {
	pointer-events: all;
	text-decoration: none;
}

@media (min-width: 768px) {
	body:not(.phone) .sms-link {
		pointer-events: none;
		color: var(--color-text);
		cursor: default;
	}

	body:not(.phone) .cta-section .sms-link {
		pointer-events: none;
		color: #fff;
		cursor: default;
	}
}

.skip-to-main {
	position: absolute;
	top: 4px;
	left: 4px;
	z-index: 2000;
	clip: rect(0, 0, 0, 0);
}

.skip-to-main:focus {
	clip: unset;
}

/* --- Navigation --- */
.navigation,
.navigation .dropdown-menu,
.navigation .dropdown-menu .dropdown-item
{
	background-color: var(--color-light-cyan);
}

.navigation .dropdown-menu {
	padding: 0;
	min-width: 100%;
	margin-top: 0;
	text-align: center;
}

.navigation .logo {
	user-select: none;
	line-height: 1;
	font-size: 2.875rem;
	font-weight: 700;
	color: #fff;
	text-shadow: 1px 1px 1px rgba(128, 128, 128, 1);
	text-decoration: none !important;
}

.navigation .navbar-toggle {
	width: 65px;
	line-height: 65px;
	font-size: 36px;
}

.navigation .navbar-toggle .expand-icon,
.navigation .navbar-toggle .collapse-icon
{
	transition: opacity 0.5s ease-in-out;
}

.navigation .navbar-toggle:not(.collapsed)  .expand-icon,
.navigation .navbar-toggle.collapsed .collapse-icon
{
	display: none;
	visibility: hidden;
	opacity: 0.0;
}

.navigation .navbar-toggle.collapsed .expand-icon,
.navigation .navbar-toggle .collapse-icon
{
	visibility: visible;
	opacity: 1.0;
}

.navbar-nav .nav-item .nav-link {
	color: #fff;
	font-size: 0.875rem;
	text-transform: uppercase;
}

.navbar-nav .nav-item.active .nav-link,
.navbar-nav .dropdown-menu .nav-link.active
{
	background-color: var(--color-cyan);
}

.navbar-nav .nav-item .nav-link:hover,
.lang-dropdown .dropdown-item:hover,
.lang-dropdown:hover
{
	background-color: var(--color-cyan);
	text-decoration: none;
}

.navigation .navbar-toggle,
.navigation .dropdown-item,
.navbar-nav .nav-item .nav-link
{
	transition: background-color 0.25s ease;
}

.navigation .lang-selection {
	z-index: 1000;
	position: relative;
	display: inline-block;
	min-width: 60px;
}

.navigation .lang-selection .lang-icon {
	margin-right: 2px;
}

.navigation .lang-dropdown .dropdown-toggle,
.navigation .lang-dropdown .dropdown-item
{
	color: #fff !important;
	white-space: nowrap;
	text-align: center;
}

.navigation .lang-dropdown .dropdown-toggle {
	display: inline-block;
	line-height: 65px;
	width: 100%;
}

@media (min-width: 1200px) {
	.navigation .nav-link {
		height: 65px;
	}

	.navigation .dropdown-menu .dropdown-item {
		height: 45px;
	}
}

.navigation .lang-dropdown .dropdown-menu .dropdown-item {
	height: 45px;
}

/* --- Call to action section --- */
.cta-section {
	background-color: var(--color-darkest-cyan);
	color: #fff;
	text-shadow: 0 2px 2px rgba(22, 22, 22, 0.5);
	text-align: center;
	padding-top: 45px;
	padding-bottom: 45px;
}

.cta-section .sms-link {
	font-weight: 900 !important;
}

@media (min-width: 992px) {
	.cta-section {
		padding-top: 60px;
		padding-bottom: 60px;
	}
}

/* --- Main section --- */
.main-section {
	padding-top: 60px;
	padding-bottom: 60px;
	text-align: center;
	min-height: 450px;
}

.main-section .subsection {
	margin-bottom: 30px;
}

.main-section h2 {
	font-size: 1.75rem;
	font-weight: 600;
	margin-bottom: 45px;
}

.main-section h3 {
	font-size: 175%;
	font-weight: 500;
	line-height: 140%;
}

.main-section h4 {
	font-size: 125%;
	font-weight: 500;
	line-height: 120%;
}

@media (min-width: 768px) {
	.main-section h2 {
		font-size: 1.75rem;
	}

	.main-section h3 {
		font-size: 1.75rem;
	}

	.main-section h4 {
		font-size: 1.4rem;
	}
}

@media (min-width: 992px) {
	.main-section h2 {
		font-size: 250%;
	}

	.main-section h3 {
		font-size: 225%;
	}
}

@media (min-width: 992px) {
	.main-section h2 {
		font-size: 260%;
	}
}

/* --- Footer --- */
.footer {
	background-color: #ddd;
}

.footer,
.footer a
{
	color: #595959 !important;
}

.footer {
	line-height: 150%;
}

.footer .fb-links,
.footer .footer-links,
.footer .provider-info,
.footer .bottom-links
{
	text-align: center;
	margin-bottom: 30px;
}

.footer .footer-links {
	margin-bottom: 0;
}

.footer .footer-links + .footer-links {
	margin-bottom: 30px;
}

.footer a.bottom-link {
	color: #aaa;
	font-size: 80%;
}

.footer .back-to-top-icon {
	font-size: 1.75rem;
	color: var(--color-cyan);
}

.footer .fb-links .fb-link {
	display: block;
	margin-left: auto;
	margin-right: auto;
}

.footer .fb-links .fb-logo {
	max-width: 70px;
	width: auto;
	margin-bottom: 30px;
	margin-left: auto;
	margin-right: auto;
}

.fb-link {
	display: inline-block;
	vertical-align: top;
}

@media (min-width: 992px) {
	.footer .fb-links,
	.footer .footer-links,
	.footer .provider-info,
	.footer .bottom-links
	{
		text-align: left;
		margin-bottom: 0;
	}

	.footer .fb-links .fb-link {
		display: inline-block;
		margin-left: 0;
		margin-right: 0;
	}

	.footer .fb-links .fb-logo {
		margin-bottom: 0;
		margin-right: 30px;
	}

	.footer .fb-links .text-link {
		max-width: 120px;
	}
}

/* --- Front page --- */
.front-page .cta-section .cta-text {
	font-size: 2rem;
	margin: 0;
}

.front-page .main-section {
	padding-top: 0;
	padding-bottom: 0;
}

.front-page .main-section .main-section-middle {
	padding-bottom: 0;
}

.front-page .main-section .content-col {
	padding-top: 30px;
	padding-bottom: 30px;
}

.front-page .main-section .img-col {
	height: 250px;
}

.front-page .main-section .img-col-nupa {
	background: transparent url(/fi16500/img/grid-nupa.jpg) no-repeat center center;
	background-size: cover;
}

.front-page .main-section .img-col-trafi {
	background: transparent url(/fi16500/img/grid-trafi.jpg) no-repeat center center;
	background-size: cover;
}

.front-page .main-section .img-col-web-trafi {
	background: transparent url(/fi16500/img/grid-web-trafi.jpg) no-repeat center center;
	background-size: cover;
}

@media (min-width: 992px) {
	.front-page .main-section .content-col,
	.front-page .main-section .img-col
	{
		flex: 1;
		padding-left: 30px;
		padding-right: 30px;
	}

	.front-page .main-section .img-col {
		height: auto;
	}

	.front-page .main-section .content-col {
		text-align: left;
	}
}

.front-page .main-section .grid-box-head {
	font-size: 1.4rem;
	font-weight: bold;
	color: #444;
	text-transform: uppercase;
	margin-bottom: 30px;
}

.front-page .main-section .msg-em,
.front-page .main-section .msg-example
{
	font-style: normal;
	font-weight: bold;
	white-space: nowrap;
}

.front-page .main-section .grid-box-btn {
	border-radius: 0;
	margin-top: 15px;
	min-width: 220px;
}

.front-page .main-section .grid-box-sms-link {
	font-weight: bold;
}

.front-page .main-section .register-number {
	font-family: sans-serif;
	padding-left: 40px;
	border-radius: 5px 0 0 5px;
	border: 2px solid #333;
	background: #fff url('/fi16500/img/reg-plate-left.png') no-repeat left;
	background-size: contain;
	font-size: 20px;
	line-height: 30px;
	vertical-align: middle;
	color: #000;
	text-transform: uppercase;
}

.front-page .main-section .register-number,
.front-page .main-section .find-vehicle
{
	height: 50px;
}

.front-page .main-section .find-vehicle {
	border: 2px solid #333;
	border-left-width: 1px;
	padding-left: 15px;
}

.front-page .main-section .find-vehicle:hover,
.front-page .main-section .find-vehicle:active,
.front-page .main-section .find-vehicle:focus
{
	border-color: #737373;
}

.front-page .main-section .register-number-wrapper {
	margin-top: 20px;
	max-width: 300px;
	margin-left: auto;
	margin-right: auto;
}

.front-page .main-section .register-number-desc {
	margin-top: 5px;
}

@media (min-width: 1200px) {
	.front-page .main-section .register-number {
		font-size: 30px;
	}
}

@media (min-width: 992px) {
	.front-page .cta-section .cta-text {
		font-size: 2.5rem;
	}

	.front-page .main-section {
		padding-top: 0;
	}

	.front-page .main-section .main-section-middle {
		padding-bottom: 0;
	}

	.front-page .main-section .register-number-wrapper {
		margin-left: 0;
		margin-right: 0;
	}
}

.front-page .main-section .main-section-bottom {
	background-color: #f7f7f7;
	padding-top: 90px;
	padding-bottom: 90px;
}

.front-page .main-section h4 {
	margin-bottom: 5px;
}

/* --- Search info pages (number, name, address, vehicle) --- */
.search-info-page .cta-section h4
{
	font-size: 1.75rem;
	font-weight: 900;
	margin-bottom: 10px;
}

.search-info-page .main-section p,
.search-info-page .main-section ul
{
	margin-bottom: 15px;
}

.search-info-page .main-section ul {
	padding-left: 15px;
}

.search-info-page .main-section ul li {
	margin-bottom: 4px;
}

.search-info-page .main-section h1,
.search-info-page .main-section h2,
.search-info-page .main-section h3
{
	margin-top: 0;
	margin-bottom: 15px;
	font-weight: normal;
}

.search-info-page .main-section h3 {
	font-size: 1.3rem;
}

.search-info-page .img-col {
	padding-bottom: 45px;
}

.search-info-page .main-section .light-box {
	background-color: #f7f7f7;
	padding: 30px;
}

.search-info-page .main-section .bordered-box {
	border: 1px solid #eeeeee;
	padding: 30px;
}

.search-info-page .main-section h1,
.search-info-page .main-section h2
{
	font-size: 1.5rem;
}

@media (min-width: 992px) {

	.search-info-page .main-section h1,
	.search-info-page .main-section h2
	{
		font-size: 1.75rem;
	}

	.search-info-page .main-section h3 {
		font-size: 1.5rem;
	}

	.search-info-page .cta-section h4 {
		font-size: 2.25rem;
	}

}

/* --- Vehicle search page --- */
.vehicle-search .main-section h1 {

}

.vehicle-search .main-section .subsection {
	margin-bottom: 30px;
}

.vehicle-search .main-section .query-types .query-type:not(:last-child) {
	margin-bottom: 35px;
}

.vehicle-search .main-section .subhead {
	font-size: 1.25rem;
	text-transform: uppercase;
	font-weight: bold;
	margin-bottom: 15px;
}

.vehicle-search .main-section .msg-em,
.vehicle-search .main-section .msg-example
{
	font-style: normal;
	font-weight: bold;
}

.vehicle-search .main-section .vehicle-search-btns .btn {
	border-radius: 0;
	margin-top: 15px;
	min-width: 220px;
}

/* --- Terms page --- */
.terms h1 {
	font-size: 2rem;
}

.terms .main-section {
	text-align: left;
	min-height: 700px;
}

.terms .main-section p {
	font-size: 1rem;
}

.example-result-page .cta-section {
	padding-top: 3rem;
	padding-bottom: 3rem;
}

.cookie-consent .logo {
	user-select: none;
	line-height: 1;
	font-size: 2.5rem;
	font-weight: 700;
	color: var(--color-light-cyan);
	text-shadow: 1px 1px 1px rgba(32, 164, 203, 1);
	text-decoration: none !important;
}

.collapsing {
	-webkit-transition-duration: 0.1s;
	transition-duration: 0.1s;
}

/* --- Customizations --- */
.btn-cyan {
	--bs-btn-color: #fff;
	--bs-btn-bg: #278ba7;
	--bs-btn-border-color: #278ba7;
	--bs-btn-hover-color: #fff;
	--bs-btn-hover-bg: rgb(71.4, 156.4, 180.2);
	--bs-btn-hover-border-color: rgb(60.6, 150.6, 175.8);
	--bs-btn-focus-shadow-rgb: 33, 118, 142;
	--bs-btn-active-color: #fff;
	--bs-btn-active-bg: rgb(82.2, 162.2, 184.6);
	--bs-btn-active-border-color: rgb(60.6, 150.6, 175.8);
	--bs-btn-active-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);
	--bs-btn-disabled-color: #fff;
	--bs-btn-disabled-bg: #278ba7;
	--bs-btn-disabled-border-color: #278ba7;
}

.btn-outline-cyan {
	--bs-btn-color: #278ba7;
	--bs-btn-border-color: #278ba7;
	--bs-btn-hover-color: #fff;
	--bs-btn-hover-bg: #278ba7;
	--bs-btn-hover-border-color: #278ba7;
	--bs-btn-focus-shadow-rgb: 39, 139, 167;
	--bs-btn-active-color: #fff;
	--bs-btn-active-bg: #278ba7;
	--bs-btn-active-border-color: #278ba7;
	--bs-btn-active-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);
	--bs-btn-disabled-color: #278ba7;
	--bs-btn-disabled-bg: transparent;
	--bs-btn-disabled-border-color: #278ba7;
	--bs-gradient: none;
}

.bg-faint-cyan {
	background-color: var(--color-faint-cyan) !important;
}

/* --- FAQ --- */
.article-card:hover .card,
.article-card:focus .card
{
	background-color: var(--bs-light) !important;
}

.article-card .fade-top {
	--fade-top-gradient: linear-gradient(to top, #000 0%, rgba(0,0,0,0.15) 100%);
	mask-image: var(--fade-top-gradient);
	-webkit-mask-image: var(--fade-top-gradient);
}

.faq-page-toc {
	top: var(--scroll-padding-top);
}

.faq-card.active-card {
	box-shadow: var(--bs-box-shadow);
	background-color: var(--color-section-highlight);
}

.faq-card .sms-link {
	font-weight: 600 !important;
}

@media (min-width: 768px) {
	.faq-card .sms-link {
		font-weight: normal !important;
	}
}

.faq-active {
	background-color: var(--color-cyan);
}

.faq-active a {
	color: #fff !important;
}

.faq-search input {
	border-color: var(--bs-border-color) !important;
	box-shadow: none !important;
}

.faq-results .dropdown-item:hover,
.faq-results .dropdown-item:focus
{
	background-color: var(--bs-dropdown-link-hover-bg) !important;
}
