/*Menu*/
.site-header {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	z-index: 1000;
}

.site-header-container {
    display: flex;
    align-items: stretch;
    justify-content: space-between;
	padding: 3rem calc(10vw - 1.5rem);
	transition: background-color 0.3s ease, padding 0.3s ease, box-shadow 0.3s ease;
}
.site-header.is-scrolled .site-header-container {
	background-color: var(--white-1, #fff);
	padding: .5rem calc(10vw - 1.5rem);
	box-shadow: rgba(0, 0, 0, 0.05) 0px 6px 24px 0px, rgba(0, 0, 0, 0.08) 0px 0px 0px 1px;
}

.custom-logo-link {
	display: inline-block;
}

.site-branding {
	display: flex;
	align-items: center;
}

	.site-branding .custom-logo {
		height: 6.8rem;
		width: auto;
		transition: height 0.3s ease;
		margin: 0 1.5rem;
	}

/*Navigation*/
.main-navigation {
	display: flex;
	align-items: stretch;
}

.main-navigation ul {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
	align-items: stretch;
}

.main-navigation .menu-item {
    position: relative;
	margin: 0 1.5rem;
    display: flex;
    align-items: stretch;
}

.main-navigation .menu-item a {
    color: var(--font-color-2);
    text-decoration: none;
    position: relative;
	display: flex;
	align-items: center;
    transition: color 0.2s ease;
	font-weight: 500;
}
.site-header.is-scrolled .main-navigation .menu-item a {
	color: var(--font-color-2);
}

.main-navigation > .site-navigation-menu > .menu-item > a::after {
    content: "";
    position: absolute;
    bottom: .5rem;
	right: 0;
    left: unset;
    width: 0;
    height: 2px;
    background-color: var(--color-1, #ff6600);
    transition: all 0.3s ease;
}
.site-header.is-scrolled .main-navigation > .site-navigation-menu > .menu-item > a::after {
    bottom: -.5rem;
}
.main-navigation > .site-navigation-menu > .menu-item:hover > a::after {
    width: 100%;
	right: unset;
	left: 0;
}

.main-navigation > .site-navigation-menu > .menu-item.btn > a {
	font-weight: 900;
}
.main-navigation > .site-navigation-menu > .menu-item.btn > a::after {
	display: none;
}

/*.site-header .main-navigation .menu-item.current-menu-item > a,
.site-header .main-navigation .menu-item.current-menu-ancestor > a {
    color: var(--color-1, #ff6600);
}*/

/* --- Menu Rozwijane (Sub-menu) na Desktopie --- */
.main-navigation .menu-item-has-children > a[href="#"] {
	cursor: default;
}

.main-navigation .menu-item-has-children {
	position: relative;
}
.main-navigation .menu-item-has-children::after {
	content: '';
	position: absolute;
	left: 0;
	right: 0;
	bottom: -1rem;
	height: 1rem;
}
.site-header.is-scrolled .main-navigation .menu-item-has-children::after {
	bottom: -2.5rem;
	height: 2.5rem;
}

#masthead.site-header .main-navigation .menu-item.menu-item-has-children > a::after {
	position: relative;
    content: '';
    display: inline-block;
	left: unset;
	top: unset;
	right: unset;
	bottom: unset;
	background-color: unset;
    width: 1rem;
    height: 1rem;
    margin-left: 0.8rem;
    vertical-align: middle;
	
    background-color: var(--white-2, #eee);
    
    -webkit-mask-image: url("../../images/arrow-down.svg");
    mask-image: url("../../images/arrow-down.svg");
    -webkit-mask-size: contain;
    mask-size: contain;
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat;
    
    transition: transform 0.3s ease, background-color 0.3s ease;
}
#masthead.site-header.is-scrolled .main-navigation .menu-item.menu-item-has-children > a::after {
	background-color: var(--font-color-2);
}
#masthead.site-header .main-navigation .menu-item.menu-item-has-children:hover > a::after {
	transform: rotate(180deg);
	width: 1rem;
}



