@font-face {
  font-family: Blmelody;
  src: url('../fonts/BLMelody-Bold.woff2') format("woff2");
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: Blmelody;
  src: url('../fonts/BLMelody-ExtraLight.woff2') format("woff2");
  font-weight: 200;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: Blmelody;
  src: url('../fonts/BLMelody-Light.woff2') format("woff2");
  font-weight: 300;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: Blmelody;
  src: url('../fonts/BLMelody-Regular.woff2') format("woff2");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: Blmelody;
  src: url('../fonts/BLMelody-SemiBold.woff2') format("woff2");
  font-weight: 600;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: Blmelody;
  src: url('../fonts/BLMelody-Medium.woff2') format("woff2");
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: Blmelody Book;
  src: url('../fonts/BLMelody-Book.woff2') format("woff2");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

:root {
  --waves-library-white: white;
  --waves-library-black: #131313;
  --v: #329a45;
  --black: black;
  --white: white;
}

.w-layout-grid {
  grid-row-gap: 16px;
  grid-column-gap: 16px;
  grid-template-rows: auto auto;
  grid-template-columns: 1fr 1fr;
  grid-auto-columns: 1fr;
  display: grid;
}

.w-checkbox {
  margin-bottom: 5px;
  padding-left: 20px;
  display: block;
}

.w-checkbox:before {
  content: " ";
  grid-area: 1 / 1 / 2 / 2;
  display: table;
}

.w-checkbox:after {
  content: " ";
  clear: both;
  grid-area: 1 / 1 / 2 / 2;
  display: table;
}

.w-checkbox-input {
  float: left;
  margin: 4px 0 0 -20px;
  line-height: normal;
}

.w-checkbox-input--inputType-custom {
  border: 1px solid #ccc;
  border-radius: 2px;
  width: 12px;
  height: 12px;
}

.w-checkbox-input--inputType-custom.w--redirected-checked {
  background-color: #3898ec;
  background-image: url('https://d3e54v103j8qbb.cloudfront.net/static/custom-checkbox-checkmark.589d534424.svg');
  background-position: 50%;
  background-repeat: no-repeat;
  background-size: cover;
  border-color: #3898ec;
}

.w-checkbox-input--inputType-custom.w--redirected-focus {
  box-shadow: 0 0 3px 1px #3898ec;
}

.w-layout-vflex {
  flex-direction: column;
  align-items: flex-start;
  display: flex;
}

body {
  color: #333;
  font-family: Blmelody Book, sans-serif;
  font-size: 15px;
  line-height: 20px;
}

a {
  color: #232323;
  text-decoration: none;
}

.collection-list-wrapper {
  column-count: 3;
  column-gap: 25px;
  width: 90vw;
  max-width: 1400px;
  margin-left: auto;
  margin-right: auto;
  display: block;
}

.collection-list-wrapper.hide {
  display: none;
}

.collection-list-wrapper.test-grid {
  grid-column-gap: 16px;
  grid-row-gap: 16px;
  grid-template-rows: auto auto;
  grid-template-columns: 1fr 1fr 1fr;
  grid-auto-columns: 1fr;
  display: grid;
}

.collection-list-wrapper.col4 {
  column-count: 4;
  max-width: 88vw;
}

.img {
  width: 100%;
}

.img.testi {
  aspect-ratio: 1;
  object-fit: cover;
}

.collection-item {
  margin-bottom: 25px;
}

.heading {
  text-align: center;
  margin-top: 10vh;
  margin-bottom: 10vh;
  font-family: Blmelody, sans-serif;
  font-weight: 700;
}

.heading.no-bot {
  margin-bottom: 3rem;
}

.heading.no-bot.no-top {
  margin-top: 3rem;
}

.section-kuvat {
  justify-content: center;
  align-items: center;
}

.section-kuvat._2 {
  margin-top: 85px;
}

.section-kuvat._2.hide {
  display: none;
}

.waves---cta-white {
  background-color: var(--waves-library-white);
  color: var(--waves-library-black);
  border-radius: 8px;
  justify-content: center;
  align-items: center;
  height: 52px;
  padding: 8px 24px;
  font-size: 16px;
  font-weight: 700;
  display: flex;
}

.waves---cta-white.wide-cta {
  background-color: var(--v);
  color: var(--waves-library-white);
  min-width: 200px;
  font-family: Blmelody, sans-serif;
  line-height: 1.1;
}

.waves---cta-white.wide-cta.hide {
  display: none;
}

.waves---mg-top-16 {
  margin-top: 16px;
}

.tekstikohta {
  color: var(--waves-library-black);
  text-align: center;
  font-family: Blmelody Book, sans-serif;
  font-size: 1.2rem;
  font-weight: 400;
  line-height: 1.4;
}

.tekstikohta.piilossa {
  display: none;
}

.tesksti-sisalla {
  width: 100%;
  max-width: 800px;
}

.waves---mega-heading-1 {
  color: var(--waves-library-black);
  text-transform: uppercase;
  margin-top: 0;
  margin-bottom: 0;
  font-family: Blmelody, sans-serif;
  font-size: 3rem;
  font-weight: 700;
  line-height: 115%;
}

.waves-title-wrap-hero-5 {
  z-index: 1;
  grid-row-gap: 24px;
  flex-direction: column;
  align-items: center;
  padding-top: 24px;
  display: flex;
  position: relative;
}

.waves---main-container {
  max-width: 1352px;
  padding-left: 24px;
  padding-right: 24px;
}

.waves-gradient-hero-5 {
  position: absolute;
  inset: 0%;
}

.waves-section-hero-5 {
  color: var(--waves-library-white);
  background-image: url('../images/_DSC2373.jpg');
  background-position: 50%;
  background-size: cover;
  padding-top: 340px;
  padding-bottom: 88px;
  position: relative;
}

.waves-section-hero-5.valok {
  background-image: url('../images/Tapiola_canvas_110x170cm.jpg');
}

.waves-section-hero-5.valok.elok {
  background-image: url('../images/TjaJ_talo.jpg');
}

.waves-section-hero-5.valok.elok.videok {
  background-image: url('../images/talviheinttunturissa.jpg');
}

.waves-section-hero-5.valok.hide {
  display: none;
}

.waves-section-hero-5.yht {
  background-image: url('../images/TeMaMa_20190710_115.jpg');
}

.waves-section-hero-5.yht.hide {
  display: block;
}

.waves-section-hero-5._2323232 {
  padding-top: 24px;
  padding-bottom: 24px;
}

.waves-section-hero-5._2323232.qw {
  background-image: none;
}

.waves-section-hero-5._2323232.qw._2 {
  margin-top: 85px;
}

.waves---nav-cta {
  background-color: var(--waves-library-black);
  border-radius: 8px;
  justify-content: center;
  align-items: center;
  height: 52px;
  padding: 8px 24px;
  font-family: Blmelody Book, sans-serif;
  font-size: 16px;
  font-weight: 700;
  display: flex;
}

.waves---nav-buttons-right {
  justify-content: flex-end;
  align-items: center;
  display: flex;
}

.waves---nav-link {
  color: var(--v);
  padding: 12px 16px;
  font-family: Blmelody, sans-serif;
}

.waves---nav-link.w--current {
  color: var(--black);
}

.waves---nav-link.mb {
  display: none;
}

.waves---dropdown-link {
  text-align: center;
}

.waves-dropdown-list.w--open {
  background-color: var(--waves-library-white);
  border: 1px solid #1313131a;
  border-radius: 4px;
}

.waves-icon-drodpdown {
  width: 24px;
  height: 24px;
}

.waves-dropdown-toggle {
  grid-column-gap: 6px;
  justify-content: center;
  align-items: center;
  padding: 12px 8px 12px 16px;
  display: flex;
}

.waves---nav-menu, .waves-right-nav-1 {
  grid-column-gap: 16px;
  justify-content: flex-end;
  align-items: center;
  display: flex;
}

.waves---brand {
  max-width: none;
  height: 100%;
}

.waves-master-nav-1 {
  justify-content: space-between;
  align-items: center;
  width: 100%;
  height: 100%;
  display: flex;
}

.waves---nav-container {
  max-width: 1440px;
  height: 100%;
  padding-left: 24px;
  padding-right: 24px;
}

.waves-navbar-1 {
  z-index: 105;
  background-color: var(--waves-library-white);
  border-bottom: 1px solid #13131333;
  height: 80px;
  position: fixed;
  inset: 0% 0% auto;
}

.logo {
  color: var(--v);
  text-transform: uppercase;
  font-family: Blmelody, sans-serif;
  font-size: 2rem;
  font-weight: 300;
  line-height: 1.2;
}

.waves---paragraph-small {
  font-family: Blmelody Book, sans-serif;
  font-size: 16px;
  line-height: 130%;
}

.waves---check-icon {
  width: 24px;
  height: 24px;
}

.waves---single-check-item {
  grid-column-gap: 6px;
  justify-content: flex-start;
  align-items: center;
  display: flex;
}

.waves---master-checks-vertical {
  grid-row-gap: 12px;
  flex-direction: column;
  align-items: flex-start;
  display: flex;
}

.waves---paragraph-big {
  font-family: Blmelody Book, sans-serif;
  font-size: 20px;
  line-height: 130%;
}

.waves---heading-2-no-margins {
  color: var(--v);
  margin-top: 0;
  margin-bottom: 0;
  font-family: Blmelody, sans-serif;
  font-size: 48px;
  line-height: 130%;
}

.waves---content-image-halves {
  grid-row-gap: 24px;
  flex-direction: column;
  align-items: flex-start;
  width: 100%;
  max-width: 520px;
  display: flex;
}

.waves-image-features-4 {
  object-fit: cover;
  border-radius: 8px;
  width: 100%;
}

.waves---grid-image-halves {
  grid-column-gap: 40px;
  grid-template-rows: auto;
}

.tulossa-kohta {
  padding-top: 100px;
  padding-bottom: 100px;
  display: block;
}

.flex-block-2 {
  grid-column-gap: 16px;
  grid-row-gap: 16px;
  grid-template-rows: auto auto;
  grid-template-columns: 1fr 1fr;
  grid-auto-columns: 1fr;
  display: grid;
}

.collection-list {
  display: block;
}

.waves-footer-1 {
  background-color: #fff;
  padding-top: 80px;
  padding-bottom: 64px;
}

.waves-top-footer-1 {
  justify-content: space-between;
  align-items: center;
  display: flex;
}

.waves-brand-link-footer-1 {
  grid-column-gap: 1rem;
  grid-row-gap: 1rem;
  align-items: center;
  height: 59px;
  text-decoration: none;
  display: flex;
}

.waves-bottom-right-footer-1 {
  grid-column-gap: 24px;
  justify-content: flex-end;
  align-items: center;
  display: flex;
}

.waves-brand-footer-1 {
  height: 100%;
}

.waves-icon-24 {
  width: 75px;
}

.waves-link-footer-1 {
  font-family: Blmelody, sans-serif;
  text-decoration: none;
}

.waves-top-right-footer-1 {
  grid-column-gap: 32px;
  justify-content: flex-end;
  align-items: center;
  display: flex;
}

.waves-bottom-footer-1 {
  justify-content: space-between;
  align-items: center;
  display: flex;
}

.div-block-4 {
  grid-column-gap: 10px;
  grid-row-gap: 10px;
  align-items: center;
  display: flex;
}

.fs-cc-manager_component {
  z-index: 999;
  display: flex;
  position: static;
  inset: auto auto 1.25rem 1.25rem;
}

.text-block {
  color: #fff;
  text-transform: none;
  font-size: 1.5rem;
  font-weight: 700;
}

.text-block.footer {
  color: #343434;
  font-family: Blmelody, sans-serif;
  line-height: 1.2;
  text-decoration: none;
}

.fs-cc-manager_trigger {
  display: none;
}

.image-2 {
  width: 30px;
  height: 30px;
}

.waves-divider-footer-1 {
  background-color: #13131333;
  width: 100%;
  height: 1px;
  margin-top: 64px;
  margin-bottom: 32px;
}

.fs-cc-manager_button {
  color: #333;
  cursor: pointer;
  background-color: #fff;
  border-radius: 999rem;
  flex-direction: column;
  padding: .625rem;
  transition: color .2s;
  display: flex;
}

.fs-cc-manager_button:hover {
  color: #4353ff;
}

.fs-cc-prefs_trigger {
  display: none;
}

.evasttt {
  flex-direction: column;
  align-items: flex-start;
  display: flex;
}

.fs-cc-prefs_checkbox-label {
  display: none;
}

.fs-cc-prefs_checkbox-field {
  background-color: #ccc;
  border-radius: 999rem;
  flex-direction: row;
  justify-content: flex-start;
  align-items: stretch;
  width: 2.75rem;
  height: 1.5rem;
  margin-bottom: 0;
  padding: .125rem;
  display: flex;
  position: relative;
}

.fs-cc-banner_trigger {
  display: none;
}

.fs-cc-prefs_title {
  color: #000;
  font-size: 1.5rem;
  font-weight: 700;
  line-height: 1.2em;
}

.fs-cc-banner_container {
  justify-content: space-between;
  align-items: center;
  width: 100%;
  max-width: 62.5rem;
  margin-left: auto;
  margin-right: auto;
  padding-left: 15px;
  padding-right: 15px;
  display: flex;
}

.fs-cc-prefs_submit-hide {
  display: none;
}

.fs-cc-banner_component {
  z-index: 998;
  background-color: #191919;
  border-radius: 50rem;
  width: 640px;
  margin-left: auto;
  margin-right: auto;
  padding: 1.5rem 2rem;
  display: none;
  position: fixed;
  inset: auto 0% 3%;
}

.fs-cc-banner_text {
  color: #fff;
  margin-right: 1.5rem;
  font-size: 14px;
}

.fs-cc-prefs_component {
  z-index: 997;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 100%;
  margin-bottom: 0;
  padding: 2rem;
  display: none;
  position: fixed;
  inset: 0%;
}

.fs-cc-prefs_content {
  height: 100%;
  padding: 2.5rem 2rem;
  overflow: scroll;
}

.fs-cc-prefs_text {
  color: #000;
  font-family: Arial, Helvetica Neue, Helvetica, sans-serif;
  font-size: 1rem;
  line-height: 1.5;
}

.fs-cc-prefs_toggle {
  background-color: #fff;
  border-radius: 999px;
  width: 1.25rem;
  height: 1.25rem;
}

.fs-cc-prefs_space-small {
  margin-bottom: .75rem;
}

.fs-cc-prefs_option {
  border-bottom: 1px solid #33333326;
  padding-top: 1rem;
  padding-bottom: 1rem;
}

.fs-cc-banner_text-link {
  color: #fff;
  border-bottom: 1px solid #fff;
  font-size: 14px;
  font-weight: 400;
  text-decoration: none;
}

.fs-cc-prefs_close {
  z-index: 1;
  color: #333;
  cursor: pointer;
  background-color: #fff;
  border-radius: 100%;
  padding: .625rem;
  font-size: 1.25rem;
  text-decoration: none;
  position: absolute;
  inset: -.75rem -.75rem auto auto;
  box-shadow: -1px 1px 12px #3333331a;
}

.fs-cc-prefs_overlay {
  z-index: -1;
  background-color: #18181899;
  width: 100%;
  height: 100%;
  position: absolute;
  inset: 0%;
}

.fs-cc-prefs_button {
  background-color: #000;
  border: 2px solid #000;
  border-radius: 999rem;
  margin-right: .5rem;
  padding: .625rem 1.5rem;
  font-size: .875rem;
  font-weight: 700;
}

.fs-cc-prefs_button.fs-cc-button-alt {
  color: #000;
  background-color: #fff;
  border-color: #000;
}

.fs-cc-banner_buttons-wrapper {
  flex-direction: row;
  flex: none;
  grid-template-rows: auto;
  grid-template-columns: auto auto;
  grid-auto-columns: 1fr;
  justify-content: flex-start;
  align-items: center;
  display: flex;
}

.fs-cc-prefs_close-icon {
  color: #021a7c;
  width: 1rem;
  height: 1rem;
}

.fs-cc-prefs_space-medium {
  margin-bottom: 2.5rem;
}

.fs-cc-prefs_form {
  background-color: #fff;
  border-radius: 1rem;
  width: 100%;
  max-width: 36rem;
  height: 100%;
  max-height: 70vh;
  margin-bottom: 0;
  position: relative;
}

.fs-cc-prefs_toggle-wrapper {
  flex-direction: row;
  justify-content: space-between;
  align-items: center;
  margin-bottom: .5rem;
  display: flex;
}

.fs-cc-banner_button {
  color: #fff;
  text-align: center;
  background-color: #0000;
  border: 1px solid #fff;
  border-radius: 999rem;
  min-width: 8.75rem;
  margin-left: 1rem;
  padding: .625rem 1.25rem;
  font-size: 14px;
}

.fs-cc-banner_button.fs-cc-button-alt {
  color: #fff;
  background-color: #0000;
  border-color: #fff;
}

.fs-cc-prefs_buttons-wrapper {
  grid-template-rows: auto;
  grid-template-columns: 1fr 1fr;
  grid-auto-columns: 1fr;
  justify-content: flex-end;
  margin-top: 2rem;
  margin-right: -.5rem;
  display: flex;
}

.fs-cc-prefs_label {
  color: #000;
  margin-top: 0;
  margin-bottom: 0;
  margin-right: 2rem;
  font-size: 1rem;
  font-weight: 700;
}

.fs-cc-prefs_checkbox {
  z-index: 1;
  opacity: 0;
  cursor: pointer;
  width: 100%;
  height: 100%;
  margin-top: 0;
  margin-left: 0;
  position: absolute;
  inset: 0%;
}

.p-max {
  max-width: 800px;
  margin-bottom: 56px;
  font-family: Blmelody Book, sans-serif;
  font-size: 1rem;
  line-height: 1.3;
}

.videogrid {
  grid-column-gap: 16px;
  grid-row-gap: 16px;
  grid-template: "Area-2 ."
                 ". Area"
                 / 1fr 1fr;
  grid-auto-columns: 1fr;
  width: 100%;
  max-width: 80vw;
  margin-top: 38px;
  padding-top: 49px;
  padding-bottom: 49px;
  display: grid;
}

.uui-contact03_form-wrapper {
  flex-direction: column;
  align-items: stretch;
}

.error-text {
  color: #e23939;
}

.uui-space-xsmall {
  width: 100%;
  min-height: 1rem;
}

.uui-form-button-wrapper {
  flex-direction: column;
  margin-top: .5rem;
  display: flex;
}

.success-text {
  font-weight: 600;
}

.success-message {
  background-color: #f4f4f4;
  padding: 1.5rem;
}

.uui-contact03_item {
  color: #262626;
  align-items: center;
  display: flex;
}

.error-message {
  margin-top: 1.5rem;
  padding: .875rem 1rem;
}

.splitter {
  grid-column-gap: 16px;
  grid-row-gap: 16px;
  grid-template-rows: auto;
  grid-template-columns: 1fr 1fr;
  grid-auto-columns: 1fr;
  display: grid;
}

.uui-icon-1x1-xsmall {
  color: #343434;
  width: 1.5rem;
  height: 1.5rem;
}

.uui-form-field-wrapper {
  position: relative;
}

.uui-section_contact03 {
  margin-top: 0;
  padding-top: 51px;
  padding-bottom: 51px;
}

.uui-contact03_icon-wrapper {
  color: #7f56d9;
  flex: none;
  align-self: flex-start;
  margin-right: 1rem;
}

.uui-contact03_component {
  grid-column-gap: 4rem;
  grid-row-gap: 4rem;
  grid-template-rows: auto;
  grid-template-columns: 1fr 1fr;
  grid-auto-columns: 1fr;
  align-items: start;
  display: grid;
}

.uui-heading-medium {
  color: #101828;
  margin-top: 0;
  margin-bottom: 0;
  font-family: Blmelody, sans-serif;
  font-size: 2.25rem;
  font-weight: 400;
  line-height: 1.3;
}

.uui-form_input {
  color: #101828;
  background-color: #fff;
  border: 1px solid #d0d5dd;
  border-radius: .5rem;
  height: auto;
  min-height: 2.75rem;
  margin-bottom: 0;
  padding: .5rem .875rem;
  font-family: system-ui, -apple-system, BlinkMacSystemFont, Segoe UI, Roboto, Oxygen, Ubuntu, Cantarell, Fira Sans, Droid Sans, Helvetica Neue, sans-serif;
  font-size: 1rem;
  line-height: 1.5;
  transition: all .3s;
  box-shadow: 0 1px 2px #1018280d;
}

.uui-form_input:focus {
  color: #101828;
  border-color: #d6bbfb;
  box-shadow: 0 1px 2px #1018280d, 0 0 0 4px #f4ebff;
}

.uui-form_input::placeholder {
  color: #667085;
}

.uui-form_input.text-area {
  height: auto;
  min-height: 11.25rem;
  padding-top: .75rem;
  padding-bottom: .75rem;
  overflow: auto;
}

.uui-container-large {
  width: 100%;
  max-width: 80rem;
  margin-left: auto;
  margin-right: auto;
}

.uui-page-padding {
  padding-left: 2rem;
  padding-right: 2rem;
}

.uui-field-label {
  margin-bottom: .5rem;
  font-size: .875rem;
  line-height: 1.5;
}

.uui-padding-vertical-xhuge {
  padding-top: 2.6rem;
  padding-bottom: 2.6rem;
}

.uui-text-style-link-02 {
  font-family: Blmelody Book, sans-serif;
  font-size: 17px;
  font-weight: 400;
  text-decoration: none;
}

.uui-contact03_form {
  grid-column-gap: 1.5rem;
  grid-row-gap: 1.5rem;
  grid-template-rows: auto auto;
  grid-template-columns: 1fr;
  grid-auto-columns: 1fr;
  display: grid;
}

.uui-text-size-large {
  color: #000;
  letter-spacing: normal;
  margin-bottom: 24px;
  font-family: Blmelody Book, sans-serif;
  font-size: 1.125rem;
  line-height: 1.5;
}

.uui-contact03_contact-list {
  grid-column-gap: 1rem;
  grid-row-gap: 1.5rem;
  grid-template-rows: auto;
  grid-template-columns: 1fr;
  grid-auto-columns: 1fr;
  margin-top: 3rem;
  display: grid;
}

.uui-button {
  grid-column-gap: .5rem;
  color: #fff;
  text-align: center;
  white-space: nowrap;
  background-color: #343434;
  border-radius: .5rem;
  justify-content: center;
  align-items: center;
  padding: .925rem 1.125rem;
  font-size: 1rem;
  line-height: 1.5;
  text-decoration: none;
  transition: all .3s;
  display: flex;
  box-shadow: 0 1px 2px #1018280d;
}

.uui-button:hover {
  background-color: #0084c2;
  border-color: #6941c6;
}

.uui-button:focus {
  background-color: #7f56d9;
  box-shadow: 0 1px 2px #1018280d, 0 0 0 4px #f4ebff;
}

.rich-text-block {
  font-family: Blmelody Book, sans-serif;
  font-size: 16px;
}

.text-block-2 {
  font-family: Blmelody, sans-serif;
}

.div-block-5 {
  flex-direction: column;
  align-items: flex-start;
  display: flex;
}

.icon {
  color: #000;
  justify-content: center;
  align-items: center;
  width: 24px;
  height: 24px;
  display: flex;
}

.ig-linkki {
  margin-top: 13px;
}

.p-light {
  margin-bottom: 35px;
  font-weight: 300;
}

.image {
  object-fit: cover;
  width: 100%;
  overflow: hidden;
}

.form {
  flex-direction: column;
  justify-content: space-between;
  height: 100%;
  padding: 20px;
  display: flex;
}

.grid_main {
  grid-column-gap: 20px;
  grid-row-gap: 20px;
  grid-template-rows: minmax(auto, 1fr) minmax(auto, 1fr) minmax(auto, 1fr) minmax(auto, 1fr) minmax(auto, 1fr) minmax(auto, 1fr) minmax(auto, 1fr) minmax(auto, 1fr);
  grid-template-columns: 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr;
  grid-auto-rows: minmax(auto, 1fr);
  grid-auto-flow: row;
  place-content: stretch space-between;
  align-items: stretch;
  width: 100%;
  max-height: 91vh;
  padding: 20px;
}

.form-field {
  margin-bottom: 10px;
}

.form-block {
  background-color: #fff;
  margin-top: 0;
  margin-bottom: 0;
  padding: 0;
}

.spacer-20 {
  width: 100%;
  height: 20px;
}

.field {
  border: 1.5px #e7e7e7;
  border-bottom: 1px solid #e7e7e7;
  height: 45px;
  margin-bottom: 0;
  padding: 8px 0;
  transition: box-shadow .2s;
}

.button {
  background-color: #000;
  width: 100%;
  height: 45px;
  font-size: 16px;
  font-weight: 400;
  text-decoration: none;
  transition: box-shadow .2s;
}

.button.social {
  grid-column-gap: 13px;
  color: #000;
  background-color: #fff;
  border: 1px solid #000;
  justify-content: center;
  align-items: center;
  margin-top: 15px;
  margin-bottom: 0;
  transition: box-shadow .2s;
  display: flex;
}

.button._2 {
  background-color: var(--v);
  justify-content: center;
  align-items: center;
  line-height: 1;
  display: flex;
}

.p {
  margin-bottom: 0;
}

.mb-20 {
  text-transform: uppercase;
  margin-top: 0;
  margin-bottom: 10px;
  font-size: 35px;
  font-weight: 800;
  line-height: 1;
}

.hidden-etusivu {
  display: block;
}

.waves---cta-dark {
  background-color: var(--waves-library-black);
  border-radius: 8px;
  justify-content: center;
  align-items: center;
  height: 52px;
  padding: 8px 24px;
  font-size: 16px;
  font-weight: 700;
  transition: background-color .2s;
  display: flex;
}

.waves---cta-dark:hover {
  background-color: #131313e6;
}

.waves---cta-dark.wide-cta {
  min-width: 200px;
}

.waves---mg-top-17 {
  margin-top: 16px;
}

.waves---subtitle-2 {
  text-align: left;
  font-size: 1rem;
  line-height: 1.3;
}

.waves---limit-481 {
  width: 100%;
  max-width: 800px;
}

.waves---mega-heading-2 {
  margin-top: 0;
  margin-bottom: 0;
  font-size: 2rem;
  line-height: 115%;
}

.waves-limit-1008 {
  width: 100%;
  max-width: 1008px;
}

.waves-title-line-hero-2 {
  background-image: linear-gradient(to right, #13131300, var(--waves-library-black));
  border-radius: 30px;
  width: 92px;
  height: 12px;
}

.waves-title-wrap-hero-2 {
  grid-row-gap: 24px;
  text-align: center;
  flex-direction: column;
  align-items: center;
  display: flex;
}

.waves---main-container-2 {
  max-width: 1352px;
  padding-left: 24px;
  padding-right: 24px;
}

.waves---section-hero-primary {
  margin-top: 76px;
  padding-top: 100px;
  padding-bottom: 10px;
}

.nappi {
  background-color: #6d9a45;
  padding: 13px 24px;
  font-family: Blmelody, sans-serif;
  font-weight: 400;
}

.h22 {
  font-size: 1.4rem;
  font-weight: 400;
  line-height: 1.4;
}

.paragraph {
  font-family: Blmelody, sans-serif;
}

.btnwrp {
  justify-content: center;
  align-items: center;
  display: flex;
}

@media screen and (max-width: 991px) {
  .collection-list-wrapper {
    column-count: 2;
    column-gap: 15px;
  }

  .collection-item {
    margin-top: 15px;
    margin-bottom: 15px;
  }

  .waves---mega-heading-1 {
    font-size: 72px;
    line-height: 110%;
  }

  .waves-section-hero-5 {
    padding-top: 240px;
  }

  .waves---hamburger-icon {
    justify-content: center;
    align-items: center;
    width: 100%;
    height: 100%;
    margin: auto;
    display: flex;
  }

  .waves---menu-button {
    justify-content: center;
    align-items: center;
    width: 52px;
    height: 52px;
    padding: 0;
    display: flex;
  }

  .waves---menu-button.w--open {
    background-color: var(--waves-library-black);
    border-radius: 6px;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    width: 52px;
    height: 52px;
    padding: 0;
    display: flex;
  }

  .waves---nav-buttons-right {
    grid-column-gap: 8px;
  }

  .waves---nav-link {
    text-align: center;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    padding-top: 16px;
    padding-bottom: 16px;
    font-size: 20px;
    display: flex;
  }

  .waves---nav-link.mb {
    display: flex;
  }

  .waves---dropdown-link {
    padding-top: 12px;
    padding-bottom: 12px;
    font-size: 20px;
  }

  .waves-dropdown-list.w--open {
    width: 100%;
    padding-top: 8px;
    padding-bottom: 8px;
    position: static;
  }

  .waves-dropdown-toggle {
    padding-right: 16px;
    font-size: 20px;
  }

  .waves---nav-dropdown {
    width: 100%;
    padding-left: 16px;
    padding-right: 16px;
  }

  .waves---nav-menu {
    background-color: var(--waves-library-white);
    border: 1px solid #1313131a;
    border-radius: 8px;
    margin-top: 4px;
  }

  .waves---nav-brand-link {
    padding-left: 0;
  }

  .waves---content-image-halves {
    text-align: center;
    align-items: center;
  }

  .waves-image-features-4 {
    max-width: 470px;
  }

  .waves---grid-image-halves {
    grid-row-gap: 48px;
    grid-template-columns: 1fr;
    margin-left: auto;
    margin-right: auto;
  }

  .waves-top-footer-1 {
    grid-row-gap: 40px;
    flex-direction: column;
  }

  .waves-bottom-footer-1 {
    grid-row-gap: 32px;
    text-align: center;
    flex-direction: column;
    align-items: center;
  }

  .waves-divider-footer-1 {
    margin-top: 40px;
  }

  .fs-cc-banner_container {
    flex-direction: row;
    align-items: flex-start;
  }

  .fs-cc-banner_text {
    margin-right: 0;
  }

  .fs-cc-banner_buttons-wrapper {
    margin-top: 1rem;
  }

  .p-max {
    max-width: 90vw;
  }

  .uui-contact03_component {
    grid-column-gap: 3rem;
    grid-auto-flow: row;
    min-height: auto;
  }

  .uui-padding-vertical-xhuge {
    padding-top: 6rem;
    padding-bottom: 6rem;
  }

  .image {
    flex: 0 auto;
    height: 200px;
  }

  .grid_main {
    flex-direction: column;
    max-height: none;
    display: flex;
  }

  .waves---mega-heading-2 {
    font-size: 72px;
    line-height: 110%;
  }

  .waves---section-hero-primary {
    text-align: center;
  }
}

@media screen and (max-width: 767px) {
  .collection-list-wrapper {
    column-gap: 15px;
  }

  .collection-item {
    margin-top: 15px;
    margin-bottom: 15px;
  }

  .tekstikohta {
    font-size: 22px;
    line-height: 34px;
  }

  .waves---mega-heading-1 {
    font-size: 56px;
  }

  .waves-title-wrap-hero-5 {
    text-align: center;
    align-items: center;
  }

  .waves---main-container {
    padding-left: 16px;
    padding-right: 16px;
  }

  .waves-section-hero-5 {
    padding-top: 160px;
  }

  .waves---nav-container {
    padding-left: 12px;
    padding-right: 12px;
  }

  .waves---heading-2-no-margins {
    font-size: 44px;
    line-height: 125%;
  }

  .tulossa-kohta {
    padding-top: 80px;
    padding-bottom: 80px;
  }

  .waves-top-right-footer-1 {
    grid-row-gap: 32px;
    flex-wrap: wrap;
  }

  .fs-cc-prefs_title {
    font-size: 1.25rem;
  }

  .fs-cc-banner_container {
    flex-direction: row;
    align-items: center;
  }

  .fs-cc-banner_component {
    width: 90vw;
  }

  .fs-cc-banner_buttons-wrapper {
    grid-column-gap: 8px;
    grid-row-gap: 8px;
    flex-direction: column;
    align-items: center;
  }

  .uui-space-xsmall {
    min-height: .75rem;
  }

  .uui-contact03_component {
    grid-row-gap: 3rem;
    grid-template-columns: 1fr;
  }

  .uui-heading-medium {
    font-size: 1.75rem;
    line-height: 1.4;
  }

  .uui-page-padding {
    padding-left: 1rem;
    padding-right: 1rem;
  }

  .uui-padding-vertical-xhuge {
    padding-top: 4rem;
    padding-bottom: 4rem;
  }

  .uui-text-size-large {
    font-size: 1rem;
  }

  .uui-contact03_contact-list {
    margin-top: 2rem;
  }

  .uui-button {
    font-size: 1rem;
  }

  .uui-button:hover {
    background-color: #7f56d9;
    border-color: #7f56d9;
  }

  .waves---subtitle-2 {
    font-size: 22px;
    line-height: 34px;
  }

  .waves---mega-heading-2 {
    font-size: 56px;
  }

  .waves---main-container-2 {
    padding-left: 16px;
    padding-right: 16px;
  }
}

@media screen and (max-width: 479px) {
  .collection-list-wrapper, .collection-list-wrapper.col4 {
    column-count: 2;
  }

  .heading.no-bot {
    max-width: 90vw;
  }

  .tekstikohta {
    font-size: 1.1rem;
    line-height: 1.4;
  }

  .waves---mega-heading-1 {
    font-size: 36px;
  }

  .waves-section-hero-5 {
    padding-bottom: 48px;
  }

  .waves---nav-cta {
    display: none;
  }

  .logo {
    font-size: 6vw;
  }

  .waves---heading-2-no-margins {
    font-size: 34px;
  }

  .waves---content-image-halves {
    align-items: stretch;
  }

  .tulossa-kohta {
    padding-top: 64px;
    padding-bottom: 64px;
  }

  .waves-bottom-right-footer-1 {
    grid-row-gap: 16px;
    flex-wrap: wrap;
  }

  .waves-top-right-footer-1 {
    grid-row-gap: 24px;
    flex-direction: column;
  }

  .evasttt {
    align-items: center;
  }

  .fs-cc-banner_container {
    flex-direction: column;
    justify-content: space-around;
  }

  .fs-cc-banner_component {
    flex-direction: row;
    width: 95vw;
    padding: .6rem .4rem;
  }

  .fs-cc-prefs_component, .fs-cc-prefs_content {
    padding: 1.5rem;
  }

  .fs-cc-prefs_button {
    margin-bottom: .5rem;
  }

  .fs-cc-banner_buttons-wrapper {
    text-align: center;
    flex-direction: row;
    align-items: center;
  }

  .fs-cc-banner_button {
    width: auto;
    min-width: auto;
    margin-bottom: .5rem;
    margin-left: 0;
  }

  .videogrid {
    grid-template-columns: 1fr;
  }

  .uui-section_contact03 {
    padding-top: 4px;
    padding-bottom: 4px;
  }

  .uui-contact03_component {
    grid-template-columns: 1fr;
  }

  .uui-padding-vertical-xhuge {
    padding-top: 2rem;
  }

  .s {
    font-size: 24px;
  }

  .form-block {
    padding-left: 0;
    padding-right: 0;
  }

  .waves---subtitle-2 {
    text-align: left;
    font-size: 1rem;
    line-height: 1.4;
  }

  .waves---mega-heading-2 {
    font-size: 36px;
  }

  .waves---section-hero-primary {
    padding-top: 80px;
    padding-bottom: 20px;
  }
}

#w-node-bfa71e1f-1b70-a57c-ebfb-1782bc766bc2-893506e6 {
  grid-area: span 1 / span 1 / span 1 / span 1;
}

#w-node-bfa71e1f-1b70-a57c-ebfb-1782bc766bc3-893506e6 {
  grid-area: span 1 / span 1 / span 1 / span 1;
  place-self: center;
}

