/*
 Theme Name:   Nightforce Theme
 Theme URI:    https://elementor.com/hello-theme/
 Description:  Nightforce custom theme
 Author:       Vincent van den Brink
 Author URI:   https://pixelcrafted.nl
 Template:     hello-elementor
 Version:      1.0.0
 Text Domain:  hello-child
*/



html {
	font-size: 1rem;
	scroll-behavior: smooth;
}

body {
	margin: 0;
	position: relative;
	transition: all .3s;
}

body::before {
	top: 0;
 	left: 0;
 	width: 100%;
  	height: 100vh;
	content: '';
	background-color: var(--e-global-color-553ea0f);
	background-image: url('img/sr-light-bg.png');
	background-repeat: no-repeat;
	background-position: top center;
	position: fixed;
	z-index: 0;
}

body * {
	outline: none;
}

h1, h2, h3, h4, h5, h6 {
    word-wrap: break-word;
    overflow-wrap: break-word;
    white-space: normal;
}

/* Sharpen images in Chrome */
img {
	image-rendering: -webkit-optimize-contrast !important;
}

/* Headings */
h1 { font-size: 2.5rem }
h2 { font-size: 2rem }
h3 { font-size: 1.66rem }
h4 { font-size: 1.33rem }
h5 { font-size: 1rem }
h6 { font-size: 0.9rem }


/* Paragraphs */
p {
	margin-top: 0;
}

/* List */
.elementor-widget-text-editor ul,
.elementor-widget-theme-post-content ul,
.elementor-widget-text-editor ol,
.elementor-widget-theme-post-content ol {
	margin: 0 0 24px 0;
}

.elementor-widget-text-editor :last-child,
.elementor-widget-theme-post-content :last-child {
	margin-bottom: 0;
}

/* Buttons */
a.elementor-button,
a:hover.elementor-button {
	font-size: var(--e-global-typography-accent-font-size) !important;
	font-weight: var(--e-global-typography-accent-font-weight) !important;
    line-height: var(--e-global-typography-accent-line-height) !important;
}

/* Special Switch Rental gradient */
.sr-gradient {
	border-radius: 24px;
	overflow: hidden;
	z-index: 1;
}

.sr-gradient a {
	padding: 0;
	height: 100%;
	border: none !important;
	background-color: transparent !important;
	overflow: hidden;
	display: flex;
	justify-content: center;
	align-items: center;
}

.sr-gradient a:after {
	top: 0;
	left: 0;
	width: 200%;
	height: 100%;
    position: absolute;
    content: '';
    background: var(--e-global-color-primary);
    background: linear-gradient(135deg, var(--e-global-color-primary) 0%, var(--e-global-color-accent) 50%, var(--e-global-color-secondary) 100%);
    z-index: -1;
    transition: transform 300ms ease-in;
}
 
.sr-gradient:hover {
	box-shadow: 0 0 12px var(--e-global-color-secondary);
}

.sr-gradient a:hover:after {
	transform: translateX(-50%);
}

/* Hide inner shadow on inputs */
input,
textarea {   
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
	outline: none;
}

/* Default blur effect */
.blur {
	backdrop-filter: blur(12px);
	-webkit-backdrop-filter: blur(12px);
	background-color: color-mix(in srgb, var(--e-global-color-553ea0f) 50%, transparent);
	box-shadow: 0 0 24px color-mix(in srgb, var(--e-global-color-primary) 10%, transparent) !important;
}

/*** HEADER ***/

/* Logo */
#logo .site-logo-dark,
#logo .site-logo-light {
	opacity: 0;
	transition: opacity .3s;
}

#logo:hover .site-logo-dark,
#logo:hover .site-logo-light {
	opacity: 1;
}

#logo .site-logo-light {
	display: none;
}

/* Main Navigation */
#main-menu nav a {
	font-size: 1.1rem;
}

#main-menu nav li.mobile-menu-link,
#main-menu nav li.current-menu-item a::after {
	display: none;
}

#main-menu nav li:hover.current-menu-item a::after {
	display: block;
}

#main-menu nav .elementor-nav-menu .sub-arrow { 
	padding: 0 0 0 8px;
}

#main-menu nav .elementor-nav-menu li a,
#main-menu nav .elementor-nav-menu li a:hover { 
	border-left: none;
	display: flex;
	justify-content: space-between;
	cursor: pointer;
}

/* Submenu */
#main-menu ul.sub-menu {
	padding: 12px 0;
}

/* Theme toggle */
#theme-toggle {
	width: 90px;
	height: 45px;
}

