.dna-card-free__outside-wrap {
  position: relative;
  height: 100%;
  display: flex;
  flex-direction: column;
}

.dna-card-free {
  display: flex;
  flex-wrap: wrap;
  height: 100%;
  border-radius: 8px;
  overflow: hidden;
  transform: translateZ(0);
}
.dna-grid .dna-grid-item > .dna-card-free {
  align-items: stretch;
}

.dna-card-free--bordered {
  border: 1px solid #D4D2CE;
}

.dna-card-free--shadow {
  border: 1px solid #EFEEED;
  box-shadow: 0px 2px 16px 0px rgba(18, 18, 18, 0.06);
  border-radius: 8px;
  overflow: hidden;
}

.dna-card-free.dna-card-free--image-w25 .dna-card-free__image {
  flex-basis: 25%;
}
.dna-card-free.dna-card-free--image-w25 .dna-card-free__text {
  flex-basis: 75%;
}

.dna-card-free.dna-card-free--image-w33 .dna-card-free__image {
  flex-basis: 33.3333333333%;
}
.dna-card-free.dna-card-free--image-w33 .dna-card-free__text {
  flex-basis: 66.6666666667%;
}

.dna-card-free.dna-card-free--image-w66 .dna-card-free__image {
  flex-basis: 66.6666666667%;
}
.dna-card-free.dna-card-free--image-w66 .dna-card-free__text {
  flex-basis: 33.3333333333%;
}

.dna-card-free:not(.dna-card-free--fixed-layout).dna-card-free--image-w25 .dna-card-free__image {
  min-width: 141px;
}
.dna-card-free:not(.dna-card-free--fixed-layout).dna-card-free--image-w33 .dna-card-free__image {
  min-width: 188px;
}
.dna-card-free:not(.dna-card-free--fixed-layout).dna-card-free--image-w66 .dna-card-free__text {
  min-width: 300px;
}

.dna-card-free--fixed-layout .dna-card-free__cta-area {
  opacity: 1;
}

.dna-card-free--fixed-horizontal {
  flex-wrap: nowrap;
}
.dna-card-free--fixed-horizontal .dna-card-free__item {
  flex-basis: 50%;
}
.dna-card-free--fixed-horizontal .dna-card-free__image {
  min-width: 50px;
}

.dna-card-free--verticalmode, .dna-card-free--fixed-vertical {
  flex-direction: column;
  flex-wrap: nowrap;
}
.dna-card-free--verticalmode .dna-card-free__image, .dna-card-free--fixed-vertical .dna-card-free__image {
  flex: 0 0 auto;
  width: 100%;
  flex-basis: auto !important;
}
.dna-card-free--verticalmode .dna-card-free__text, .dna-card-free--fixed-vertical .dna-card-free__text {
  flex: 1 1 auto;
  width: 100%;
}
.dna-card-free--verticalmode .limited-height, .dna-card-free--fixed-vertical .limited-height {
  height: 200px;
}
.dna-card-free--verticalmode .no-crop .dna-cld-responsive, .dna-card-free--fixed-vertical .no-crop .dna-cld-responsive {
  width: 100%;
  height: 100%;
  object-fit: contain;
}
.dna-card-free--verticalmode .dna-card-free__image-wrap--only-logo, .dna-card-free--fixed-vertical .dna-card-free__image-wrap--only-logo {
  aspect-ratio: 16/9;
}
.dna-card-free--verticalmode .dna-card-free__item--centered, .dna-card-free--verticalmode .dna-card-free__item--v-centered, .dna-card-free--fixed-vertical .dna-card-free__item--centered, .dna-card-free--fixed-vertical .dna-card-free__item--v-centered {
  justify-content: flex-start;
}

.dna-card-free__image-wrap {
  position: relative;
  overflow: hidden;
}
.dna-card-free__image-wrap--only-logo {
  width: 100%;
  height: 100%;
}
.dna-card-free.ds-bg--none:not(.dna-card-free--bordered):not(.dna-card-free--shadow) .dna-card-free__image-wrap {
  border-radius: 8px;
}

.dna-card-free__link {
  color: inherit;
}

.dna-card-free__text {
  align-items: flex-start;
}

.dna-card-free__item {
  flex: 1 0 300px;
  display: flex;
  flex-direction: column;
  max-width: 100%;
  align-items: stretch;
}
.dna-card-free__item .align-v-bottom {
  margin-top: auto;
}
.dna-card-free__item .ratio-1-1 {
  aspect-ratio: 1/1;
}
.dna-card-free__item .ratio-4-3 {
  aspect-ratio: 4/3;
}
.dna-card-free__item .ratio-16-9 {
  aspect-ratio: 16/9;
}

.dna-card-free__item--centered {
  align-items: center;
  justify-content: center;
  text-align: center;
}

.dna-card-free__item--h-centered {
  align-items: center;
  text-align: center;
}

.dna-card-free__item--v-centered {
  justify-content: center;
}

.dna-card-free__item--v-top {
  justify-content: flex-start;
}

.dna-card-free__item--v-bottom {
  justify-content: flex-end;
}

.dna-card-free__item--padding {
  padding: max(30px, 5%) max(20px, 5%);
}

.dna-card-free__item--v-padding {
  padding: max(30px, 5%) 0;
}

.dna-card-free__item--top-side-padding {
  padding: max(30px, 5%) max(20px, 5%) 0;
}

.dna-card-free:not(.dna-card-free--verticalmode):not(.dna-card-free--fixed-vertical) .dna-card-free__image + .dna-card-free__text.dna-card-free__item--v-padding {
  padding-left: max(20px, 5%);
}
.dna-card-free:not(.dna-card-free--verticalmode):not(.dna-card-free--fixed-vertical).dna-card-free--inverted .dna-card-free__image + .dna-card-free__text.dna-card-free__item--v-padding {
  padding-left: 0;
  padding-right: max(20px, 5%);
}

.dna-card-free:not(.dna-card-free--verticalmode):not(.dna-card-free--fixed-vertical) .cover-height .dna-card-free__image-wrap {
  height: 100%;
  width: 100%;
  aspect-ratio: auto;
}
.dna-card-free:not(.dna-card-free--verticalmode):not(.dna-card-free--fixed-vertical) .cover-height .dna-cld-responsive:not(.dna-logo-image) {
  height: 100%;
  object-fit: cover;
}

.dna-card-free__image .dna-cld-responsive.placeholder {
  filter: blur(10px);
}

.dna-card-free__author {
  display: block;
  text-transform: uppercase;
  font-size: 14px;
  line-height: 20px;
  font-family: "DNA Text Medium", "Helvetica Neue", Helvetica, Arial, sans-serif;
  min-height: 40px;
}
.dna-card-free__author + * {
  margin-top: 20px;
}

.dna-card-free__text {
  container: card-text/inline-size;
}
.dna-card-free__text blockquote {
  margin: 0;
}
.dna-card-free__text h1:first-child, .dna-card-free__text h2:first-child, .dna-card-free__text h3:first-child {
  margin-top: 0;
}
.dna-card-free__text > *:last-child {
  margin-bottom: 0;
}

.dna-card-free__align-bottom {
  margin-top: auto;
}

.dna-card-free__cta-area {
  width: 100%;
  margin-top: 4px;
  opacity: 0;
  transition: opacity 0.2s ease-in-out;
  z-index: 1;
}
.dna-card-free__js-ready .dna-card-free__cta-area {
  opacity: 1;
}

.dna-card-free__item--centered .dna-card-free__cta-wrapper, .dna-card-free__item--h-centered .dna-card-free__cta-wrapper {
  justify-content: center;
}

.dna-card-free__cta.ds-btn {
  flex: 1 1 200px;
  max-width: 260px;
}

.dna-card-free__image--text > *:first-child {
  margin-top: 0;
}
.dna-card-free__image--text > *:last-child {
  margin-bottom: 0;
}

.dna-card-free__tag {
  top: initial;
  max-width: calc(100% - 60px);
}

.dna-card-free--inverted:not(.dna-card-free--verticalmode) .dna-card-free__image {
  order: 2;
}

@media screen and (max-width: 479px) {
  .dna-card-free--mobile-text-first .dna-card-free__image {
    order: 2;
  }
}

@media screen and (max-width: 479px) {
  .dna-card-free--mobile-no-image .dna-card-free__image {
    display: none;
  }
}

.dna-card-free__full-element-link {
  position: absolute;
  inset: 0;
}