#w-node-fcf96415-b50e-cd44-b767-cc469dd6464b-893506e6 {
  grid-area: 1 / 1 / 9 / 3;
}

#w-node-fcf96415-b50e-cd44-b767-cc469dd6464c-893506e6 {
  grid-area: 1 / 7 / 3 / 11;
}

#w-node-fcf96415-b50e-cd44-b767-cc469dd6464d-893506e6 {
  grid-area: 6 / 6 / 9 / 9;
}

#w-node-fcf96415-b50e-cd44-b767-cc469dd6464e-893506e6 {
  grid-area: 3 / 7 / 6 / 10;
}

#w-node-fcf96415-b50e-cd44-b767-cc469dd6464f-893506e6 {
  grid-area: 3 / 10 / 6 / 11;
}

#w-node-fcf96415-b50e-cd44-b767-cc469dd64650-893506e6 {
  grid-area: 6 / 3 / 9 / 6;
}

#w-node-fcf96415-b50e-cd44-b767-cc469dd64651-893506e6 {
  grid-area: 6 / 9 / 9 / 11;
}

#w-node-_23f08157-dc21-ba31-b6da-e8e7d9e11cab-893506e6 {
  grid-area: span 5 / span 4 / span 5 / span 4;
}

#w-node-b4b5124e-67f7-5884-6923-e371db15b7c0-893506e6 {
  grid-area: 1 / 1 / 9 / 3;
}