#theme-toggle .switch {
	width: 100%;
	height: 100%;
	border-radius: 23px;
	background: var(--e-global-color-secondary);
  	cursor: pointer;
	transition: background .3s;
	position: relative;
	display: block;
}

#theme-toggle .slider::before {
    top: 10px;
	left: 10px;
	width: 25px;
	height: 25px;
  	border-radius: 50%;
	content: "";
  	background: white;
	box-shadow: none;
	position: absolute;
	transform: translateX(45px);  
	transition: transform .3s, box-shadow .3s;
}



/*** HOMEPAGE ***/

/* Service tile */
a.service * {
	transition: all 0.3s;
}

a:hover.service * {
	color: white !important;
}

/* Qoute carousel */
.quote-carousel .quote {
	cursor: grab;
}

.quote-carousel .quote .quotation {	
    font-size: 1.33rem;
    line-height: 36px;
    font-family: var(--e-global-typography-secondary-font-family);
    font-weight: var(--e-global-typography-secondary-font-weight);
	font-style: italic;
}

.quote-carousel .quote .quotation:before,
.quote-carousel .quote .quotation:after {
    font-size: 2rem;
    color: var(--e-global-color-secondary);
    font-weight: var(--e-global-typography-primary-font-weight);
}

.quote-carousel .quote .quotation:before {
	content: open-quote;
}

.quote-carousel .quote .quotation:after {
	content: close-quote;
}

.quote-carousel .quote .person .name,
.quote-carousel .quote .person .position,
.quote-carousel .quote .person .company {
	color: color-mix(in srgb, var(--e-global-color-text) 67%, transparent);
}

/* Logo carousel */
.logo-carousel .logo img {
	max-width: 125px;
	width: auto;
	max-height: 56px;
	height: auto;
	filter: brightness(0) invert(0) !important;
	transition: filter .3s;
}

.logo-carousel .logo img:hover {
	filter: none !important;
}




/*** SERVICE PAGE ***/

/* Faq (general) */
.faq details:first-child summary {
	border-color: transparent !important;
}

.faq details summary {
	align-items: flex-start !important;
}

.faq details summary[aria-expanded="true"] .e-n-accordion-item-title-text {
	font-weight: bold;
}

.faq details summary .e-n-accordion-item-title-icon {
	height: 26px;
}



/*** PROJECTS ***/

/** Project filter **/
#project-filter button {
	cursor: pointer;
	transition: all .3s ease-in-out;
}

#project-filter button[aria-pressed="true"] {
	color: white;
}

/** Project tile **/

/* Image */
.project-tile:hover .project-image {
	transform: scale(1.08);
}

/* Project overlay */

/* Hover effect */
.project-tile a.project-link:after {
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: linear-gradient(135deg, color-mix(in srgb, var(--e-global-color-primary) 80%, transparent) 0%, color-mix(in srgb, var(--e-global-color-accent) 80%, transparent) 100%);
	z-index: 2;
	content: '';
	position: absolute;
	opacity: 0;
	transition: all .3s ease-in-out;
}

.project-tile a:hover.project-link:after {
	opacity: 1;
}

/* Hover arrow */
.project-tile .view-project .elementor-icon-wrapper {
	display: flex;
}

.project-tile .view-project svg {
	opacity: 0;
	transition: all .3s ease-in-out;
}

.project-tile a:hover.project-link .view-project svg {
	opacity: 1;
}

/* Project description (large tiles) */
.project-tile .project-description * {
	display: none;
}

.project-tile .project-description :first-child {
	display: -webkit-box;
	overflow: hidden;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	text-overflow: ellipsis;
}

/* Load more (autoload) */
.e-load-more-spinner svg {
	margin: 0 auto;
	width: 2em !important;
	height: 2em !important;
}



/*** PROJECT PAGE ***/
#project .hero {
	min-height: clamp(480px, 50vh, 50vh);
}

/** (Project) Quote **/
#project .quote {
	margin-top: 40px;
}

/* General quote styling */
figure.quote blockquote {
	margin: 0 40px;
	font-size: 1.33rem;
	font-family: var(--e-global-typography-secondary-font-family);
	font-weight: var(--e-global-typography-secondary-font-weight);
}

figure.quote blockquote q {
	font-style: italic;
	line-height: 32px;
}

figure.quote blockquote q:before,
figure.quote blockquote q:after {
	font-size: 2rem;
	color: var(--e-global-color-secondary);
	font-weight: var(--e-global-typography-primary-font-weight);
}

figure.quote blockquote q:before {
	margin: 0 6px 0 0;
}

figure.quote figcaption {
	margin: 12px 40px 0 40px;
	color: color-mix(in srgb, var(--e-global-color-text) 67%, transparent);
}