.dna-card-free--as-hero {
  border: 1px solid #EFEEED;
  box-shadow: 0px 8px 64px 0px rgba(18, 18, 18, 0.16);
  border-radius: 8px;
  border-radius: 0;
  border-width: 0 0 1px;
  position: relative;
  z-index: 1;
  margin-bottom: 20px;
}
.dna-card-free--as-hero .dna-card-free__image-wrap {
  border-radius: 0 !important;
}
.dna-card-free--as-hero:not(.dna-card-free--verticalmode):not(.dna-card-free--fixed-vertical) .dna-card-free__item {
  flex-basis: 400px;
}
body.admin-signed-in.controls-visible .dna-card-free--as-hero {
  z-index: initial;
}
/*# sourceMappingURL=data:application/json;base64,{"version":3,"sourceRoot":"/source/","sources":["card-free.scss","home/jenkins/agent/workspace/DNAfi/BUILD_AND_DEPLOY_PLANS/DNA.fi_DXP_PROD_AWS/Prod_app2_liferay_install_and_deploy/dna-liferay-source/dna-fi-theme/src/css/dna/_vars.scss","home/jenkins/agent/workspace/DNAfi/BUILD_AND_DEPLOY_PLANS/DNA.fi_DXP_PROD_AWS/Prod_app2_liferay_install_and_deploy/dna-liferay-source/dna-fi-theme/src/css/dna/_mixins.scss"],"names":[],"mappings":"AAOA;EACE;EAEA;EACA;EACA;;;AAGF;EACE;EACA;EACA;EACA,eC2DsB;ED1DtB;EACA;;AAEA;EACE;;;AAGJ;EACE;;;AAEF;EEkII;EACA;EACA,eDpFoB;ECsFhB;;;AFhIN;EACE;;AAEF;EACE;;;AAIF;EACE;;AAEF;EACE;;;AAIF;EACE;;AAEF;EACE;;;AAOA;EACE;;AAIF;EACE;;AAIF;EACE;;;AAOJ;EACE;;;AAGJ;EACE;;AACA;EACE;;AAEF;EACE;;;AASJ;EACE;EACA;;AACA;EACE;EACA;EACA;;AAEF;EACE;EACA;;AAEF;EACE;;AAEF;EACE;EACA;EACA;;AAGF;EACE;;AAIF;EACE;;;AAIJ;EACE;EACA;;AAEA;EACE;EACA;;AAIF;EACE,eChEoB;;;ADmExB;EACE;;;AAEF;EACE;;;AAEF;EACE;EACA;EACA;EACA;EACA;;AAEA;EACE;;AAKF;EACE;;AAEF;EACE;;AAEF;EACE;;;AAGJ;EACE;EACA;EACA;;;AAEF;EACE;EACA;;;AAEF;EACE;;;AAEF;EACE;;;AAEF;EACE;;;AAEF;EACE;;;AAEF;EACE;;;AAEF;EACE;;;AAMA;EACE;;AAEF;EACE;EACA;;;AAOA;EACE;EACA;EACA;;AAEF;EACE;EACA;;;AAMJ;EACE;;;AAIJ;EACE;EACA;EACA,WC/N6B;EDgO7B;EACA,aCtN8B;EDuN9B;;AACA;EACE;;;AAIJ;EACE;;AACA;EACE;;AAGA;EACE;;AAGJ;EACE;;;AAIJ;EACE;;;AAEF;EACE;EACA;EACA;EACA;EACA;;AACA;EACE;;;AAIF;EACE;;;AAGJ;EACE;EACA;;;AAIA;EACE;;AAEF;EACE;;;AAIJ;EACE;EACA;;;AAKA;EACE;;;AE5QI;EFiRJ;IACE;;;;AElRE;EFwRJ;IACE;;;;AAKN;EEhMI;EACA;;;AFwkBJ;EEzhBI;EACA;EACA,eDpGoB;ED6nBtB;EACA;EACA;EACA;EACA;;AAEA;EACE;;AAIF;EACE;;AAIF;EACE","sourcesContent":["@charset \"UTF-8\";\n@use \"sass:math\";\n\n@import \"../vars\";\n@import \"../mixins\";\n\n// for positioning elements outside the card, e.g. label so that the radius & overflow hidden don't cut them\n.dna-card-free__outside-wrap {\n  position: relative;\n  // needed for full height elements in grid. Flex fixes margin issues.\n  height: 100%;\n  display: flex;\n  flex-direction: column;\n}\n\n.dna-card-free {\n  display: flex;\n  flex-wrap: wrap;\n  height: 100%;\n  border-radius: $border-radius--normal;\n  overflow: hidden; // to get the radius to child elements\n  transform: translateZ(0); // Safari rounded corners DNADXP-6717\n\n  .dna-grid .dna-grid-item > & {\n    align-items: stretch;\n  }\n}\n.dna-card-free--bordered {\n  border: 1px solid $color-line--02;\n}\n.dna-card-free--shadow {\n  @include dropshadow-elevation-low($clip: true);\n}\n\n// Image widths. .dna-card-free -selector added to give more weight\n.dna-card-free.dna-card-free--image-w25 {\n  .dna-card-free__image {\n    flex-basis: 25%;\n  }\n  .dna-card-free__text {\n    flex-basis: 75%;\n  }\n}\n.dna-card-free.dna-card-free--image-w33 {\n  .dna-card-free__image {\n    flex-basis: percentage(math.div(1,3));\n  }\n  .dna-card-free__text {\n    flex-basis: percentage(math.div(2,3));\n  }\n}\n.dna-card-free.dna-card-free--image-w66 {\n  .dna-card-free__image {\n    flex-basis: percentage(math.div(2,3));\n  }\n  .dna-card-free__text {\n    flex-basis: percentage(math.div(1,3));\n  }\n}\n\n// dynamic layout cards min widths\n.dna-card-free:not(.dna-card-free--fixed-layout) {\n  &.dna-card-free--image-w25 {\n    .dna-card-free__image {\n      min-width: 141px; // 141*4 = 564, 568 is card width in 2cols, 60px gap and 1px border\n    }\n  }\n  &.dna-card-free--image-w33 {\n    .dna-card-free__image {\n      min-width: 188px; // 188*3 = 564, 568 is card width in 2cols, 60px gap and 1px border\n    }\n  }\n  &.dna-card-free--image-w66 {\n    .dna-card-free__text {\n      min-width: 300px;\n    }\n  }\n}\n\n// fixed layout cards\n.dna-card-free--fixed-layout {\n  .dna-card-free__cta-area {\n    opacity: 1;\n  }\n}\n.dna-card-free--fixed-horizontal {\n  flex-wrap: nowrap;\n  .dna-card-free__item {\n    flex-basis: 50%;\n  }\n  .dna-card-free__image {\n    min-width: 50px;\n  }\n}\n\n// Handle vertical / horizontal mode\n// We need to do this with javascript since container queries are not supported yet.\n// And it is impossible to make elements to align bottom (e.g. CTA) with css only.\n// See cardFree.es.js and\n// https://codepen.io/petterila/pen/yLMegJy\n.dna-card-free--verticalmode, .dna-card-free--fixed-vertical {\n  flex-direction: column;\n  flex-wrap: nowrap;\n  .dna-card-free__image {\n    flex: 0 0 auto;\n    width: 100%;\n    flex-basis: auto !important; // overwrite image width flex basis\n  }\n  .dna-card-free__text {\n    flex: 1 1 auto;\n    width: 100%;\n  }\n  .limited-height {\n    height: 200px;\n  }\n  .no-crop .dna-cld-responsive {\n    width: 100%;\n    height: 100%;\n    object-fit: contain;\n  }\n\n  .dna-card-free__image-wrap--only-logo {\n    aspect-ratio: 16/9; // ensure some height as there aren't normal image to set the height\n  }\n\n  // align texts to top in vertical mode\n  .dna-card-free__item--centered, .dna-card-free__item--v-centered {\n    justify-content: flex-start;\n  }\n}\n\n.dna-card-free__image-wrap {\n  position: relative;\n  overflow: hidden;\n\n  &--only-logo {\n    width: 100%;\n    height: 100%;\n  }\n\n  // with transparent background and no borders, image has radius in all corners\n  .dna-card-free.ds-bg--none:not(.dna-card-free--bordered):not(.dna-card-free--shadow) & {\n    border-radius: $border-radius--normal;\n  }\n}\n.dna-card-free__link {\n  color: inherit;\n}\n.dna-card-free__text {\n  align-items: flex-start;\n}\n.dna-card-free__item {\n  flex: 1 0 300px;\n  display: flex;\n  flex-direction: column;\n  max-width: 100%;\n  align-items: stretch;\n\n  .align-v-bottom {\n    margin-top: auto;\n  }\n\n  // aspect ratio is a new feature and doesn't work in all browsers https://caniuse.com/mdn-css_properties_aspect-ratio\n  // but it's the most elegant way to implement aspect ratio text content without cutting the text in overflow\n  .ratio-1-1 {\n    aspect-ratio: 1/1;\n  }\n  .ratio-4-3 {\n    aspect-ratio: 4/3;\n  }\n  .ratio-16-9 {\n    aspect-ratio: 16/9;\n  }\n}\n.dna-card-free__item--centered {\n  align-items: center;\n  justify-content: center;\n  text-align: center;\n}\n.dna-card-free__item--h-centered {\n  align-items: center;\n  text-align: center;\n}\n.dna-card-free__item--v-centered {\n  justify-content: center;\n}\n.dna-card-free__item--v-top {\n  justify-content: flex-start;\n}\n.dna-card-free__item--v-bottom {\n  justify-content: flex-end;\n}\n.dna-card-free__item--padding {\n  padding: #{'max(30px, 5%) max(20px, 5%)'};\n}\n.dna-card-free__item--v-padding {\n  padding: #{'max(30px, 5%) 0'};\n}\n.dna-card-free__item--top-side-padding {\n  padding: #{'max(30px, 5%) max(20px, 5%) 0'};\n}\n// only vertical padding in text\n// in horizontal mode\n.dna-card-free:not(.dna-card-free--verticalmode):not(.dna-card-free--fixed-vertical) {\n  // when there's image\n  .dna-card-free__image + .dna-card-free__text.dna-card-free__item--v-padding {\n    padding-left: #{'max(20px, 5%)'};\n  }\n  &.dna-card-free--inverted .dna-card-free__image + .dna-card-free__text.dna-card-free__item--v-padding {\n    padding-left: 0;\n    padding-right: #{'max(20px, 5%)'};\n  }\n}\n\n// cover full height in horizontal mode\n.dna-card-free:not(.dna-card-free--verticalmode):not(.dna-card-free--fixed-vertical) {\n  .cover-height  {\n    .dna-card-free__image-wrap {\n      height: 100%;\n      width: 100%;\n      aspect-ratio: auto;\n    }\n    .dna-cld-responsive:not(.dna-logo-image) {\n      height: 100%;\n      object-fit: cover;\n    }\n  }\n}\n\n.dna-card-free__image {\n  .dna-cld-responsive.placeholder {\n    filter: blur(10px);\n  }\n}\n\n.dna-card-free__author {\n  display: block;\n  text-transform: uppercase;\n  font-size: $font-size-small;\n  line-height: 20px;\n  font-family: $font-family-text-medium;\n  min-height: 40px; // min two lines\n  & + * {\n    margin-top: 20px; // ensure the margin to the next element, e.g. h3\n  }\n}\n\n.dna-card-free__text {\n  container: card-text / inline-size;\n  blockquote {\n    margin: 0;\n  }\n  h1,h2,h3 {\n    &:first-child {\n      margin-top: 0;\n    }\n  }\n  > *:last-child {\n    margin-bottom: 0;\n  }\n}\n\n.dna-card-free__align-bottom {\n  margin-top: auto;\n}\n.dna-card-free__cta-area {\n  width: 100%;\n  margin-top: 4px; // 20px - 1rem\n  opacity: 0;\n  transition: opacity .2s ease-in-out;\n  z-index: 1; // to be over full-element-link\n  .dna-card-free__js-ready & {\n    opacity: 1;\n  }\n}\n.dna-card-free__cta-wrapper {\n  .dna-card-free__item--centered &, .dna-card-free__item--h-centered & {\n    justify-content: center;\n  }\n}\n.dna-card-free__cta.ds-btn {\n  flex: 1 1 200px;\n  max-width: 260px;\n}\n\n.dna-card-free__image--text {\n  > *:first-child {\n    margin-top: 0;\n  }\n  > *:last-child {\n    margin-bottom: 0;\n  }\n}\n\n.dna-card-free__tag {\n  top: initial;\n  max-width: calc(100% - 60px);\n}\n\n// Inverted and mobile layout settings\n.dna-card-free--inverted:not(.dna-card-free--verticalmode) {\n  .dna-card-free__image {\n    order: 2;\n  }\n}\n.dna-card-free--mobile-text-first {\n  @include breakpoint(small-mobile) {\n    .dna-card-free__image {\n      order: 2;\n    }\n  }\n}\n.dna-card-free--mobile-no-image {\n  @include breakpoint(small-mobile) {\n    .dna-card-free__image {\n      display: none;\n    }\n  }\n}\n\n.dna-card-free__full-element-link {\n  @include positionAbsoluteFull;\n}\n\n\n// Card with free layout\n//\n// This card has basically an image section and a text section and then multiple options how to present those.\n//\n// Styleguide 20.\n\n// Freestyle card\n//\n// Here are demo cards to test cards with different kinds of content and content lengths. You can click on the links here in the header section to see different settings in action.\n// Please note, that the default settings here are not ideal for all use cases, e.g. for the text content instead of image.\n// <b>Portlet settings (bold marks current setting in this demo)</b>\n//<p>\n//  <b>Layout</b>\n//  <div>\n//  Card area\n//  <a onclick=\"setClass('.dna-card-free','dna-card-free--bordered',['dna-card-free--bordered','dna-card-free--shadow'],'selected')\" class=\"selected\">Border</a>\n//  <a onclick=\"setClass('.dna-card-free','dna-card-free--shadow',['dna-card-free--bordered','dna-card-free--shadow'],'selected')\">Shadow</a>\n//  <a onclick=\"setClass('.dna-card-free','',['dna-card-free--bordered','dna-card-free--shadow'],'selected')\">No border</a>\n//  </div>\n//  <div>\n//  Card layout in desktop\n//  <a onclick=\"toggleClass('.dna-card-free','dna-card-free--inverted','selected')\">Inverted layout</a>\n//  </div>\n//  <div>\n//  Card layout in mobile\n//  <a onclick=\"setClass('.dna-card-free','',['dna-card-free--mobile-text-first','dna-card-free--mobile-no-image'],'selected')\" class=\"selected\">Normal, image first</a>\n//  <a onclick=\"setClass('.dna-card-free','dna-card-free--mobile-text-first',['dna-card-free--mobile-no-image'],'selected')\">Text first</a>\n//  <a onclick=\"setClass('.dna-card-free','dna-card-free--mobile-no-image',['dna-card-free--mobile-text-first'],'selected')\">No image</a>\n//  </div>\n//  <div>\n//  Card image in horizontal mode\n//  <a onclick=\"setClass('.dna-card-free','dna-card-free--image-w25', ['dna-card-free--image-w25','dna-card-free--image-w33', 'dna-card-free--image-w50','dna-card-free--image-w66'], 'selected')\">Image width 25%</a>\n//  <a onclick=\"setClass('.dna-card-free','dna-card-free--image-w33', ['dna-card-free--image-w25','dna-card-free--image-w33', 'dna-card-free--image-w50','dna-card-free--image-w66'], 'selected')\">Image width 33%</a>\n//  <a onclick=\"setClass('.dna-card-free','dna-card-free--image-w50', ['dna-card-free--image-w25','dna-card-free--image-w33', 'dna-card-free--image-w50','dna-card-free--image-w66'], 'selected')\" class=\"selected\">Image width 50%</a>\n//  <a onclick=\"setClass('.dna-card-free','dna-card-free--image-w66', ['dna-card-free--image-w25','dna-card-free--image-w33', 'dna-card-free--image-w50','dna-card-free--image-w66'], 'selected')\">Image width 66%</a>\n//  </div>\n//  <div>\n//  Card image in vertical mode\n//  <a onclick=\"setClass('.dna-card-free__image','', ['limited-height','no-crop'], 'selected')\" class=\"selected\">Image height normal</a>\n//  <a onclick=\"setClass('.dna-card-free__image','limited-height', ['limited-height','no-crop'], 'selected')\">Image height limited</a>\n//  <a onclick=\"setClass('.dna-card-free__image',['limited-height','no-crop'], ['limited-height','no-crop'], 'selected')\">Image height limited, no cropping</a>\n//  </div>\n//  <div>\n//  Card layout behaviour\n//  <a onclick=\"setClass('.dna-card-free','', ['dna-card-free--fixed-layout','dna-card-free--fixed-horizontal', 'dna-card-free--fixed-vertical', 'dna-card-free--verticalmode'], 'selected')\" class=\"selected\">Dynamic</a>\n//  <a onclick=\"setClass('.dna-card-free',['dna-card-free--fixed-layout', 'dna-card-free--fixed-horizontal'], ['dna-card-free--fixed-layout','dna-card-free--fixed-horizontal', 'dna-card-free--fixed-vertical', 'dna-card-free--verticalmode'], 'selected')\">Always horizontal</a>\n//  <a onclick=\"setClass('.dna-card-free',['dna-card-free--fixed-layout', 'dna-card-free--fixed-vertical'], ['dna-card-free--fixed-layout','dna-card-free--fixed-horizontal', 'dna-card-free--fixed-vertical', 'dna-card-free--verticalmode'], 'selected')\">Always vertical</a>\n//  </div>\n//</p>\n//<p>\n//  <b>Image size</b>\n//  <div>\n//  Image ratio\n//  <a onclick=\"(function() {changeImageAttrs('img.dna-cld-responsive--full','/upload/ar_1:1,c_fill,f_auto,q_auto,w_600/v1/');setClass('.dna-card-free__image-wrap','ratio-1-1',['ratio-1-1','ratio-4-3','ratio-16-9'],'selected')})()\">1:1</a>\n//  <a onclick=\"(function() {changeImageAttrs('img.dna-cld-responsive--full','/upload/ar_4:3,c_fill,f_auto,q_auto,w_600/v1/');setClass('.dna-card-free__image-wrap','ratio-4-3',['ratio-1-1','ratio-4-3','ratio-16-9'],'selected')})()\">4:3</a>\n//  <a onclick=\"(function() {changeImageAttrs('img.dna-cld-responsive--full','/upload/ar_16:9,c_fill,f_auto,q_auto,w_600/v1/');setClass('.dna-card-free__image-wrap','ratio-16-9',['ratio-1-1','ratio-4-3','ratio-16-9'],'selected')})()\">16:9</a>\n//  <a onclick=\"(function() {changeImageAttrs('img.dna-cld-responsive--full','/upload/c_scale,f_auto,q_auto,w_600/v1/');setClass('.dna-card-free__image-wrap','',['ratio-1-1','ratio-4-3','ratio-16-9'],'selected')})()\" class=\"selected\">Original</a>\n//  </div>\n//  <div>\n//  Image cover\n//  <a onclick=\"toggleClass('.dna-card-free__image','cover-height','selected')\">Image should cover full height in all cases</a>\n//  </div>\n//</p>\n//<p>\n//  <b>Alignments and paddings</b>\n//  <div>\n//  Image alignment\n//  <a onclick=\"setClass('.dna-card-free__image','dna-card-free__item--v-centered',['dna-card-free__item--v-centered','dna-card-free__item--h-centered','dna-card-free__item--v-top','dna-card-free__item--v-bottom','dna-card-free__item--centered'],'selected')\" class=\"selected\">Vertically centered</a>\n//  <a onclick=\"setClass('.dna-card-free__image','dna-card-free__item--h-centered',['dna-card-free__item--v-centered','dna-card-free__item--h-centered','dna-card-free__item--v-top','dna-card-free__item--v-bottom','dna-card-free__item--centered'],'selected')\">Horizontally centered</a>\n//  <a onclick=\"setClass('.dna-card-free__image','dna-card-free__item--v-top',['dna-card-free__item--v-centered','dna-card-free__item--h-centered','dna-card-free__item--v-top','dna-card-free__item--v-bottom','dna-card-free__item--centered'],'selected')\">Top</a>\n//  <a onclick=\"setClass('.dna-card-free__image','dna-card-free__item--v-bottom',['dna-card-free__item--v-centered','dna-card-free__item--h-centered','dna-card-free__item--v-top','dna-card-free__item--v-bottom','dna-card-free__item--centered'],'selected')\">Bottom</a>\n//  <a onclick=\"setClass('.dna-card-free__image','dna-card-free__item--centered',['dna-card-free__item--v-centered','dna-card-free__item--h-centered','dna-card-free__item--v-top','dna-card-free__item--v-bottom','dna-card-free__item--centered'],'selected')\">Centered</a>\n//  </div>\n//  <div>\n//  Image padding\n//  <a onclick=\"setClass('.dna-card-free__image','',['dna-card-free__item--padding','dna-card-free__item--v-padding','dna-card-free__item--top-side-padding'],'selected')\" class=\"selected\">No padding</a>\n//  <a onclick=\"setClass('.dna-card-free__image','dna-card-free__item--padding',['dna-card-free__item--padding','dna-card-free__item--v-padding','dna-card-free__item--top-side-padding'],'selected')\">Image padding</a>\n//  <a onclick=\"setClass('.dna-card-free__image','dna-card-free__item--v-padding',['dna-card-free__item--padding','dna-card-free__item--v-padding','dna-card-free__item--top-side-padding'],'selected')\">Image vertical padding</a>\n//  <a onclick=\"setClass('.dna-card-free__image','dna-card-free__item--top-side-padding',['dna-card-free__item--padding','dna-card-free__item--v-padding','dna-card-free__item--top-side-padding'],'selected')\">Image top and side padding</a>\n//  </div>\n//  <div>\n//  Text alignment\n//  <a onclick=\"setClass('.dna-card-free__text','dna-card-free__item--v-centered',['dna-card-free__item--v-centered','dna-card-free__item--h-centered','dna-card-free__item--v-top','dna-card-free__item--v-bottom','dna-card-free__item--centered'],'selected')\" class=\"selected\">Vertically centered</a>\n//  <a onclick=\"setClass('.dna-card-free__text','dna-card-free__item--h-centered',['dna-card-free__item--v-centered','dna-card-free__item--h-centered','dna-card-free__item--v-top','dna-card-free__item--v-bottom','dna-card-free__item--centered'],'selected')\">Horizontally centered</a>\n//  <a onclick=\"setClass('.dna-card-free__text','dna-card-free__item--v-top',['dna-card-free__item--v-centered','dna-card-free__item--h-centered','dna-card-free__item--v-top','dna-card-free__item--v-bottom','dna-card-free__item--centered'],'selected')\">Top</a>\n//  <a onclick=\"setClass('.dna-card-free__text','dna-card-free__item--v-bottom',['dna-card-free__item--v-centered','dna-card-free__item--h-centered','dna-card-free__item--v-top','dna-card-free__item--v-bottom','dna-card-free__item--centered'],'selected')\">Bottom</a>\n//  <a onclick=\"setClass('.dna-card-free__text','dna-card-free__item--centered',['dna-card-free__item--v-centered','dna-card-free__item--h-centered','dna-card-free__item--v-top','dna-card-free__item--v-bottom','dna-card-free__item--centered'],'selected')\">Centered</a>\n//  </div>\n//  <div>\n//  Text padding\n//  <a onclick=\"setClass('.dna-card-free__text','dna-card-free__item--padding',['dna-card-free__item--padding','dna-card-free__item--v-padding'],'selected')\" class=\"selected\">Text padding</a>\n//  <a onclick=\"setClass('.dna-card-free__text','dna-card-free__item--v-padding',['dna-card-free__item--padding','dna-card-free__item--v-padding'],'selected')\">Text vertical padding</a>\n//  <a onclick=\"setClass('.dna-card-free__text','',['dna-card-free__item--padding','dna-card-free__item--v-padding'],'selected')\">No padding</a>\n//  </div>\n//</p>\n//<p>\n//  <b>Colors</b>\n//  <div>\n//  Set area background to\n//  <a onclick=\"toggleClass('.dna-content-wrap--content','ds-bg--white','selected')\">White</a> or\n//  <a onclick=\"toggleClass('.dna-content-wrap--content','ds-bg--sand-01','selected')\">Sand E01</a>\n//  to see the effects of card background.\n//  </div>\n//  <div>\n//  Card background\n//  <a onclick=\"setClass('.dna-card-free',['ds-bg--none'],['ds-bg--none','ds-bg--white','ds-bg--sand','ds-bg--sand-01','ds-bg--plum','ds-color--white','ds-color--black','ds-content--dark-bg'],'selected')\" class=\"selected\">None</a>\n//  <a onclick=\"setClass('.dna-card-free',['ds-bg--white','ds-color--black'],['ds-bg--none','ds-bg--white','ds-bg--sand','ds-bg--sand-01','ds-bg--plum','ds-color--white','ds-color--black','ds-content--dark-bg'],'selected')\">White</a>\n//  <a onclick=\"setClass('.dna-card-free',['ds-bg--sand','ds-color--black'],['ds-bg--none','ds-bg--white','ds-bg--sand','ds-bg--sand-01','ds-bg--plum','ds-color--white','ds-color--black','ds-content--dark-bg'],'selected')\">Sand</a>\n//  <a onclick=\"setClass('.dna-card-free',['ds-bg--sand-01','ds-color--black'],['ds-bg--none','ds-bg--white','ds-bg--sand','ds-bg--sand-01','ds-bg--plum','ds-color--white','ds-color--black','ds-content--dark-bg'],'selected')\">Sand E01</a>\n//  <a onclick=\"setClass('.dna-card-free',['ds-bg--plum','ds-color--white','ds-content--dark-bg'],['ds-bg--none','ds-bg--white','ds-bg--sand','ds-bg--sand-01','ds-bg--plum','ds-color--white','ds-color--black','ds-content--dark-bg'],'selected')\">Plum</a>\n//  </div>\n//  <div>\n//  Image area bg color (some examples)\n//  <a onclick=\"setClass('.dna-card-free__image','',['ds-bg--white','ds-bg--plum','ds-bg--pink-02','ds-bg--sky-02','ds-color--white','ds-color--black','ds-content--dark-bg'],'selected')\" class=\"selected\">None</a>\n//  <a onclick=\"setClass('.dna-card-free__image',['ds-bg--white','ds-color--black'],['ds-bg--white','ds-bg--plum','ds-bg--pink-02','ds-bg--sky-02','ds-color--white','ds-color--black','ds-content--dark-bg'],'selected')\">White</a>\n//  <a onclick=\"setClass('.dna-card-free__image',['ds-bg--plum','ds-color--white','ds-content--dark-bg'],['ds-bg--white','ds-bg--plum','ds-bg--pink-02','ds-bg--sky-02','ds-color--white','ds-color--black','ds-content--dark-bg'],'selected')\">Plum</a>\n//  <a onclick=\"setClass('.dna-card-free__image',['ds-bg--pink-02','ds-color--black'],['ds-bg--white','ds-bg--plum','ds-bg--pink-02','ds-bg--sky-02','ds-color--white','ds-color--black','ds-content--dark-bg'],'selected')\">Pink E02</a>\n//  <a onclick=\"setClass('.dna-card-free__image',['ds-bg--sky-02','ds-color--black'],['ds-bg--white','ds-bg--plum','ds-bg--pink-02','ds-bg--sky-02','ds-color--white','ds-color--black','ds-content--dark-bg'],'selected')\">Sky E02</a>\n//  </div>\n//</p>\n//<p>\n//  <b>Only image or text provided</b>\n//  <div>\n//  Limit data\n//  <a onclick=\"toggleClass('.dna-card-free__image','ds-hidden','selected')\">No image</a>\n//  <a onclick=\"toggleClass('.dna-card-free__text','ds-hidden','selected')\">No text</a>\n//  </div>\n//</p>\n//<p>\n//  <b>Author and date info(pre-title)</b>\n//  <div>\n//  Author and date info: can be used for dates, author, etc.\n//  <a onclick=\"toggleClass('.dna-card-free__author','ds-hidden','selected')\">Toggle author info on/off</a>\n//  </div>\n//</p>\n//<p>\n//  <b>Logo image usage</b>\n//  <div>\n//  Use logo image\n//  <a onclick=\"toggleClass('.dna-logo-image__container','ds-hidden','selected')\">Toggle logo on/off</a>\n//  </div>\n//  <div>\n//  Logo image position\n//  <a onclick=\"setClass('.dna-logo-image__container',['dna-logo-image__container--default'],['dna-logo-image__container--default','styleguide-freecard-logo-custom','full','topright','bottomright','topleft','bottomleft'],'selected')\" class=\"selected\">Center</a>\n//  <a onclick=\"setClass('.dna-logo-image__container',['dna-logo-image__container--default','full'],['dna-logo-image__container--default','styleguide-freecard-logo-custom','full','topright','bottomright','topleft','bottomleft'],'selected')\">Full area</a>\n//  <a onclick=\"setClass('.dna-logo-image__container',['dna-logo-image__container--default','topright'],['dna-logo-image__container--default','styleguide-freecard-logo-custom','full','topright','bottomright','topleft','bottomleft'],'selected')\">Top right</a>\n//  <a onclick=\"setClass('.dna-logo-image__container',['dna-logo-image__container--default','bottomright'],['dna-logo-image__container--default','styleguide-freecard-logo-custom','full','topright','bottomright','topleft','bottomleft'],'selected')\">Bottom right</a>\n//  <a onclick=\"setClass('.dna-logo-image__container',['dna-logo-image__container--default','topleft'],['dna-logo-image__container--default','styleguide-freecard-logo-custom','full','topright','bottomright','topleft','bottomleft'],'selected')\">Top left</a>\n//  <a onclick=\"setClass('.dna-logo-image__container',['dna-logo-image__container--default','bottomleft'],['dna-logo-image__container--default','styleguide-freecard-logo-custom','full','topright','bottomright','topleft','bottomleft'],'selected')\">Bottom left</a>\n//  <a onclick=\"setClass('.dna-logo-image__container',['dna-logo-image__container--custom','styleguide-freecard-logo-custom'],['dna-logo-image__container--default','styleguide-freecard-logo-custom','full','topright','bottomright','topleft','bottomleft'],'selected')\">Custom</a>\n//  </div>\n//</p>\n// <script>\n//  function setClass(element, className, removeClassNames, focusClass) {\n//    document.querySelectorAll(element).forEach(function(x) {if(removeClassNames)x.classList.remove(...removeClassNames);if(className){if(Array.isArray(className)){x.classList.add(...className)}else{x.classList.add(className)};}});\n//    Array.from(event.target.parentElement.children).forEach(function(x) {x.classList.remove(focusClass)});\n//    event.target.classList.add(focusClass);\n//  }\n//  function toggleClass(element, className, focusClass) {\n//    document.querySelectorAll(element).forEach(function(x) {x.classList.toggle(className)});\n//    event.target.classList.toggle(focusClass);\n//  }\n//  function changeImageAttrs(element, attrs) {document.querySelectorAll(element).forEach(function(x) {x.src=x.src.replace(/\\/upload\\/.*\\/v1\\//, attrs)}) }\n// </script>\n//\n// .dna-grid.dna-grid--3.dna-grid--wide-gutter - In a grid\n//\n// Markup:\n//<div class=\"dna-content-wrap--content\">\n//    <div class=\"styleguide-dna-card-free {$modifiers}\">\n//        <div class=\"dna-grid-item\">\n//            <div class=\"styleguide-explanation\">Normal card with 2 CTA</div>\n//            <div class=\"dna-card-free__outside-wrap\">\n//                <div class=\"dna-card-free dna-card-free--bordered ds-bg--none\">\n//                    <div class=\"dna-card-free__image dna-card-free__item dna-card-free__item--v-centered\">\n//                        <div class=\"dna-card-free__image-wrap dna-cld-container\">\n//                            <img class=\"dna-cld-responsive dna-cld-responsive--full\" src=\"https://res.cloudinary.com/dnaoyj/image/upload/c_scale,f_auto,q_auto,w_600/v1/sample.jpg\" loading=\"lazy\" />\n//                            <div class=\"dna-logo-image__container dna-logo-image__container--default ds-hidden\">\n//                                <img class=\"dna-cld-responsive dna-logo-image\" src=\"https://res.cloudinary.com/dnaoyj/image/upload/dpr_1,f_auto,q_auto,w_200/v1/Assets/Icons%20and%20logos/DNA%20Logos/DNA_logo_pink_1200x1200\">\n//                            </div>\n//                        </div>\n//                    </div>\n//                    <div class=\"dna-card-free__text dna-card-free__item dna-card-free__item--padding dna-card-free__item--v-centered basic-web-content\">\n//                        <span class=\"dna-card-free__author ds-hidden\">\n//                            12.12.2023 Joan Doe\n//                        </span>\n//                        <h2>Onko sinulla DNA:n puhelin- tai nettiliittymä?</h2>\n//                        <p>Hyödynnä asiakasetusi. Jos sinulla on DNA:n puhelin- tai nettiliittymä, saat valituista kanavapaketeista 20% alennuksen + lisäksi DNA TV 2kk 0 €, jonka jälkeen 6,90 €/kk</p>\n//                        <div class=\"dna-card-free__align-bottom\"></div>\n//                        <div class=\"dna-card-free__cta-area\">\n//                            <div class=\"dna-card-free__cta-wrapper ds-btn-group\">\n//                                <a href=\"#\" class=\"dna-card-free__cta ds-btn\">Tutustu ja tilaa</a>\n//                                <a href=\"#\" class=\"dna-card-free__cta ds-btn\">Lue lisää</a>\n//                            </div>\n//                        </div>\n//                    </div>\n//                </div>\n//            </div>\n//        </div>\n//        <div class=\"dna-grid-item\">\n//            <div class=\"styleguide-explanation\">Normal card with 1 CTA</div>\n//            <div class=\"dna-card-free__outside-wrap\">\n//                <div class=\"dna-card-free dna-card-free--bordered ds-bg--none\">\n//                    <div class=\"dna-card-free__image dna-card-free__item dna-card-free__item--v-centered dna-cld-container\">\n//                        <div class=\"dna-card-free__image-wrap dna-cld-container\">\n//                            <img class=\"dna-cld-responsive dna-cld-responsive--full\" src=\"https://res.cloudinary.com/dnaoyj/image/upload/c_scale,f_auto,q_auto,w_600/v1/Assets/KLT/DNA%20TV/dnatv_kanavat1\" loading=\"lazy\" />\n//                            <div class=\"dna-logo-image__container dna-logo-image__container--default ds-hidden\">\n//                                <img class=\"dna-cld-responsive dna-logo-image\" src=\"https://res.cloudinary.com/dnaoyj/image/upload/dpr_1,f_auto,q_auto,w_200/v1/Assets/Icons%20and%20logos/DNA%20Logos/DNA_logo_pink_1200x1200\">\n//                            </div>\n//                        </div>\n//                    </div>\n//                    <div class=\"dna-card-free__text dna-card-free__item dna-card-free__item--padding dna-card-free__item--v-centered basic-web-content\">\n//                        <span class=\"dna-card-free__author ds-hidden\">\n//                           12.12.2023 Joan Doe\n//                       </span>\n//                        <h2>Toimintavarma netti on modeemista kiinni</h2>\n//                        <p>Varmistat toimintavarman netin ja kattavan WiFi:n koko kotiisi huolehtimalla, että modeemisi on ajan tasalla ja kodissasi on riittävä määrä Mesh WiFi  -laitteita. Saatat tarvita kodin WiFi -verkolle vahvistimia, eli Mesh WiFi -laitteita silloin, kun neliöitä tai kerroksia on enemmän tai kotonasi on esim. paksuja kiviseiniä. Yksi Mesh WiFi -laite kattaa noin 70 m2 yhdessä kerroksessa.</p>\n//                        <p>Uudella modeemilla ja Mesh WiFi -laitteilla saat toimintavarman netin kodin jokaiseen huoneeseen.</p>\n//                        <div class=\"dna-card-free__align-bottom\"></div>\n//                        <div class=\"dna-card-free__cta-area\">\n//                            <div class=\"dna-card-free__cta-wrapper ds-btn-group\">\n//                                <a href=\"#\" class=\"dna-card-free__cta ds-btn\">Tutustu nettilaitteisiin täällä</a>\n//                            </div>\n//                        </div>\n//                    </div>\n//                </div>\n//            </div>\n//        </div>\n//        <div class=\"dna-grid-item\">\n//            <div class=\"styleguide-explanation\">Full element link</div>\n//            <div class=\"dna-card-free__outside-wrap\">\n//                <div class=\"dna-card-free dna-card-free--bordered ds-bg--none\">\n//                    <div class=\"dna-card-free__image dna-card-free__item dna-card-free__item--v-centered dna-cld-container\">\n//                        <div class=\"dna-card-free__image-wrap dna-cld-container\">\n//                            <img class=\"dna-cld-responsive dna-cld-responsive--full\" src=\"https://res.cloudinary.com/dnaoyj/image/upload/c_scale,f_auto,q_auto,w_600/v1/sample.jpg\" loading=\"lazy\" />\n//                            <div class=\"dna-logo-image__container dna-logo-image__container--default ds-hidden\">\n//                                <img class=\"dna-cld-responsive dna-logo-image\" src=\"https://res.cloudinary.com/dnaoyj/image/upload/dpr_1,f_auto,q_auto,w_200/v1/Assets/Icons%20and%20logos/DNA%20Logos/DNA_logo_pink_1200x1200\">\n//                            </div>\n//                        </div>\n//                    </div>\n//                    <div class=\"dna-card-free__text dna-card-free__item dna-card-free__item--padding dna-card-free__item--v-centered basic-web-content\">\n//                        <blockquote>\n//                            <p>It's a long way to the top if you wanna rock 'n' roll</p>\n//                            <p>AC/DC</p>\n//                        </blockquote>\n//                    </div>\n//                    <a href=\"#\" class=\"dna-card-free__full-element-link\"></a>\n//                </div>\n//            </div>\n//        </div>\n//        <div class=\"dna-grid-item\">\n//            <div class=\"styleguide-explanation\">Text instead of image, transformed 150px image</div>\n//            <div class=\"dna-card-free__outside-wrap\">\n//                <div class=\"dna-card-free dna-card-free--bordered ds-bg--none\">\n//                    <div class=\"dna-card-free__image dna-card-free__image--text dna-card-free__item dna-card-free__item--v-centered\">\n//                        <div class=\"dna-card-free__image-wrap\">\n//                            <p><img class=\"dna-cld-transformed dna-cld-transformed--fixed-size\" src=\"https://res.cloudinary.com/dnaoyj/image/upload/c_scale,f_auto,q_auto,w_150/v1/Assets/Nettipulssi/usp2\" loading=\"lazy\" /></p>\n//                            <div class=\"dna-logo-image__container dna-logo-image__container--default ds-hidden\">\n//                                <img class=\"dna-cld-responsive dna-logo-image\" src=\"https://res.cloudinary.com/dnaoyj/image/upload/dpr_1,f_auto,q_auto,w_200/v1/Assets/Icons%20and%20logos/DNA%20Logos/DNA_logo_pink_1200x1200\">\n//                            </div>\n//                        </div>\n//                    </div>\n//                    <div class=\"dna-card-free__text dna-card-free__item dna-card-free__item--padding dna-card-free__item--v-centered basic-web-content\">\n//                        <span class=\"dna-card-free__author ds-hidden\">\n//                            12.12.2023 Joan Doe\n//                        </span>\n//                        <h2>Haluatko tietää miten kotiverkollasi menee? Ota pulssi!</h2>\n//                        <p>DNA Nettipulssilla voit kätevästi tarkistaa kotisi WiFin toimivuuden. Saat samalla vinkkejä langattoman verkon parantamiseksi kotisi jokaisessa huoneessa.</p>\n//                        <p><a href=\"#\">Tutustu DNA Nettipulssiin</a>.</p>\n//                    </div>\n//                </div>\n//            </div>\n//        </div>\n//        <div class=\"dna-grid-item\">\n//            <div class=\"styleguide-explanation\">Text instead of image</div>\n//            <div class=\"dna-card-free__outside-wrap\">\n//                <div class=\"dna-card-free dna-card-free--bordered ds-bg--none\">\n//                    <div class=\"dna-card-free__image dna-card-free__image--text dna-card-free__item dna-card-free__item--v-centered\">\n//                        <div class=\"dna-card-free__image-wrap\">\n//                            <h2>Täyden&shy;tävät palvelut</h2>\n//                            <p>Tähän voi laittaa lisää sisältöä</p>\n//                            <div class=\"dna-logo-image__container dna-logo-image__container--default ds-hidden\">\n//                                <img class=\"dna-cld-responsive dna-logo-image\" src=\"https://res.cloudinary.com/dnaoyj/image/upload/dpr_1,f_auto,q_auto,w_200/v1/Assets/Icons%20and%20logos/DNA%20Logos/DNA_logo_pink_1200x1200\">\n//                            </div>\n//                        </div>\n//                    </div>\n//                    <div class=\"dna-card-free__text dna-card-free__item dna-card-free__item--padding dna-card-free__item--v-centered basic-web-content\">\n//                        <p><strong><a href=\"#\">Yritysverkko</a>, <a href=\"#\">internet yhteydet</a></strong> ja<strong> <a href=\"#\">lähiverkot</a> </strong>ovat tyypillisiä kohteita palomuurilla suojattaviksi.</p>\n//                        <p><strong><a href=\"#\">Palvelunestohyökkäyksiltä suojautuminen</a> </strong>täydentää palomuurin turvaa suojaamalla internetliikenteen jo DNA:n runkoverkossa palvelunestohyökkäysten varalta.</p>\n//                        <p><strong><a href=\"#\">Päätelaitteiden tietoturva</a> </strong>täydentää palomuurin turvaa suojaamalla päätelaitteet ja palvelimet.</p>\n//                    </div>\n//                </div>\n//            </div>\n//        </div>\n//        <div class=\"dna-grid-item\">\n//            <div class=\"styleguide-explanation\">Example for fixed layout</div>\n//            <div class=\"dna-card-free__outside-wrap\">\n//                <div class=\"dna-card-free dna-card-free--bordered ds-bg--none\">\n//                    <div class=\"dna-card-free__image dna-card-free__item dna-card-free__item--v-centered dna-cld-container\">\n//                        <div class=\"dna-card-free__image-wrap dna-cld-container\">\n//                            <img class=\"dna-cld-responsive dna-cld-responsive--full\" src=\"https://res.cloudinary.com/dnaoyj/image/upload/c_scale,f_auto,q_auto,w_600/v1/Assets/Icons%20and%20logos/DNA%20emoji%20set/dna_emoji_stareye.png\" loading=\"lazy\" />\n//                            <div class=\"dna-logo-image__container dna-logo-image__container--default ds-hidden\">\n//                                <img class=\"dna-cld-responsive dna-logo-image\" src=\"https://res.cloudinary.com/dnaoyj/image/upload/dpr_1,f_auto,q_auto,w_200/v1/Assets/Icons%20and%20logos/DNA%20Logos/DNA_logo_pink_1200x1200\">\n//                            </div>\n//                        </div>\n//                    </div>\n//                    <div class=\"dna-card-free__text dna-card-free__item dna-card-free__item--padding dna-card-free__item--v-centered basic-web-content\">\n//                        <span class=\"dna-card-free__author ds-hidden\">\n//                            12.12.2023 Joan Doe\n//                        </span>\n//                        <h2>Test Tester</h2>\n//                        <p>Testing content suitable for contact cards</p>\n//                        <p>\n//                            <strong><a href=\"#\">+358 123 4567</a></strong><br>\n//                            <strong><a href=\"#\">test.tester@dna.fi</a></strong>\n//                        </p>\n//                    </div>\n//                </div>\n//            </div>\n//        </div>\n//        <div class=\"dna-grid-item\">\n//            <div class=\"styleguide-explanation\">With label</div>\n//            <div class=\"dna-card-free__outside-wrap\">\n//                <div class=\"dna-card-free__tag ds-label ds-label--text ds-label--align-top-center\">\n//                    Kuva & video\n//                </div>\n//                <div class=\"dna-card-free dna-card-free--bordered ds-bg--none\">\n//                    <div class=\"dna-card-free__image dna-card-free__item dna-card-free__item--v-centered\">\n//                        <div class=\"dna-card-free__image-wrap dna-cld-container\">\n//                            <img class=\"dna-cld-responsive dna-cld-responsive--full\" src=\"https://res.cloudinary.com/dnaoyj/image/upload/c_scale,f_auto,q_auto,w_600/v1/asentaja-laite-600x400\" loading=\"lazy\" />\n//                            <div class=\"dna-logo-image__container dna-logo-image__container--default ds-hidden\">\n//                                <img class=\"dna-cld-responsive dna-logo-image\" src=\"https://res.cloudinary.com/dnaoyj/image/upload/dpr_1,f_auto,q_auto,w_200/v1/Assets/Icons%20and%20logos/DNA%20Logos/DNA_logo_pink_1200x1200\">\n//                            </div>\n//                        </div>\n//                    </div>\n//                    <div class=\"dna-card-free__text dna-card-free__item dna-card-free__item--padding dna-card-free__item--v-centered basic-web-content\">\n//                        <h2>DNA Laitenetti Plus</h2>\n//                        <p>8,90 €/kk/12 kk, jatkossa 9,90 €/kk, avaus 0 €</p>\n//                    </div>\n//                </div>\n//            </div>\n//        </div>\n//        <div class=\"dna-grid-item\">\n//            <div class=\"styleguide-explanation\">Only logo</div>\n//            <div class=\"dna-card-free__outside-wrap\">\n//                <div class=\"dna-card-free dna-card-free--bordered ds-bg--none\">\n//                    <div class=\"dna-card-free__image dna-card-free__item dna-card-free__item--v-centered\">\n//                        <div class=\"dna-card-free__image-wrap dna-card-free__image-wrap--only-logo\">\n//                            <div class=\"dna-logo-image__container dna-logo-image__container--default\">\n//                                <img class=\"dna-cld-responsive dna-logo-image\" src=\"https://res.cloudinary.com/dnaoyj/image/upload/dpr_1,f_auto,q_auto,w_200/v1/Assets/Icons%20and%20logos/DNA%20Logos/DNA_logo_pink_1200x1200\">\n//                            </div>\n//                        </div>\n//                    </div>\n//                    <div class=\"dna-card-free__text dna-card-free__item dna-card-free__item--padding dna-card-free__item--v-centered basic-web-content\">\n//                        <h2>Only logo image</h2>\n//                        <p>Lorem ipsum dolor sit amet, consectetur adipiscing elit. Pellentesque eleifend ut felis ut porta. Suspendisse potenti. Phasellus ut sem tortor. Duis a est vitae dui luctus placerat vitae a mauris. Nam at consectetur risus, eu vehicula lectus. Nam nisi erat, finibus a nunc a, blandit rutrum libero. Aenean luctus imperdiet turpis, sit amet volutpat lorem sagittis eu. Nulla tincidunt mauris porttitor nulla bibendum sollicitudin.</p>\n//                        <div class=\"dna-card-free__align-bottom\"></div>\n//                        <div class=\"dna-card-free__cta-area\">\n//                            <div class=\"dna-card-free__cta-wrapper ds-btn-group\">\n//                                <a href=\"#\" class=\"dna-card-free__cta ds-btn\">button</a>\n//                            </div>\n//                        </div>\n//                    </div>\n//                </div>\n//            </div>\n//        </div>\n//        <div class=\"dna-grid-item\">\n//            <div class=\"styleguide-explanation\">CTA in content</div>\n//            <div class=\"dna-card-free__outside-wrap\">\n//                <div class=\"dna-card-free dna-card-free--bordered ds-bg--none\">\n//                    <div class=\"dna-card-free__image dna-card-free__item dna-card-free__item--v-centered\">\n//                        <div class=\"dna-card-free__image-wrap dna-cld-container\">\n//                            <img alt=\"\" class=\"dna-cld-transformed dna-cld-transformed--fixed-size\" loading=\"lazy\" src=\"https://res.cloudinary.com/dnaoyj/image/upload/c_scale,w_60,dpr_auto,f_auto,q_auto/v1/Assets/Tietoturva/DNA_Digiturva_340x400\">\n//                        </div>\n//                    </div>\n//                    <div class=\"dna-card-free__text dna-card-free__item dna-card-free__item--padding dna-card-free__item--v-centered basic-web-content\">\n//                        <h3>DNA Digiturva 1-2 laitteelle</h3>\n//                        <p>Yhden hengen taloudelle sopiva paketti</p>\n//                        <p><button class=\"ds-btn ds-btn--full ds-btn--primary\" type=\"button\">Tilaa tästä</button></p>\n//                    </div>\n//                </div>\n//            </div>\n//        </div>\n//    </div>\n//</div>\n//\n// Styleguide 20.1\n\n.dna-card-free--as-hero {\n  @include dropshadow-elevation-extra-high();\n  border-radius: 0;\n  border-width: 0 0 1px;\n  position: relative;\n  z-index: 1;\n  margin-bottom: 20px;\n\n  .dna-card-free__image-wrap {\n    border-radius: 0 !important;\n  }\n\n  // switch to vertical mode earlier\n  &:not(.dna-card-free--verticalmode):not(.dna-card-free--fixed-vertical) .dna-card-free__item {\n    flex-basis: 400px;\n  }\n\n  // in admin mode, drop the z-index, because it blocks portlet controls\n  body.admin-signed-in.controls-visible & {\n    z-index: initial;\n  }\n}\n\n// Freestyle card as Hero\n//\n// There are special cases for Heros, which can't be done with normal Hero content. E.g. Apple campaign heros.\n// For that purpose there is an option to use Freestyle card as Hero.\n//\n// Markup:\n//  <div class=\"dna-card-free__outside-wrap\">\n//    <div class=\"dna-card-free dna-card-free--as-hero ds-bg--white ds-color--black dna-card-free--inverted dna-card-free--image-w50\">\n//      <div class=\"dna-card-free__item dna-card-free__image  cover-height dna-card-free__item--v-centered\">\n//        <div class=\"dna-card-free__image-wrap dna-cld-container\">\n//          <img class=\"dna-cld-responsive dna-cld-responsive--full\" src=\"https://res.cloudinary.com/dnaoyj/image/upload/dpr_2,f_auto,q_auto,w_600/v1/Assets/KLT/valmistajaländärit/Samsung/dna_laitelanseeraus_diamond_dnafi_laitteet_banneri_800x467uusin\" loading=\"lazy\" />\n//        </div>\n//      </div>\n//      <div class=\"dna-card-free__item dna-card-free__text dna-card-free__item--padding dna-card-free__item--v-centered basic-web-content\">\n//        <h1>Himotuimmat Samsung uutuudet</h1>\n//        <p>Lorem ipsum dolor sit amet, consectetur adipiscing elit. Sed ac diam vitae dolor rhoncus auctor sed id nisl. Aliquam vehicula eu nibh ac malesuada.</p>\n//        <p>&nbsp;</p>\n//        <p><a class=\"ds-btn ds-btn--primary\" href=\"#\">Lue lisää</a></p>\n//      </div>\n//    </div>\n//  </div>\n//\n// Styleguide 20.2\n","// Breakpoints\n$breakpoint-tiny-mobile: 360px;\n$breakpoint-large-mobile: 480px;\n$breakpoint-tablet: 768px;\n$breakpoint-desktop: 1024px;\n$breakpoint-desktop-content: 1280px;\n$breakpoint-large-desktop: 1440px;\n$breakpoint-extralarge-desktop: 1920px;\n\n$font-size-normal:             16px;\n$font-size-emphasized:         18px;\n$font-size-bigger:             20px;\n$font-size-large:              32px;\n$font-size-largest:            44px;\n$font-size-huge:               80px;\n$font-size-small:              14px;\n$font-size-extrasmall:         12px;\n$font-size-tiny:               10px;\n\n$line-height-normal:           1.25; // for 16px, 20px\n$line-height-large:            1.5; // for 16px, 24px\n\n$font-family-heading-demi-bold: 'DNA Heading Demi Bold', 'Helvetica Neue', Helvetica, Arial, sans-serif;\n$font-family-heading-bold:      'DNA Heading Bold', 'Helvetica Neue', Helvetica, Arial, sans-serif;\n$font-family-heading-black:     'DNA Heading Black', 'Helvetica Neue', Helvetica, Arial, sans-serif;\n$font-family-text-bold:         'DNA Text Bold', 'Helvetica Neue', Helvetica, Arial, sans-serif;\n$font-family-text-medium:       'DNA Text Medium', 'Helvetica Neue', Helvetica, Arial, sans-serif;\n$font-family-text-regular:      'DNA Text Regular', 'Helvetica Neue', Helvetica, Arial, sans-serif;\n\n// colors https://www.figma.com/file/L4IG6SG3AL7sue9YG1g2gB/DNA-Colors-NEW?node-id=2%3A419\n$color-main--white: #FFFFFF;\n$color-main--black: #121212;\n$color-main--pink: #DA0070;\n$color-main--pink-01: #FF82C1;\n$color-main--pink-02: #FFBFDF;\n$color-main--plum: #551C3E;\n$color-main--plum-01: #69214C;\n$color-main--plum-02: #792A59;\n\n$color-accent--lemon: #FFF347;\n$color-accent--lemon-01: #FFF9A3;\n$color-accent--lemon-02: #FFFABA;\n$color-accent--sky: #2ECAF0;\n$color-accent--sky-01: #77DCF5;\n$color-accent--sky-02: #96E4F8;\n$color-accent--orange: #FFA633;\n$color-accent--orange-01: #FFCA85;\n$color-accent--orange-02: #FFDBAD;\n\n$color-bg--white: #FFFFFF;\n$color-bg--sand: #FDFBFA;\n$color-bg--sand-01: #F8F4F1;\n$color-bg--sand-02: #EDE8E1;\n$color-bg--frostedglass: #f5f5f5eb;\n\n$color-text--black: #121212;\n$color-text--dark-gray: #505050;\n$color-text--plum: #551C3E;\n$color-text--pink: #DA0070;\n$color-text--white: #FFFFFF;\n$color-text--disabled: scale_color($color-text--black, $alpha: -50%);\n\n$color-utility--text-link: #DA0070;\n$color-utility--text-link-hover: scale_color($color-utility--text-link, $lightness: -20%);\n$color-utility--focus: #0064E2;\n$color-utility--focus-light: #D8E9FF;\n\n$color-line--01: #948B89;\n$color-line--02: #D4D2CE;\n$color-line--03: #E7E5E3;\n$color-line--04: #EFEEED;\n\n$color-notification--info: #0B7C99;\n$color-notification--warning: #EB6600;\n$color-notification--error: #DD0A0A;\n$color-notification--success: #008500;\n\n$border-radius--small: 4px;\n$border-radius--normal: 8px;\n$border-radius--full: 50%;\n\n\n//page min max widths\n$page-min-width: 320px;\n$page-max-width: 2560px;\n$page-layout-normal-content-maxwidth: 1200px;\n$page-layout-medium-content-maxwidth: 860px;\n$page-layout-small-content-maxwidth: 640px;\n\n// grid paddings\n$grid-gap--small: 10px;\n$grid-gap--wide: 30px;\n$grid-gap--large: 60px;\n$grid-padding: 10px;\n\n//portlet margins\n$margin-portlet-default:        50px;\n$margin-portlet-small:          30px;\n$margin-portlet-extrasmall:     10px;\n$margin-portlet-extralarge:     20vh;\n\n//input variables\n$button-height-default:   40px;\n$button-height-small:     32px;\n$input-height-default:    40px;\n$input-border-color:            $color-line--01;\n$input-field-bg:                $color-bg--white;\n$input-text-color:              $color-text--black;\n$input-border-shorthand:        1px solid $input-border-color;\n$form-elements-max-width:       515px;\n\n//label\n$ds-label-height: 22px;\n\n// Use these colors anywhere a link, input or a button is disabled!\n$disabled-background:           #f2f2f2;\n$disabled-text:                 #999999;\n\n\n$header-height-desktop: 108px; // 48px site nav + 60 main nav\n$header-height-mobile: 98px; // 38px site nav + 60 main nav\n$header-main-nav-height: 60px;\n$secondary-nav-height-desktop: 57px; // needed for toaster positioning\n$secondary-nav-height-mobile: 64px;\n$admin-dockbar-height: 74px;\n$admin-edit-mode-dockbar-height: 155px;\n\n$card-height: 400px;\n$card-height-actual: 400px - 2px; //borders\n$card-height-extended: 600px;\n$card-title-line-height: 20px;\n\n$form-element-border-width: 0 1px 1px;\n\n$tab-item-height: 36px;\n\n// z-index levels\n$z-index-level-1-base: 0;\n$z-index-level-2-floating: 200; // for all first level floating elements\n$z-index-level-3-popup-overlay: 600; // for header login modals and other popups that should be under the header\n$z-index-level-4-header: 1000;\n$z-index-level-5-chat: 1040; // Should be above header but below overlay. Rocket modal has z-index: 1050, so we need Chat to be just below, and above their header that has 1030.\n$z-index-level-6-modal-overlay: 1100; // for modal that should cover the header\n$z-index-level-7-modal: 1200; // top level modals","@use \"sass:math\";\n\n@mixin breakpoint($point) {\n    @if $point == mobile {\n        @media screen and (max-width: $breakpoint-tablet - 1)  { @content; }\n    }\n    @else if $point == tablet {\n        @media screen and (min-width: $breakpoint-tablet) { @content; }\n    }\n    @else if $point == smaller-than-desktop {\n        @media screen and (max-width: $breakpoint-desktop - 1) { @content; }\n    }\n    @else if $point == desktop {\n        @media screen and (min-width: $breakpoint-desktop) { @content; }\n    }\n    @else if $point == desktop-content {\n        @media screen and (min-width: $breakpoint-desktop-content) { @content; }\n    }\n    @else if $point == large-desktop {\n        @media screen and (min-width: $breakpoint-large-desktop) { @content; }\n    }\n    @else if $point == extralarge-desktop {\n        @media screen and (min-width: $breakpoint-extralarge-desktop) { @content; }\n    }\n    @else if $point == tablet-only {\n        @media screen and (min-width: $breakpoint-tablet) and (max-width: $breakpoint-desktop - 1) { @content; }\n    }\n    @else if $point == large-mobile {\n        @media screen and (min-width: $breakpoint-large-mobile) { @content; }\n    }\n    @else if $point == large-mobile-only {\n        @media screen and (min-width: $breakpoint-large-mobile) and (max-width: $breakpoint-tablet - 1) { @content; }\n    }\n    @else if $point == small-mobile {\n        @media screen and (max-width: $breakpoint-large-mobile - 1)  { @content; }\n    }\n    @else if $point == tiny-mobile {\n        @media screen and (max-width: $breakpoint-tiny-mobile - 1)  { @content; }\n    }\n    @else if $point == max-page {\n        @media screen and (min-width: $page-max-width)  { @content; }\n    }\n\n    @else {\n        @media (#{$point}) { @content; }\n    }\n}\n\n@mixin orientation($orientation) {\n    @if $orientation == landscape {\n        @media all and (orientation:landscape) { @content; }\n    }\n    @else if $orientation == portrait {\n        @media all and (orientation:portrait) { @content; }\n    }\n}\n\n@mixin high-res() {\n    @media only screen and (-webkit-min-device-pixel-ratio: 1.5),\n    only screen and (min-resolution: 144dpi) {\n        @content;\n    }\n}\n\n// The micro clearfix http://nicolasgallagher.com/micro-clearfix-hack/\n@mixin clearfix() {\n\n    &:before,\n    &:after {\n        content:\"\";\n        display:table;\n    }\n    &:after {\n        clear:both;\n    }\n}\n\n@mixin aspect-ratio($ratio-or-width, $height: null) {\n    $padding: if($height, percentage(math.div($height,$ratio-or-width)), percentage(math.div(1,$ratio-or-width)));\n    &:before {\n        content: '';\n        float: left;\n        padding-bottom: $padding;\n    }\n    &:after {\n        content: '';\n        display: table;\n        clear: both;\n    }\n}\n\n@mixin transparent-selection {\n    &::selection {\n        background: none;\n    }\n\n    &::-moz-selection {\n        background: none;\n    }\n}\n\n@mixin hero-font-size($mobile, $largemobile, $tablet, $desktop, $largedesktop: $desktop) {\n    font-size: $mobile + px;\n    @include breakpoint(large-mobile) {\n        font-size: $largemobile + px;\n    }\n    @include breakpoint(tablet) {\n        font-size: $tablet + px;\n    }\n    @include breakpoint(desktop) {\n        font-size: $desktop + px;\n    }\n    @include breakpoint(large-desktop) {\n        font-size: $largedesktop + px;\n    }\n}\n\n@mixin matchToHeaderHeight($property, $isBodyElement: false, $extraheight: 0, $negative:false) {\n    $multiplier: 1;\n    @if $negative { $multiplier: -1}\n\n    #{$property}: ($header-height-mobile + $extraheight) * $multiplier;\n    @include breakpoint(desktop) {\n        #{$property}: ($header-height-desktop + $extraheight) * $multiplier;\n    }\n}\n\n@mixin positionAbsoluteFull {\n    position: absolute;\n    inset: 0;\n}\n@mixin positionAbsoluteCenter {\n    position: absolute;\n    top: 50%;\n    left: 50%;\n    transform: translate(-50%,-50%);\n}\n\n@mixin buttonStyleReset {\n    border: none;\n    background: none;\n    font: inherit;\n    line-height: inherit;\n    color: currentColor;\n    text-align: left;\n    margin: 0;\n    padding: 0;\n}\n\n@mixin listStyleReset {\n    list-style: none;\n    margin: 0;\n    padding: 0;\n    overflow: initial;\n    > li {\n        margin: 0;\n    }\n}\n\n@mixin dropshadow-elevation-low($clip: null) {\n    border: 1px solid $color-line--04;\n    box-shadow: 0px 2px 16px 0px scale_color($color-text--black, $alpha: -94%);\n    border-radius: $border-radius--normal;\n    @if($clip) {\n        overflow: hidden;\n    }\n}\n@mixin dropshadow-elevation-high($clip: null) {\n    border: 1px solid $color-line--04;\n    box-shadow: 0px 4px 24px 0px scale_color($color-text--black, $alpha: -92%);\n    border-radius: $border-radius--normal;\n    @if($clip) {\n        overflow: hidden;\n    }\n}\n@mixin dropshadow-elevation-extra-high($clip: null) {\n    border: 1px solid $color-line--04;\n    box-shadow: 0px 8px 64px 0px scale_color($color-text--black, $alpha: -84%);\n    border-radius: $border-radius--normal;\n    @if($clip) {\n        overflow: hidden;\n    }\n}\n@mixin default-focus($radius: null) {\n    &:focus {\n        outline: none;\n        box-shadow: none;\n    }\n    &:focus-visible {\n        outline: 1px solid transparent;\n        box-shadow: 0px 0px 0px 2px $color-utility--focus-light, 0px 0px 0px 4px $color-utility--focus;\n        @if($radius) {\n            border-radius: $radius;\n        }\n    }\n}\n@mixin inner-focus($radius: null) {\n    &:focus {\n        outline: none;\n        box-shadow: none;\n    }\n    &:focus-visible {\n        outline: none;\n        box-shadow: inset 0px 0px 0px 2px $color-utility--focus, inset 0px 0px 0px 4px $color-utility--focus-light;\n        @if($radius) {\n            border-radius: $radius;\n        }\n    }\n}\n@mixin input-field-icon($url, $url2: null) {\n    @if($url2) {\n        padding-right: 60px;\n        background-image: url($url), url($url2);\n    } @else {\n        padding-right: 40px;\n        background-image: url($url);\n    }\n    background-position: right 10px center, right 35px center;\n    background-repeat: no-repeat;\n    background-size: 20px 20px;\n}\n@mixin underline {\n    text-decoration: underline;\n    text-underline-offset: 0.2em;\n    text-decoration-skip-ink: auto;\n    text-decoration-thickness: from-font;\n}\n@mixin link-underline {\n    @include underline;\n    &:hover {\n        @include underline;\n    }\n}\n\n@mixin hover-active-state-effects($text-color: null, $text-color-change: false, $bg-color: null, $border-color: null) {\n    &:hover {\n        @if($text-color-change) {\n            color: scale_color($text-color, $lightness: -20%);\n        } @else {\n            color: $text-color;\n        }\n        @if($bg-color) {\n            background-color: scale_color($bg-color, $lightness: -20%);\n        }\n        @if($border-color) {\n            border-color: scale_color($border-color, $lightness: -20%);\n        }\n    }\n    &:active {\n        @if($text-color-change) {\n            color: scale_color($text-color, $lightness: 10%);\n        } @else {\n            color: $text-color;\n        }\n        @if($bg-color) {\n            background-color: scale_color($bg-color, $lightness: 10%);\n        }\n        @if($border-color) {\n            border-color: scale_color($border-color, $lightness: 10%);\n        }\n    }\n}\n\n// GRID\n@mixin grid($columns:1, $gap:$grid-gap--small) {\n    display: grid;\n    gap: $gap;\n    grid-template-columns: repeat($columns, minmax(0, 1fr));\n}\n@mixin grid-columns($columns:1) {\n    grid-template-columns: repeat($columns, minmax(0, 1fr));\n}\n\n@mixin full-card-link-overlay() {\n    &::after {\n      content: \"\";\n      display: block;\n      position: absolute;\n      inset: 0;\n    }\n}"],"file":"card-free.css"} */