#w-node-b4b5124e-67f7-5884-6923-e371db15b7c1-893506e6 {
  grid-area: 1 / 7 / 3 / 11;
}

#w-node-b4b5124e-67f7-5884-6923-e371db15b7c2-893506e6 {
  grid-area: 6 / 6 / 9 / 9;
}

#w-node-b4b5124e-67f7-5884-6923-e371db15b7c3-893506e6 {
  grid-area: 3 / 7 / 6 / 10;
}

#w-node-b4b5124e-67f7-5884-6923-e371db15b7c4-893506e6 {
  grid-area: 3 / 10 / 6 / 11;
}

#w-node-b4b5124e-67f7-5884-6923-e371db15b7c5-893506e6 {
  grid-area: 6 / 3 / 9 / 6;
}

#w-node-b4b5124e-67f7-5884-6923-e371db15b7c6-893506e6 {
  grid-area: 6 / 9 / 9 / 11;
}

#w-node-b4b5124e-67f7-5884-6923-e371db15b7c7-893506e6 {
  grid-area: span 5 / span 4 / span 5 / span 4;
}

#w-node-b61b2015-ccca-3e41-991b-c77a2458d9e5-893506e7, #w-node-_118cd7c8-e110-361a-229e-a4bdf5554d8c-893506e7, #w-node-_9dd0dcfe-a235-b99e-60da-205be7806d50-893506e7, #w-node-c5e5a745-de4a-fc59-b2a2-9ec68afdcff1-893506e7 {
  grid-area: span 1 / span 1 / span 1 / span 1;
}