/** Photos **/
#project #photos .swiper-slide {
	width: 100%;
	aspect-ratio: 4/3;
	background: var(--e-global-color-91e85bc);
	cursor: pointer;
}

#project #photos .swiper-lazy-preloader {
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	margin: 0;
	border-radius: 0px;
	border: none;
	background: var(--e-global-color-f87f0f5);
	animation: none;
}

/* Slider arrows */
#project #photos .elementor-swiper-button {
	margin-top: -8px;
	top: 50%;
	width: 48px;
	height: 48px;
	justify-content: center;
	align-items: center;
	border-radius: 50%;
	backdrop-filter: blur(12px);
	-webkit-backdrop-filter: blur(12px);
	background-color: color-mix(in srgb, var(--e-global-color-553ea0f) 50%, transparent);
	box-shadow: 0 0 24px color-mix(in srgb, var(--e-global-color-primary) 10%, transparent);
}

#project #photos .elementor-swiper-button:hover svg {
	color: var(--e-global-color-secondary);
}

#project #photos .elementor-swiper-button-prev {
	left: -24px;
}

#project #photos .elementor-swiper-button-next {
	right: -24px;
}

/* Slider pagination dots */
#project #photos .swiper-pagination {
	justify-content: center;
	display: flex;
	gap: 8px;
}

#project #photos .swiper-pagination-bullet {
	width: 24px;
	height: 6px;
	border-radius: 3px;
	transition-duration: 500ms;
}

#project #photos .swiper-pagination-bullet-active {
	width: 48px;
}

#project #photos .swiper-pagination-bullet:hover {
	background-color: var(--e-global-color-secondary);
}


/** Related projects **/
#project #related a:hover * {
	color: white;
}



/*** CONTACT ***/

/* General form styling */
#sw-form form input:focus,
#sw-form form textarea:focus,
#sw-form form select:focus {
	background-color: var(--e-global-color-553ea0f);
	box-shadow: 0 0 8px color-mix(in srgb, var(--e-global-color-secondary) 50%, transparent);
}

#sw-form form select option {
  background-color:  var(--e-global-color-553ea0f);
}

#sw-form form .elementor-message::before {
	display: none;
}



/*** LIVESTREAM ***/
#livestream,
#livestream .livestream-embed {
	width: 100%;
	position: relative;
	aspect-ratio: 16 / 9;
}

#livestream .livestream-embed > div {
	padding: 0 !important;
	height: 100% !important;
	inset: 0;
	position: absolute !important;
}

/* Iframe vult altijd de wrapper */
#livestream .livestream-embed iframe {
	padding: 0 !important;
	width: 100% !important;
	height: 100% !important;
	inset: 0;
	position: absolute !important;
}



/*** SITEMAP ***/
#sitemap .elementor-sitemap-title {
	margin: 0 0 16px 0;
}

#sitemap .elementor-sitemap-list a {
	transition: all .3s;
} 

#sitemap .elementor-sitemap-list a:hover {
	color: var(--e-global-color-secondary);
}



/*** FOOTER ***/

/* General social media buttons */
.social-media-btn a {
	width: 48px !important;
	height: 48px !important;
	display: flex;
	align-items: center;
	justify-content: center;
}

.social-media-btn a svg {
	width: 24px !important;
	height: 24px !important;
}



/*** DARK MODE ***/
body.dark-mode {
	--e-global-color-primary: #0E73BA;
    --e-global-color-secondary: #3399D4;
    --e-global-color-text: #FFFFFF;
    --e-global-color-accent: #56ABDE;
    --e-global-color-553ea0f: #141414;
	--e-global-color-f87f0f5: #242424;
}

body.dark-mode::before {
	background-image: url('img/sr-dark-bg.png');
}

/* Blur */
.dark-mode .blur {
	box-shadow: 0 3px 8px rgba(0,0,0,0.25) !important;
}

/* Header */
.dark-mode #header {
	background-color: color-mix(in srgb, var(--e-global-color-553ea0f) 67%, transparent);
}

/* Logo */
.dark-mode #logo .site-logo-light {
	display: block;
}

.dark-mode #logo .site-logo-dark {
	display: none;
}

/* Theme toggle */
.dark-mode #theme-toggle .switch {
	background: var(--e-global-color-f87f0f5);
}

.dark-mode #theme-toggle .slider::before {
	background: var(--e-global-color-f87f0f5);
	box-shadow: inset 12px -4px 0 white;
	transform: translateX(0);
}

/* Image carousel */
.dark-mode .logo-carousel .logo img {
  filter: brightness(0) invert(1) !important;
}