.main-navigation .sub-menu {
	display: block;
    position: absolute;
    left: 50%;
    top: 100%;
    transform: translateX(-50%) translateY(1rem);
	margin-top: 1rem;
    padding: 2.2rem;
    background-color: var(--white-1, #fff);
    border-radius: .5rem;
	box-shadow: rgba(0, 0, 0, 0.05) 0px 6px 24px 0px, rgba(0, 0, 0, 0.08) 0px 0px 0px 1px;
    min-width: 200px;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.3s ease, transform 0.3s ease;
    z-index: 10;
}

.main-navigation .sub-menu::before {
	content: "";
	position: absolute;
	left: 50%;
	top: -0.75rem;
	transform: translateX(-50%) rotate(45deg);
	width: 1.5rem;
	height: 1.5rem;
	box-shadow: rgba(0, 0, 0, 0.05) 0px 6px 24px 0px, rgba(0, 0, 0, 0.08) 0px 0px 0px 1px;
	background-color: var(--white-1);
}
.main-navigation .sub-menu::after {
	content: "";
	position: absolute;
	left: 50%;
	top: 0px;
	transform: translatex(-50%);
	width: 3rem;
	height: 2rem;
	background-color: var(--white-1, #fff);
	z-index: 1;
}

.main-navigation .menu-item-has-children:hover > .sub-menu,
.main-navigation .menu-item-has-children:focus-within > .sub-menu {
    opacity: 1;
    pointer-events: auto;
    transform: translateX(-50%) translateY(0);
}
.site-header.is-scrolled .main-navigation .menu-item-has-children:hover > .sub-menu {
	transform: translateX(-50%) translateY(1.5rem);
}

.main-navigation .sub-menu a {
    color: var(--font-color-2, #212529);
    white-space: nowrap;
    display: block;
    padding: .8rem 0 1px 0;
	display: inline-block;
    background-repeat: no-repeat;
    transition: all .2s;
	background-position: bottom left;
    background-size: 0% 2px;
    background-image: linear-gradient( var(--color-1), var(--color-1) );
}
.main-navigation .sub-menu a:hover {
	background-size: 100% 2px;
}

#masthead.site-header .main-navigation .sub-menu .submenu-title a {
    color: var(--font-color-4, #6c757d);
    font-weight: 500;
    padding-bottom: 1rem;
    margin-bottom: 1rem;
    border-bottom: 1px solid var(--white-3, #ddd);
    cursor: default;
}

.main-navigation .sub-menu .submenu-title a::after {
    display: none;
}
.main-navigation .sub-menu .submenu-title a:hover {
    color: var(--font-color-4, #6c757d);
	background-size: 0% 2px;
}


/* ==========================================================================
   3. Nawigacja Mobilna (zarządzana przez JS i klasę na <body>)
   ========================================================================== */

/* Przycisk "Hamburger" */
.mobile-menu-toggle {
    display: none;
    background: none;
    border: none;
    cursor: pointer;
    padding: 0;
    z-index: 1010;
	margin: 0 1.5rem;
}

/* Ukryj menu desktop na mobile */
@media (max-width: 1200px) {
	
	.site-header .main-navigation {
        display: none;
    }
	
    .mobile-menu-toggle {
        display: block;
    }
	
	.mobile-navigation {
		text-align: center;
	}
	
	.btn {
		margin-top: 3rem;
	}
	
	.site-branding .custom-logo {
		height: 6.4rem;
	}
	
}

.mobile-menu-toggle .mobile-menu-line {
    height: 2px; width: 28px; background-color: var(--white-1, #fff);
    transition: transform 0.3s ease-in-out, background-color 0.3s ease-in-out;
    display: block;
}
.mobile-menu-toggle .mobile-menu-line:nth-child(3) { margin: 6px 0; }

.site-header.is-scrolled .mobile-menu-toggle .mobile-menu-line {
	background-color: var(--font-color-1, #222);
}

.mobile-navigation {
    display: flex;
    flex-direction: column;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: var(--white-1, #fff);
    padding: 12rem 10vw 2rem 10vw;
    overflow-y: auto;
    transform: translateX(100%);
    transition: transform 0.4s ease-in-out;
    z-index: 999;
}

body.mobile-menu-is-open .mobile-navigation {
    transform: translateX(0);
}

body.mobile-menu-is-open {
    overflow: hidden;
}

body.mobile-menu-is-open .mobile-menu-toggle .mobile-menu-line {
    background-color: var(--font-color-1, #212529);
}
body.mobile-menu-is-open .mobile-menu-toggle .mobile-menu-line:nth-child(2) {
    transform: translateY(8px) rotate(45deg);
}
body.mobile-menu-is-open .mobile-menu-toggle .mobile-menu-line:nth-child(3) {
    transform: scaleX(0);
}
body.mobile-menu-is-open .mobile-menu-toggle .mobile-menu-line:nth-child(4) {
    transform: translateY(-8px) rotate(-45deg);
}

.mobile-navigation .site-navigation-menu { 
	list-style: none;
	padding: 0;
	flex-direction: column; 
	width: 100%; 
}
.mobile-navigation .menu-item a { color: var(--font-color-2, #212529); padding: 1.5rem 0; font-size: 2rem; display: block; width: 100%; text-align: center; border-bottom: 1px solid var(--white-3, #ddd); }
.mobile-navigation .menu-item:last-child a { border-bottom: none; }
.mobile-navigation .sub-menu { 
	position: static; 
	transform: none; 
	background: linear-gradient(to right, var(--white-1) 0%, var(--white-2) 50%, var(--white-1) 100%);
	width: 100%; 
	padding: 0; 
	box-shadow: none; max-height: 0; 
	overflow: hidden; 
	transition: max-height 0.4s ease, padding 0.4s ease; 
}
.mobile-navigation .sub-menu .submenu-title {
	display: none;
}
.mobile-navigation .sub-menu::before { display: none; }
.mobile-navigation .menu-item.submenu-is-open > .sub-menu { max-height: 100vh; padding: 1rem 0; }
.mobile-navigation .menu-item-has-children > a { position: relative; }
.mobile-navigation .menu-item-has-children > a::after { content: '+'; position: absolute; right: 2rem; top: 50%; transform: translateY(-50%); font-size: 2.8rem; font-weight: 300; color: var(--color-1, #ff6600); transition: transform 0.3s ease; }
.mobile-navigation .menu-item.submenu-is-open > a::after { transform: translateY(-50%) rotate(45deg); }

/*animacja linkow*/
.mobile-navigation .menu-item {
    opacity: 0;
    transform: translateX(20px);
    transition: opacity 0.4s ease, transform 0.4s ease;
}
body.mobile-menu-is-open .mobile-navigation .menu-item {
    opacity: 1;
    transform: translateX(0);
}
/* Opóźnienia dla kolejnych elementów */
body.mobile-menu-is-open .mobile-navigation .menu-item:nth-child(1) { transition-delay: .25s; }
body.mobile-menu-is-open .mobile-navigation .menu-item:nth-child(2) { transition-delay: .30s; }
body.mobile-menu-is-open .mobile-navigation .menu-item:nth-child(3) { transition-delay: .35s; }
body.mobile-menu-is-open .mobile-navigation .menu-item:nth-child(4) { transition-delay: .40s; }
body.mobile-menu-is-open .mobile-navigation .menu-item:nth-child(5) { transition-delay: .45s; }
body.mobile-menu-is-open .mobile-navigation .menu-item:nth-child(6) { transition-delay: .50s; }
body.mobile-menu-is-open .mobile-navigation .menu-item:nth-child(7) { transition-delay: .55s; }
body.mobile-menu-is-open .mobile-navigation .menu-item:nth-child(8) { transition-delay: .60s; }
body.mobile-menu-is-open .mobile-navigation .menu-item:nth-child(9) { transition-delay: .65s; }
body.mobile-menu-is-open .mobile-navigation .menu-item:nth-child(10) { transition-delay: .70s; }
body.mobile-menu-is-open .mobile-navigation .menu-item:nth-child(11) { transition-delay: .75s; }
body.mobile-menu-is-open .mobile-navigation .menu-item:nth-child(12) { transition-delay: .80s; }