#w-node-a2dc7e17-18e2-ab66-cc94-cd41a242a87f-893506ea, #w-node-a2dc7e17-18e2-ab66-cc94-cd41a242a884-893506ea {
  align-self: start;
}

#w-node-a2dc7e17-18e2-ab66-cc94-cd41a242a89c-893506ea {
  grid-area: span 1 / span 1 / span 1 / span 1;
}

#w-node-a2dc7e17-18e2-ab66-cc94-cd41a242a89d-893506ea {
  justify-self: start;
}

@media screen and (max-width: 991px) {
  #w-node-bfa71e1f-1b70-a57c-ebfb-1782bc766bc2-893506e6 {
    justify-self: center;
  }
}


@font-face {
  font-family: 'Blmelody';
  src: url('../fonts/BLMelody-Bold.woff2') format('woff2');
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'Blmelody';
  src: url('../fonts/BLMelody-ExtraLight.woff2') format('woff2');
  font-weight: 200;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'Blmelody';
  src: url('../fonts/BLMelody-Light.woff2') format('woff2');
  font-weight: 300;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'Blmelody';
  src: url('../fonts/BLMelody-Regular.woff2') format('woff2');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'Blmelody';
  src: url('../fonts/BLMelody-SemiBold.woff2') format('woff2');
  font-weight: 600;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'Blmelody';
  src: url('../fonts/BLMelody-Medium.woff2') format('woff2');
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'Blmelody Book';
  src: url('../fonts/BLMelody-Book.woff2') format('woff2');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}