.dark-mode .logo-carousel .logo img:hover {
  filter: none !important;
}

/* Form */
.dark-mode #sw-form .elementor-date-field::-webkit-calendar-picker-indicator {
  filter: invert(1);
} 



@media only screen and (max-width: 1024px) {
	
	body::before {
		background-image: url('img/sr-light-bg-small.png');
	}
	
	/*** HEADER ***/
	
	/* Mobile menu */
	header #main-menu nav.elementor-nav-menu--dropdown {
		top: 79px !important;
		left: 16px !important;
		right: 16px !important;
		width: calc(100% - 32px) !important;
		position: fixed;
	}
	
	header #main-menu nav.elementor-nav-menu--dropdown a {
		line-height: 24px;
		border-top: 1px solid color-mix(in srgb, var(--e-global-color-text) 10%, transparent);
	}
	
	header #main-menu nav.elementor-nav-menu--dropdown li:first-child a {
		border: none;
	}

	/* Sub menu arrow */
	header #main-menu nav.elementor-nav-menu--dropdown li a .sub-arrow svg {
		width: 1em;
		height: 1em;
	}

	header #main-menu nav.elementor-nav-menu--dropdown li a.highlighted .sub-arrow svg {
		transform: rotate(180deg);
	}
	
	/* Sub submenu */
	header #main-menu nav.elementor-nav-menu--dropdown ul.sub-menu {
		padding: 0;
	}
	
	header #main-menu nav.elementor-nav-menu--dropdown ul.sub-menu a {
		padding-left: 32px;
		font-size: 1rem;
		border-top: 1px solid color-mix(in srgb, var(--e-global-color-text) 10%, transparent);
	}
	
	
	
	/*** PROJECT PAGE ***/
	#project #photos .elementor-swiper-button-prev {
		left: 16px;
	}

	#project #photos .elementor-swiper-button-next {
		right: 16px;
	}
	
	
	
	/*** DARK MODE ***/
	body.dark-mode::before {
		background-image: url('img/sr-dark-bg-small.png');
	}
	

}

@media only screen and (max-width: 767px) {

	/* HEADINGS */
	h1 { font-size: 2.25rem }
	h2 { font-size: 1.75rem }
	h3 { font-size: 1.5rem }
	h4 { font-size: 1.25rem }
	
	/*** HEADER ***/
	
	/* Mobile menu */
		header #main-menu nav.elementor-nav-menu--dropdown {
		top: 66px !important;
	}
	
	/* Call button */
	header #call-button a,
	header #call-button a:hover {
		padding: 0;
		width: 36px;
		height: 36px;
		border-radius: 0;
		border: none;
		background: none;
		justify-content: center;
		align-content: center;
		display: flex;
	}

	header #call-button a svg {
		width: 21px;
		height: 21px;
		fill: var(--e-global-color-text);
	}
	
	header #call-button a .elementor-button-text {
		display: none;
	}
	
	/* Dark mode toggle */
	#theme-toggle {
		width: 64px;
		height: 32px;
	}

	#theme-toggle .slider::before {
		top: 6px;
		left: 6px;
		width: 20px;
		height: 20px;
		transform: translateX(32px);  
	}
	
	/* Mobile menu */
	header #main-menu nav li.mobile-menu-link {
		display: block;
	}
	
	
	
	/*** PROJECT PAGE ***/
	
	/* Hero */
	#project .hero {
		min-height: clamp(380px, 67vh, 67vh);
	}
	
	/* Quote */
	figure.quote blockquote {
		margin: 0 16px;
	}
	
	figure.quote figcaption {
		margin: 8px 16px 0 16px;
	}

	/* Photos */
	#project #photos .elementor-swiper-button {
		display: none;
	}
	
	/* Related projects */
	#project #related .elementor-post-navigation {
		gap: 16px;
	}
	
	#project #related .elementor-post-navigation__link a {
		gap: 8px;
	}
	
	#project #related .elementor-post-navigation__separator-wrapper,
	#project #related .post-navigation__prev--label,
	#project #related .post-navigation__next--label {
		display: none;
	}
	
	
	
	/*** FOOTER ***/
	
	/* Bottom footer */
	#footer #bottom .menu ul {
		gap: 8px;
	}
	
	#footer #bottom .menu li {
		width: 100%;
	}
	
	#footer #bottom .menu a {
		margin: 0;
		padding: 0;
		justify-content: center;
	}
	
	/*** DARK MODE ***/
	.dark-mode #theme-toggle .slider::before {
		box-shadow: inset 8px -4px 0 white;
	}
}