* {
box-sizing: border-box;
}
html {
scroll-behavior: smooth;
}
body {
margin: 0;     
background:var(--white);
opacity: 0;
font-weight: 500;
font-family: 'Poppins', sans-serif;
overflow-x: hidden;
}
img {
display: block;
}
a:focus, button:focus, input:focus {
outline:none;
}
em {
color: var(--light-green);
}
:root {
--black: #000000;
--white: #ffffff;
--light: #e5efe4;
--grey: #5b5b5b;
--dark: #022109;
--light-green: #73d580;
--green: #39b54a;
--medium-green: #053310;
--dark-green: #0d3d14;
--blue: #5babff;
--orange: #ff812b;
--max-width: 1420px;
}
p, li {
font-size: 16px;
line-height: 1.7;
}
h1, h2, h3, h4, h5, h6 {
font-weight: 750;
font-family: "Montserrat", sans-serif;
letter-spacing: -0.6px;
}
h1 {
font-size: 74px;
line-height: 1.1;   
margin:0; 
}
.banner-container h1 {
font-size: 86px;
} h1 span {
color: var(--green);
}
h2 {
font-size: 46px;
line-height: 1.1;
margin-top:0;
margin-bottom: 20px;
}
h3 {
font-size: 36px;
line-height: 1.1;
}
h4 {
font-size: 30px;
margin:24px 0;
}
h5 {
font-size:24px;
margin-top:20px;
margin-bottom: 0;
}
h6 {
position: relative;
font-size: 18px;
letter-spacing: 0.4px;
display: inline-block;
margin:0 0 30px 0;
color:var(--green) !important;
}
.post, .page {
margin:0;
}
::-webkit-scrollbar {
width: 10px;
}
::-webkit-scrollbar-thumb {
background: var(--green);
}
::-webkit-scrollbar-track {
background: var(--dark);
} #headercontainer {
position: fixed;
top:40px;
width:100%;
max-width: 100%;
z-index: 9999;
transition: 0.2s all ease-in-out;
background:var(--white);
box-shadow: 0 0 8px 4px rgb(13 61 20 / 4%);
}
.top-header {
position: fixed;
width: 100%;
background: var(--dark);
z-index: 111;
}
.top-site-header {
max-width: var(--max-width);
margin: 0 auto;
padding: 6px 60px;
height: 40px;
display: flex;
align-items: center;
justify-content: right;
}
.top-site-header ul {
margin: 0;
padding: 0;
}
.top-site-header ul li {
display: inline-block;
font-size: 13px;
color: var(--white);
margin-left: 20px;
}
.top-site-header ul li a {
color: var(--white);
text-decoration: none;
transform: 0.2s all ease-in-out;
}
.top-site-header ul li a:hover {
color:var(--green);
}
.site-header {
position: relative;
height: 90px;
max-width: var(--max-width);
margin: 0 auto;
transition: 0.2s all ease-in-out;
}
.hide-header {
margin-top:-40px;
}
.show-header {
margin-top:0;
}
.site-title {
position: absolute;
top: 50%;
left: 60px;
transform: translateY(-50%);
}
.site-title img {
width: 180px;
height: auto;
object-fit: contain;
}
.header-cta-container {
position: absolute !important;
top: 50%;
right: 60px;
transform: translateY(-50%);
}
.header-cta-container a.cta {
margin: 0 !important;
} .banner-container {
height: calc(100vh - 130px);    
min-height: 900px;
}
.banner-image {
position: absolute;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
width: 100%;
}
.banner-image img {
width:100%;
height: calc(100vh - 130px);
min-height: 900px;
object-fit: cover;
object-position: center center;
}
.height-40, .height-40 video, .height-40 img {
height: calc(40vh - 130px);
min-height: 450px;
}
.height-50, .height-50 video, .height-50 img {
height: calc(50vh - 130px);
min-height: 550px;
}
.height-60, .height-60 video, .height-60 img {
height: calc(60vh - 130px);
min-height: 600px;
}
.height-70, .height-70 video, .height-70 img {
height: calc(70vh - 130px);
min-height: 600px;
}
.height-80, .height-80 video, .height-80 img {
height: calc(80vh - 130px);
min-height: 600px;
}
.height-90, .height-90 video, .height-90 img {
height: calc(90vh - 130px);
min-height: 600px;
}
.height-100, .height-100 video, .height-100 img {
height: calc(100vh - 130px);
min-height: 600px;
}
.image-overlay {
background:linear-gradient(180deg, rgba(0,0,0,0.6) 0%, rgba(0,0,0,0.6) 100%);
width:100%;
height: 100%;
position: absolute;
top:0;
left:0;
}
.banner-container p {
font-size: 22px;
}
.bottom-banner-wrap {
position: absolute;
left: 50%;
bottom: 40px;
transform: translateX(-50%);
width: 100%;
max-width: 900px;
z-index: 10;
}
.bottom-banner {
position: relative;
padding: 20px;
text-align: center;
border-radius: 10px;
}
.skew:after {
content: "";
position: absolute;
top: 0;
left: 0;
right: 0;
bottom: 0;
background: var(--green);
transform: skew(-27deg);
z-index: -1;
border-radius: 4px;
}
.bottom-banner h4 {
color:var(--white) !important;
}
.bottom-banner-wrap::before {
content: '';
position: absolute;
width: 96%;
height: 90%;
left: 2%;
bottom: 20px;
background: var(--dark-green);
border-radius: 4px;
transform: skew(-27deg);
z-index: -2;
}
.bottom-banner h4 {
margin: 0;
color:var(--white);
}
pre {
font-family: 'Poppins', sans-serif;
}
a.cta, pre a {
display: inline-block;
position: relative;
font-size: 16px;
background: none;
border: none;
padding: 15px 40px 15px 40px;
margin: 10px 10px 0 0;
cursor: pointer;
z-index: 1;
color: var(--white) !important;
text-decoration: none;
font-weight: 700;
min-width: 240px;
text-align: center;
transition: 0.2s all ease-in-out;
}
.site-content a.cta:first-of-type {
margin-left: 14px;
}
a.cta:after, pre a:after {
content: "";
position: absolute;
top: 0;
left: 0;
right: 0;
bottom: 0;
background: var(--green);
transform: skew(-27deg);
z-index: -1;
border-radius: 4px;
transition: 0.2s all ease-in-out;
}
a.cta.secondary-cta:after {
background:var(--dark-green);
}
a.cta:hover:after, pre a:hover:after {
filter:brightness(1.15);
}
a.simple-cta {
position: relative;
display: inline-flex;
align-items: center;
gap: 20px;
margin-top:20px;
text-decoration: none;
font-weight: 700;
font-size: 16px;
transition: 0.2s all ease-in-out;
}
.white-container a.simple-cta, .light-container a.simple-cta {
color:var(--dark) !important;
}
.dark-container a.simple-cta {
color:var(--white) !important;
}
a.simple-cta:after {
content: '';
background: url(https://lvienergia.fi/wp-content/themes/lvienergia/assets/arrow-right-green.svg) no-repeat;
background-size: contain;
width: 20px;
height: 20px;
}
a.simple-cta:hover {
color:var(--green) !important;
gap:30px;
} .breadcrumbs {
font-size: 14px;
}
.breadcrumbs-list {
display: flex;
flex-wrap: wrap;
align-items: center;
gap: 4px;
list-style: none;
margin: 0;
padding: 0 !important;
}
.breadcrumbs-item {
display: flex;
align-items: center;
margin-bottom: 0 !important;
}
.breadcrumbs-link {
text-decoration: none;
color:var(--green) !important;
}
.breadcrumbs-link:hover, .breadcrumbs-link:focus {
text-decoration: underline;
color:var(--orange) !important;
}
.breadcrumbs-item-sep {
user-select: none;
}
.breadcrumbs-item-current {
pointer-events: none;
}
.breadcrumbs-pill {
display: inline-flex;
} .main-navigation {
position: absolute;
left:50%;
top:50%;
transform: translate(-50%,-50%);
}
.main-navigation .menu {
display: flex;
gap: 0;
}
.menu-indicator {
position: absolute;
bottom: 0;
height: 2px;
width: 0;
background: var(--dark-green);
transition: all 0.2s ease-in-out;
}
.main-navigation ul {
padding: 0;
margin: 0;
}
.main-navigation ul li {
list-style-type: none;
display: inline-block;
position: relative;
margin-right: 6px;
}
.main-navigation ul li:last-of-type {
margin-right: 0;
}
.main-navigation ul li a {
display: inline-block;
position: relative;
color: var(--dark);
font-size: 16px;
letter-spacing: -0.2px;
font-weight: 700;
text-decoration: none;
padding: 32px 16px;
z-index: 3;
transition: 0.2s color ease-in-out;
}
.main-navigation ul li a:hover {
color: var(--green);
}
.main-navigation ul ul {
position: fixed;
display: block;
opacity: 0;
visibility: hidden;
padding: 0;
left: 50%;
transform: translateX(-50%);
min-height: 360px;
width: calc(var(--max-width) - 120px);
top: 90px;
background: var(--white);
padding: 20px 0;
text-align: left;
border:solid 1px rgba(0,0,0,0.1);
}
.main-navigation .menu-item-has-children:before {
content: '';
width: 100%;
height: 10px;
position: absolute;
bottom: -10px;
}
.main-navigation .menu-item-has-children:after {
content: '';
background: url(https://lvienergia.fi/wp-content/themes/lvienergia/assets/arrow-down-dark.svg) no-repeat;
background-size: contain;
width: 18px;
height: 18px;
position: absolute;
right: -4px;
top: 50%;
z-index: 1;
transform: translateY(-50%);
transition: all 0.3s ease-in-out;
}
.main-navigation .menu-item-has-children:hover:after {
color: var(--green) !important;
}
.main-navigation ul li:hover>ul {
opacity: 1;
visibility: visible;
margin-top: 0;
}
.main-navigation ul ul li {
display: block;
width: calc(100% / 3);
}
.main-navigation ul ul li a {
display: block;
padding: 20px 40px;
transition: 0.2s all ease-in-out;
}
.main-navigation ul ul ul {
position: fixed;
left: 50%;
width: 33.33%;
height: calc(100% - 1px);
min-height: unset;
top: 0;
box-shadow: none;
border-bottom: none;
border-top:none;
}
.main-navigation ul ul ul li {
width: 100%;
}
.main-navigation ul ul ul ul {
position: fixed;
left: 150%;
width: 100%;
height: 100%;
top: 0;
box-shadow: none;
border-right:none;
border-top:none;
}
.main-navigation ul ul li.menu-item-has-children:after {
right: 40px;
color: var(--white);
transform: translateY(-50%) rotate(-90deg);
}
.current-menu-item>a {
color: var(--green) !important;
}
.current-menu-item.menu-item-has-children:after {
color: var(--green) !important;
}
.current-menu-ancestor ul li a:hover {
color: var(--green) !important;
} .mobile-menu {  
display: none;
position: absolute;
right: 40px;
top: 50%;
transform: translateY(-50%);        
z-index: 102;
transition: all 300ms ease-in-out;
}
#nav-icon {
width: 24px;
height: 18px;
position: relative;
z-index: 100; 
transform: rotate(0deg);
transition: .5s ease-in-out;
cursor: pointer;
}
#nav-icon span {
display: block;
position: absolute;
height: 2px;
width: 24px;
background: var(--dark);
opacity: 1;
left: 0;
transform: rotate(0deg);
transition: .25s ease-in-out;
}
#nav-icon span:nth-child(1) {
top: 0px;
}
#nav-icon span:nth-child(2),#nav-icon span:nth-child(3) {
top: 8px;
}
#nav-icon span:nth-child(4) {
top: 16px;
}
#nav-icon.open span:nth-child(1) {
top: 14px;
width: 0%;
left: 50%;
}
#nav-icon.open span:nth-child(2) {
transform: rotate(45deg);
}
#nav-icon.open span:nth-child(3) {
transform: rotate(-45deg);
}
#nav-icon.open span:nth-child(4) {
top: 14px;
width: 0%;
left: 50%;
} .overlay {
background: var(--light);
width: 100%;    
position: fixed;
z-index: 999;    
top: 130px;
left:0;
padding: 40px;
visibility: hidden;
opacity: 0;
max-height: calc(100vh - 130px);
overflow-y: auto;
}
.overlay ul {
padding:0;
margin:0;
}
.overlay ul li {
position: relative;
padding:8px 0;
margin:0;
cursor:pointer;
list-style-type: none;
}
.overlay ul li a {
display: inline-block;
position: relative;
text-decoration: none;
color:var(--black);
font-size: 24px;
font-weight: 600;
transition: 0.2s all ease-in-out;
}
.overlay ul li a:hover {
color:var(--orange) !important;
}
.overlay ul ul {
margin-top: 14px;
}
.overlay ul ul li a {
font-size: 20px;
}
.overlay ul ul li {
padding: 4px 0 4px 14px;
}
.open-menu {
visibility: visible;
opacity: 1;
}
.overlay ul.menu li.menu-item-has-children:before {
content: '';
background: url(https://lvienergia.fi/wp-content/themes/lvienergia/assets/arrow-down-dark.svg) no-repeat;
background-size: contain;
width: 22px;
height: 22px;
position: absolute;
right: 0;
top: 10px;
transition: 0.2s all ease-in-out;
}
.overlay ul.menu ul li.menu-item-has-children:before {
top: 5px;
}
.overlay ul.menu li.menu-item-has-children.rotate-arrow:before {
transform: rotate(180deg);
} .white-container {
position: relative;
background:var(--white);
}
.white-container :is(h1, h2, h3, h4, h5, h6){
color:var(--dark-green);
}
.white-container :is(p, li, td, strong, a){
color:var(--dark);
}
.light-container {
position: relative;
background:var(--light);
}
.light-container :is(h1, h2, h3, h4, h5, h6){
color:var(--dark-green);
}
.light-container :is(p, li, td, strong, a){
color:var(--dark);
}
.dark-container {
position: relative;
background: var(--dark);
}
.dark-container :is(h1, h2, h3, h4){
color:var(--white);
}
.dark-container :is(h5, h6){
color:var(--green);
}
.dark-container :is(p, li, td, strong, a){
color:var(--white);
}
.dark-container :is(h1 strong, h2 strong, h3 strong, h4 strong, h5 strong, h6 strong){
color:var(--green);
}
.green-container {
position: relative;
background:var(--green);
}
.green-container :is(h1, h2, h3, h4, h5, h6, p, li, td, strong, a){
color:var(--white);
}
.medium-green-container {
position: relative;
background:var(--medium-green);
}
.medium-green-container :is(h1, h2, h3, h4, h5, h6, p, li, td, strong, a){
color:var(--white);
}
.banner-overlay {  
position: absolute;
top:0;
left:0;
width:100%;
height: 100%;
background-image: radial-gradient(rgb(57 181 74 / 15%) 3px, transparent 1px);
background-size: 60px 60px;
background-position: center;
}
main.main-content {
padding-top: 130px;
}
.site-content {
width:100%;
max-width: var(--max-width);
margin:0 auto;
padding: 100px 60px;
position: relative;
z-index: 1;
}
.site-content.padding-top-100 {
padding-top: 100px;
}
.site-content.padding-top-80 {
padding-top: 80px;
}
.site-content.padding-top-60 {
padding-top: 60px;
}
.site-content.padding-top-40 {
padding-top: 40px;
}
.site-content.padding-top-20 {
padding-top: 20px;
}
.site-content.padding-bottom-100 {
padding-bottom: 100px;
}
.site-content.padding-bottom-80 {
padding-bottom: 80px;
}
.site-content.padding-bottom-60 {
padding-bottom: 60px;
}
.site-content.padding-bottom-40 {
padding-bottom: 40px;
}
.site-content.padding-bottom-20 {
padding-bottom: 20px;
}
.site-content ul {
padding-left: 0;
}
.site-content ul li {
list-style: none;
position: relative;
padding-left: 20px;
margin-bottom: 6px;
}
.site-content ol {
padding-left: 20px;
}
.site-content ol li  {
position: relative;
margin-bottom: 6px;
}
::marker {
color: var(--green);
}
.site-content ul li::before {
content: '';
position: absolute;
left: 0;
top: 9px;
width: 8px;
height: 8px;
background: var(--green);
border-radius: 20px;
}
ol.custom-list li {
font-size: 18px;
background: rgb(0 0 0 / 0%);
padding: 8px;
margin-bottom: 10px;
backdrop-filter: blur(40px);
border-bottom: solid 1px rgba(255, 255, 255, 0.1);
}
.site-content p a, .site-content li a {
text-decoration: none;
font-weight: 600;
color:var(--green);
}
.flex-container {
display: flex;
flex-wrap: wrap;
justify-content: space-between;
}
.flex-container img {
width:100%;
}
.flex-start {
justify-content: start;
}
.flex-center {
justify-content: center;
}
.flex-end {
justify-content: end;
}
.align-start {
align-items: start;
}
.align-center {
align-items: center;
}
.align-end {
align-items: end;
}
.flex-100 {
width:100%;
}
.flex-66 {
width:calc(66.66% - 20px);
position: relative;
}
.flex-60 {
width:calc(60% - 20px);
position: relative;
}
.flex-50 {
width:calc(50% - 30px);
position: relative;
}
.flex-40 {
width:calc(40% - 20px);
position: relative;
}
.flex-33 {
width:calc(33.33% - 20px);
position: relative;
}
.flex-25 {
width:calc(25% - 20px);
position: relative;
}
.flex-20 {
width:calc(20% - 20px);
position: relative;
}
.flex-image img, .flex-image video {
width: 100%;
height: 600px;
display: block;
object-fit: cover;
border-radius: 10px;
}
.media-text .flex-image {
order:1;
}
.media-text .flex-text {
order:2;
}
.text-media .flex-image.mask img {
mask-image: url(//lvienergia.fi/wp-content/themes/lvienergia/assets/lvienergia-icon-black.svg);
-webkit-mask-image: url(//lvienergia.fi/wp-content/themes/lvienergia/assets/lvienergia-icon-black.svg);
mask-repeat: no-repeat;
mask-size: 100% 100%;
}
.media-text .flex-image.mask img {
mask-image: url(//lvienergia.fi/wp-content/themes/lvienergia/assets/lvienergia-leaf-black.svg);
-webkit-mask-image: url(//lvienergia.fi/wp-content/themes/lvienergia/assets/lvienergia-leaf-black.svg);
mask-repeat: no-repeat;
mask-size: 100% 100%;
}
.flex-50-50 .flex-text {
width: calc(50% - 20px); 
}
.flex-33-66 .flex-text:nth-of-type(1) {
width: calc(33.33% - 20px); 
}
.flex-33-66 .flex-text:nth-of-type(2) {
width: calc(66.66% - 20px); 
}
.flex-66-33 .flex-text:nth-of-type(1) {
width: calc(66.66% - 20px); 
}
.flex-66-33 .flex-text:nth-of-type(2) {
width: calc(33.33% - 20px); 
}
.flex-text p:last-of-type {
margin-bottom: 0;
}
.center {
text-align: center;
margin:0 auto;
max-width: 991px;
}
.center p {
font-size: 22px;
}
.values-container .flex-33 {
padding: 0 30px;
border-right: solid 1px var(--green);
}
.values-container .flex-33:last-of-type {
border-right: none;
}
.values-container h5 {
margin:0;
}
.values-container p {
margin-bottom:0;
} .icon-container {
gap: 15px;
}
img.icon {
width: 30px !important;
} .main-post-content .site-content {
max-width: 991px;
}
.post-banner-image {
position: relative;
margin-bottom: 40px;
}
.post-banner-image img {
width: 100%;
max-height: 700px;
object-fit: cover;
object-position: center top;
border-radius: 10px;
}
.post-banner-header h1 {
font-size: 56px;
margin-bottom: 20px;
}
.post-banner-header p {
font-size: 22px;
}
a.post-category, a.post-tag, p.post-category {
background: var(--orange);
padding: 6px 14px;
display: inline-block;
color: var(--dark);
font-weight: 700;
font-size: 13px;
text-decoration: none;
}
p.post-category {
position: absolute;
top: 10px;
left: 10px;
margin: 0;
}
p.date {
font-size: 14px !important;
margin-bottom: 0;
font-weight: 600;
color: var(--green) !important;
}
figure {
position: relative;
}
figure.wp-block-image img {
width: 100%;
margin-top: 30px;
}
figcaption.wp-element-caption {
position: absolute;
bottom: 0;
width: 100%;
background: var(--blue);
margin: 0;
padding: 10px;
text-align: center;
font-size: 14px;
border-radius: 0 0 20px 20px;
color: var(--white);
font-weight: bold;
}
.author-excerpt {
margin-top: 10px;
}
.post-menu-container {
overflow: hidden;
}
.post-menu-container p {
font-size: 16px;
font-weight: 600;
margin-bottom: 10px !important;
margin-top: 0;
color: var(--dark) !important;
}
.post-menu-container a {
font-size: 20px;
letter-spacing: -0.4px;
font-weight: 700;
text-decoration: none;
transition: 0.2s all ease-in-out;
color: var(--dark) !important;
}
.previous-post {
width: 50%;
padding: 40px;
background: var(--white);
border-radius: 6px;
}
.next-post {
width: 50%;
padding: 40px;
background: var(--green);
border-radius: 6px;
}
.next-post a {
color: var(--white) !important;
} .flex-container.grid-box-container {
justify-content: start;
gap: 30px;
}
.grid-box-text {
padding:40px;
}
.grid-box-text :is(h1, h2, h3, h4, h5) {
margin-top:0;
margin-bottom: 0;
}
.grid-box-text p {
margin-bottom: 20px;
}
.white-container .grid-box {
background:var(--light);
}
.light-container .grid-box {
background:var(--white);
}
.dark-container .grid-box {
background:var(--dark-green);
}
.grid-box-media img {
height: 350px;
width:100%;
object-fit:cover;
object-position: center top;
background: rgb(13 61 20 / 15%);
}
.grid-box {
display: flex;
flex-direction: column;
border-radius: 6px;
overflow: hidden;
}
.grid-box-text {
display: flex;
flex-direction: column;
flex: 1;
}
.grid-box-text .simple-cta {
margin-top: auto;
}
.grid-box-icon {
margin-bottom: 40px;
}
.grid-box-icon img {
height: 40px;
width: 40px;
object-fit: contain; 
}
.flex-50.grid-box.blog-post {
width:calc(50% - 15px);
} .blog-post img {
height: 350px;
width:100%;
object-fit: cover;
object-position: center top;
}
.blog-post h4 {
margin:0;
font-size: 24px;
}
.blog-post h4 a {
text-decoration: none;
}
.post-list-date {
margin-top:0;
font-size: 12px;
font-weight: 600;
color:var(--green) !important;
text-transform: capitalize;
}
h2.wp-block-heading {
margin-top: 30px;
} .image-container.dark-container {
overflow: hidden;
display: flex;
height: 50vh;
align-items: center;
}
.image-container .center {
margin:0 auto;
} .accordion {
margin-bottom: 20px;
}
.accordion-item {
position: relative;
overflow: hidden;
transition: 0.2s all ease-in-out;
cursor: pointer;
margin-bottom: 12px;
width: 100%;
}
.white-container .accordion-item {
background: var(--light);
}
.light-container .accordion-item {
background: var(--white);
}
.dark-container .accordion-item {
background: var(--green);
}
.accordion-title {
margin: 20px 20px 20px 0;
padding-bottom: 0;
padding-left: 20px;
transition: 0.2s all ease-in-out;
}
.accordion-item::after {
content: '';
background: url(https://lvienergia.fi/wp-content/themes/lvienergia/assets/arrow-down-dark.svg) no-repeat;
background-size: contain;
width: 22px;
height: 22px;
position: absolute;
top: 24px;
right: 20px;
z-index: 1;
transition: all 0.2s ease-in-out;
}
.dark-container .accordion-item::after {
color: var(--white);
}
.accordion-content {
padding: 0 20px 20px 20px;
display: none;
}
.accordion-content a {
color: var(--green);
text-decoration: none;
}
.accordion-content p {
margin-top: 0;
}
.accordion-item.active::after {
transform: rotate(180deg);
}
.accordion-content ul {
margin-top: 0;
} #pyyda-tarjous {
border-top: solid 1px rgb(57 181 74 / 30%);
}
.wpforms-container {
margin-top: 0 !important;
}
.wpforms-field {
overflow: visible !important;
}
.wpforms-field-large {
height: 70px !important;
border: none !important;
border-radius: 6px !important;
background: var(--white) !important;
color: var(--dark) !important;
font-size: 16px !important;
padding-left: 30px !important;
font-family: 'Poppins', sans-serif !important;
}
.wpforms-field-medium {
height: 320px !important;
border: none !important;
border-radius: 6px !important;
background: var(--white) !important;
color: var(--dark) !important;
font-size: 16px !important;
padding-left: 30px !important;
padding-top:30px !important;
font-family: 'Poppins', sans-serif !important;
}
.wpforms-submit {
height: 59px !important;
color:var(--white) !important;
background: none !important;
border:none !important;
border-radius: 0 !important;
padding: 20px 80px !important;
min-width: 240px !important;
font-size: 16px !important;
font-weight: 700 !important;
transition: 0.3s all ease-in-out !important;
font-family: 'Poppins', sans-serif !important;
}
.wpforms-form .wpforms-field {
position: relative;
}
.wpforms-form .wpforms-field-label {
position: absolute;
top: 40px;
left: 20px;
pointer-events: none;
transition: all 0.2s ease;
z-index: 2;
}
.wpforms-form .wpforms-field:has(input:focus) > .wpforms-field-label,
.wpforms-form .wpforms-field:has(input:not(:placeholder-shown)) > .wpforms-field-label,
.wpforms-form .wpforms-field:has(textarea:focus) > .wpforms-field-label,
.wpforms-form .wpforms-field:has(textarea:not(:placeholder-shown)) > .wpforms-field-label {
top: -9px;
left: 0;
font-size: 14px;
color: var(--green); 
}
.wpforms-submit:after {
content: "";
position: absolute;
top: 0;
left: 0;
right: 0;
bottom: 0;
background: var(--green);
transform: skew(-27deg);
z-index: -1;
border-radius: 4px;
transition: 0.2s all ease-in-out;
}
.wpforms-submit:hover:after {
filter: brightness(1.15);
}
.valitse-palvelu .wpforms-field-label {
position: relative !important;
left: unset;
top: unset !important;
text-align: left;
}
.wpforms-field-checkbox ul {
display: inline-flex !important;
flex-wrap: wrap !important;
}
.wpforms-field-checkbox ul li:before {
display: none;
}
.wpforms-field select {
background: var(--green) !important;
border: none !important;
height: 60px !important;
border-radius: 10px !important;
font-size: 18px !important;
font-weight: 500 !important;
margin-bottom: 4px !important;
font-family: 'Poppins', sans-serif !important;
}
.wpforms-field-checkbox input[type="checkbox"] {
display: none !important;
}
.wpforms-field-checkbox label {
display: inline-block !important;
padding: 12px 23px 10px 23px !important;
border-radius: 4px !important;
border: none !important;
background: var(--white) !important;
cursor: pointer !important;
font-size: 16px !important;
font-family: 'Poppins', sans-serif !important;
font-weight: 700 !important;
color: var(--dark) !important;
transition: all 0.2s ease !important;
}
.wpforms-field-checkbox label:hover {
background:var(--green) !important;
color:var(--white) !important;
}
.wpforms-field-checkbox input[type="checkbox"]:checked+label {
background: var(--green) !important;
color: var(--white) !important;
} .logo-container {
gap: 80px;
}
.logo-container img {
max-width: 120px;
max-height: 50px;
object-fit: contain;
} #footercontainer h4 {
margin-bottom: 20px;
color: var(--green);
}
#footercontainer ul {
padding:0;
margin:0 0 20px 0;
}
#footercontainer ul li {
list-style-type: none;
font-size: 20px;
line-height: 1.7;
}
#footercontainer .site-content ul li::before {
top: 13px;
}
#footercontainer ul li a {
text-decoration: none;
transition: 0.3s all ease-in-out;
color:var(--white);
}
#footercontainer ul li a:hover {
color:var(--orange);
}
#footercontainer p {
font-size: 14px;
}
.smallprint {
margin-top: 40px;
padding-top: 40px;
border-top: solid 1px rgba(255, 255, 255, 0.1);
}
#footercontainer {
overflow:hidden;
}
#footercontainer:after {
content:'';
background: url(https://lvienergia.fi/wp-content/themes/lvienergia/assets/lvienergia-icon.svg) no-repeat;
width: 40vw;
height: 34vw;
position: absolute;
right: 0;
bottom: 0;
opacity: 0.05;
} @media(max-width:1367px){
.open-body {
overflow: hidden;
}
.site-title {     
left: 40px;
}
.main-navigation {
display: none;
}
.mobile-menu {
display: block;
}
.header-cta-container {
right:100px;
}
.site-content {     
padding: 80px 40px;        
}
}
@media(max-width:1200px){
h1, .banner-container h1 {
font-size: 56px;
}
h2 {
font-size: 36px;
}
h3 {
font-size: 24px;
}
h4 {
font-size: 20px;
}
h5 {
font-size: 20px;
}
.flex-33 {
width: calc(50% - 15px);        
}
.full-width-text {
max-width: 100% !important;
}
}
@media(max-width:991px){
h1, .post-banner-header h1, .banner-container h1  {
font-size: 48px;
}
h2 {
font-size: 32px;
}
h3 {
font-size: 22px;
}
h4 {
font-size: 18px;
}
h5 {
font-size: 18px;
}
p, li {
font-size: 16px;
}
a.cta, pre a {
font-size: 16px;        
}   
.post-banner-header p {
font-size: 18px;
}
.center p {
font-size: 18px;
}
.values-container .flex-33 {
padding: 0;        
width: 100%;
border-right: none;
margin-bottom: 40px;
}
.values-container .flex-33:last-of-type {
margin-bottom: 0;
}
.flex-50 {
width: 100%;
}
.flex-50.flex-text {
order:1;
margin-bottom: 40px;
}
.flex-50.flex-image {
order:2;
}
.flex-image img, .flex-image video {
height: auto;
max-height: 400px;
}
.banner-container {        
min-height: 600px;
}
.banner-image img {
min-height: 600px;
}
.flex-50.grid-box.blog-post {
width: 100%;
}
.blog-post img {
height: 100%;
max-height: 50vh;     
}
}
@media(max-width:768px){
.top-site-header {     
padding: 6px 30px;
}
.site-title {
left: 30px;
}
.site-title img {
width: 160px;
}
.mobile-menu {
right: 30px;
}
h1, .post-banner-header h1, .banner-container h1  {
font-size: 42px;
}
h2 {
font-size: 30px;
}
h3 {
font-size: 20px;
}	
.site-content {     
padding: 60px 30px;        
}
.site-content.padding-top-100 {
padding-top: 60px;
}
.site-content.padding-top-80 {
padding-top: 40px;
}
.site-content.padding-top-60 {
padding-top: 40px;
}
.site-content.padding-top-40 {
padding-top: 20px;
}
.site-content.padding-bottom-100 {
padding-bottom: 60px;
}
.site-content.padding-bottom-80 {
padding-bottom: 40px;
}
.site-content.padding-bottom-60 {
padding-bottom: 40px;
}
.site-content.padding-bottom-40 {
padding-bottom: 20px;
}
.header-cta {
display: none;
}
a.cta, pre a { 
padding: 15px 30px 15px 30px;
min-width: 200px;
}
.flex-33 {
width: 100%;
margin-bottom: 30px;
}
.flex-33:last-of-type {
margin-bottom: 0;
}
.bottom-banner-wrap {
position: relative;
width:calc(100% - 80px);
bottom: unset;
transform: none;
left: unset;
margin: 0 auto;
}
.bottom-banner-wrap::before {     
width: 90%;
left: 6%;
}
.grid-box-text {
padding: 30px;
}
.flex-50.flex-text {
margin-bottom: 30px;
}    
.previous-post, .next-post {
padding: 40px;
}
#footercontainer .flex-33 {
margin-bottom: 0;
}
.logo-container {
gap: 40px;
}
}
@media(max-width:520px){
.top-site-header {     
padding: 6px 20px;
}
.site-header {
height: 70px;
}
.site-title {
left: 20px;
}
.mobile-menu {
right: 20px;
}
.header-cta-container {
display: none;
}
.overlay {     
top: 110px;
padding: 20px;
max-height: calc(100vh - 110px);
}
.scrolling-down .overlay {
top: 70px;       
max-height: calc(100vh - 70px);
}
main.main-content {
padding-top: 110px;
}
h1, h2, h3, h4, h5, h6 {
letter-spacing: 0;
}
h1, .post-banner-header h1, .banner-container h1  {
font-size: 30px;
}
h2 {
font-size: 26px; 
}
h3 {
font-size: 18px;
}
h4 {
font-size: 16px;
}
h5 {
font-size: 16px;
} 
h6 {
font-size: 14px;
margin: 0 0 20px 0;
}
.banner-container {
height: unset;
}
.post-banner-header p {
font-size: 16px;
}
.bottom-banner {     
padding: 10px 20px;
}
.center p {
font-size: 16px;
}
p, li {
font-size: 14px;
}
.site-content ul li::before {
top: 5px;
}
a.cta, pre a {
font-size: 14px;    
padding: 15px 20px 15px 20px;
min-width: 180px;    
}
a.simple-cta {
font-size: 14px;
}
.site-content a.cta, .site-content pre a {
width:calc(100% - 30px);
}
.overlay-content {
padding:40px;
}
.overlay ul li a {
line-height: 26px;
font-size: 20px;
}
.overlay ul ul li a {
font-size: 15px;
}   
.site-content {     
padding: 30px 20px;        
}
.site-content.padding-top-100 {
padding-top: 30px;
}
.site-content.padding-top-80 {
padding-top: 20px;
}
.site-content.padding-top-60 {
padding-top: 20px;
}
.site-content.padding-top-40 {
padding-top: 20px;
}
.site-content.padding-bottom-100 {
padding-bottom: 30px;
}
.site-content.padding-bottom-80 {
padding-bottom: 20px;
}
.site-content.padding-bottom-60 {
padding-bottom: 20px;
}
.site-content.padding-bottom-40 {
padding-bottom: 20px;
}
.grid-box-text {
padding: 20px;
}
.grid-box-media img {
height: 250px;     
}
.blog-post img {
height: 250px;
}
.flex-33 {
margin-bottom: 20px;
}    
.previous-post, .next-post {
padding: 20px;
}
.post-menu-container p {
font-size: 14px;
}
#footercontainer ul li {     
font-size: 16px;
}
#footercontainer .site-content ul li::before {
top: 9px;
}
.wpforms-field-large {
height: 60px !important;     
font-size: 14px !important;
}
.wpforms-field-medium {
height: 240px !important;     
font-size: 14px !important;
}
.wpforms-form .wpforms-field-label {     
top: 36px;
font-size: 14px !important;
}
.wpforms-field-checkbox label {
font-size: 14px !important;
}
.flex-container.grid-box-container {
gap: 20px;
}
}
@media(max-width: 420px){
h6 {
font-size: 12px;
}
.post-banner-header p {
font-size: 15px;
}
.center p {
font-size: 15px;
}
p, li {
font-size: 13px;
}
a.cta, pre a {
font-size: 13px;    
padding: 14px 18px 14px 18px;
min-width: 160px;    
}
a.simple-cta {
font-size: 13px;
}
.wpforms-field-large {
height: 54px !important;     
font-size: 13px !important;
}
.wpforms-field-medium {
height: 200px !important;     
font-size: 13px !important;
}
.wpforms-form .wpforms-field-label {     
top: 32px;
font-size: 13px !important;
}
.wpforms-field-checkbox label {
font-size: 13px !important;
}
}