/*!
Baselayer 3 CSS v.1.2.5
https://github.com/SimonPadbury/baselayer
*/
@layer defaults, typography, forms-and-buttons, layout, decoration, color-setup, color-shade, color-other;
:root {
  --bgc-body: #fff;
  --tc-base: #222;
  --tc-link: #2c6aff;
  --tc-link-hover: #2559fe;
  --focus-ring: #4df5ff;
  --tc-input: #000;
  --bgc-input: #f5f5f5;
  --tc-btn: #fff;
  --tc-btn-hover: #fff;
  --bgc-btn: #898989;
  --bgc-btn-hover: #707070;
  --tc-code: #000;
  --bgc-code: #4df5ff;
  --bgc-highlight: #ffcc0066;
  --bc-fineline: #d9d9d9;
  --tx: #222;
  --bx: #aaa;
  --bgx: #ddd;
  --tc-base: oklch(var(--l900) var(--c0) var(--gray));
  --tc-link: oklch(var(--l600) var(--c30) var(--blue));
  --tc-link-hover: oklch(var(--l800) var(--c30) var(--blue));
  --focus-ring: oklch(var(--l200) var(--c30) var(--blue));
  --bgc-input: oklch(var(--l100) var(--c0) var(--gray));
  --bgc-btn: oklch(var(--l600) var(--c0) var(--gray));
  --bgc-btn-hover: oklch(var(--l700) var(--c0) var(--gray));
  --bgc-code: oklch(var(--l100) var(--c10) var(--blue));
  --bc-fineline: oklch(var(--l200) var(--c0) var(--gray)) ;
}

* {
  --l100: 97%;
  --l200: 88.5%;
  --l300: 80%;
  --l400: 71.5%;
  --l500: 63%;
  --l600: 54.5%;
  --l700: 46%;
  --l800: 37.5%;
  --l900: 29%;
  --l1000: 20.5%;
  --c0: 0;
  --c02: 0.02;
  --c04: 0.04;
  --c06: 0.06;
  --c08: 0.08;
  --c10: 0.10;
  --c15: 0.15;
  --c20: 0.20;
  --c25: 0.25;
  --c30: 0.3;
  --gray: 0;
  --red: 30;
  --orange: 90;
  --green: 155;
  --blue: 265;
  --tx: oklch(var(--tl) var(--tc) var(--th));
  --bx: oklch(var(--bl) var(--bc) var(--bh));
  --bgx: oklch(var(--bgl) var(--bgc) var(--bgh)) ;
}

.theme-dark,
.theme-dark * {
  --l100: 85%;
  --l200: 77.5%;
  --l300: 70%;
  --l400: 62.5%;
  --l500: 55%;
  --l600: 47.5%;
  --l700: 40%;
  --l800: 32.5%;
  --l900: 25%;
  --l1000: 18% ;
}

.theme-dark {
  --bgc-body: oklch(var(--l1000) var(--c0) var(--gray));
  --tc-base: oklch(var(--l100) var(--c0) var(--gray));
  --tc-link: oklch(var(--l300) var(--c30) var(--blue));
  --tc-link-hover: oklch(var(--l400) var(--c30) var(--blue));
  --tc-input: #fff;
  --bgc-input: oklch(var(--l800) var(--c0) var(--gray));
  --tc-code: #fff;
  --bgc-code: oklch(var(--l800) var(--c30) var(--blue));
  --bc-fineline: oklch(var(--l600) var(--c0) var(--gray)) ;
}

:root {
  --t-sans-serif: ui-sans-serif, system-ui, sans-serif;
  --t-serif: ui-serif, Georgia, Cambria, "Times New Roman", Times, serif;
  --t-mono: ui-monospace, Menlo, Consolas, "Courier New", monospace;
  --t-old-serif: "Iowan Old Style", "Palatino Linotype", Palatino, Georgia, serif;
  --t-base: var(--t-sans-serif);
  --t-prose: var(--t-serif);
  --fs-base: 100%;
  --lh-base: 1.5;
  --m-lh: calc(var(--lh-base)*1rem);
  --fw-lighter: 200;
  --fw-normal: 400;
  --fw-semibold: 500;
  --fw-bold: 700;
  --fw-heavy: 900;
  --w-xs: 320px;
  --w-sm: 640px;
  --w-md: 960px;
  --w-lg: 1280px;
  --w-xl: 1600px;
  --w-cg: 40em;
  --w-expand: 8.5em;
  --sp-1: 0.5rem;
  --sp-2: clamp(1rem, 0.5rem + 1.25vw, 1.5rem);
  --sp-3: clamp(2rem, 1rem + 2.5vw, 3rem);
  --sp-4: clamp(3rem, 1.5rem + 3.75vw, 4.5rem);
  --p-cell: var(--sp-1) calc(var(--sp-1)*2);
  --sp-list: 0.75em;
  --h1: 2.441em;
  --h2: 1.953em;
  --h3: 1.563em;
  --h4: 1.25em;
  --h5: 1em;
  --h6: .8em;
  --h-font: inherit;
  --h-fw: var(--fw-bold);
  --h-lh: calc(1em + 0.5rem);
  --fs-long-read: clamp(1rem, 0.625rem + 0.9375vw, 1.375rem);
  --do-link: .3rem;
  --dt-link: 1px;
  --h-input: 2.5em;
  --fw-btn: var(--fw-semibold);
  --b-1: 1px solid var(--bc-fineline);
  --b-2: 4px solid var(--bc-fineline);
  --b-3: 8px solid var(--bc-fineline);
  --r-2: 4px;
  --r-3: 8px;
  --r-4: 16px ;
}

.container {
  --sp-2: clamp(1rem, 0.5rem + 1.25cqi, 1.5rem);
  --sp-3: clamp(2rem, 1rem + 2.5cqi, 3rem);
  --sp-4: clamp(3rem, 1.5rem + 3.75cqi, 4.5rem);
  --fs-long-read: clamp(1rem, 0.625rem + 0.9375cqi, 1.375rem) ;
}

@custom-media --max-sm (max-width: 639px);
@custom-media --min-sm (min-width: 649px);
@custom-media --max-md (max-width: 959px);
@custom-media --min-md (min-width: 960px);
@custom-media --max-lg (max-width: 1279px);
@custom-media --min-lg (min-width: 1280px);
@layer defaults {
  html {
    -moz-text-size-adjust: none;
    -webkit-text-size-adjust: none;
    text-size-adjust: none;
    box-sizing: border-box;
  }
  *,
  :after,
  :before {
    box-sizing: inherit;
  }
  body {
    -webkit-font-smoothing: antialiased;
    font-size: var(--fs-base);
    line-height: var(--lh-base);
    margin: 0;
    min-height: 100dvh;
    text-rendering: optimizeLegibility;
  }
  canvas,
  img,
  picture,
  video {
    display: block;
    max-width: 100%;
  }
  iframe {
    border: 0;
  }
  summary {
    cursor: pointer;
  }
  :target {
    scroll-margin-block: 5ex;
  }
  body {
    background-color: var(--bgc-body);
    color: var(--tc-base);
    font-family: var(--t-base);
  }
}
@layer defaults {
  :focus-visible {
    box-shadow: 0 0 0 2px #fff;
    outline: 2px dotted #000;
  }
  .visually-hidden:not(:focus):not(:active) {
    clip: rect(0 0 0 0);
    -webkit-clip-path: inset(50%);
    clip-path: inset(50%);
    height: 1px;
    overflow: hidden;
    position: absolute;
    white-space: nowrap;
    width: 1px;
  }
}
@layer typography {
  blockquote,
  dl,
  fieldset,
  figcaption,
  figure,
  ol,
  p,
  pre,
  table,
  ul {
    text-wrap: pretty;
    margin-block: 0 var(--m-lh);
  }
  caption {
    margin-block: var(--sp-1);
  }
  .h1,
  h1 {
    font-size: var(--h1);
    font-weight: var(--h-fw);
    line-height: var(--h-lh);
    margin-block: 0 var(--m-lh);
  }
  .h2,
  h2 {
    font-size: var(--h2);
  }
  .h3,
  h3 {
    font-size: var(--h3);
  }
  .h4,
  h4 {
    font-size: var(--h4);
  }
  .h5,
  h5 {
    font-size: var(--h5);
  }
  .h6,
  h6 {
    font-size: var(--h6);
  }
  .h2,
  .h3,
  .h4,
  .h5,
  .h6,
  h2,
  h3,
  h4,
  h5,
  h6 {
    text-wrap: balance;
    font-weight: var(--h-fw);
    line-height: var(--h-lh);
    margin-block: var(--h-lh) var(--m-lh);
  }
  .content-grid > .h2,
  .content-grid > .h3,
  .content-grid > .h4,
  .content-grid > .h5,
  .content-grid > .h6,
  .content-grid > h2,
  .content-grid > h3,
  .content-grid > h4,
  .content-grid > h5,
  .content-grid > h6 {
    margin-block: calc(var(--h-lh) - var(--m-lh)) var(--m-lh);
  }
  a {
    color: var(--tc-link);
    cursor: pointer;
    text-decoration: underline;
    transition: all 0.15s ease;
  }
  a,
  a * {
    text-decoration-skip-ink: auto;
    text-decoration-thickness: var(--dt-link);
    text-underline-offset: var(--do-link);
  }
  a:focus,
  a:hover {
    color: var(--tc-link-hover);
  }
  ol,
  ul {
    margin-block: 0 var(--m-lh);
    padding-left: 1.5em;
  }
  li ol,
  li ul,
  li + li {
    margin-block: var(--sp-list) 0;
  }
  dl {
    margin: 0 0 var(--m-lh);
  }
  dt {
    font-weight: 700;
  }
  dd {
    margin: 0 0 var(--sp-list);
    padding-left: 1.5em;
  }
  ol ol {
    list-style-type: lower-alpha;
  }
  ol ol ol {
    list-style-type: lower-roman;
  }
  .table {
    border-collapse: collapse;
    border-spacing: 0;
    width: 100%;
  }
  .table td,
  .table th {
    border: var(--b-1);
    padding: var(--p-cell);
    text-align: left;
    vertical-align: top;
  }
  .table th {
    font-weight: 700;
  }
  hr {
    border: 0;
    border-top: var(--b-1);
    height: 0;
    margin-block: 3rem;
    width: 100%;
  }
  blockquote {
    margin-inline: 0;
    padding-inline: var(--sp-3);
  }
  blockquote p:last-child {
    margin-bottom: 0;
  }
  code,
  kbd,
  samp {
    font-family: var(--t-mono);
    font-style: normal;
    font-weight: 400;
  }
  code {
    background: var(--bgc-code);
    color: var(--tc-code);
    display: inline-block;
    padding-inline: 0.25em;
  }
  pre {
    font-style: normal;
    font-weight: 400;
  }
  pre,
  pre code {
    overflow-x: auto;
  }
  pre code {
    background: var(--bgc-code);
    display: block;
    padding: 1em;
  }
  sub,
  sup {
    font-size: 85%;
    line-height: 0;
  }
  .unlist,
  .unlist li {
    list-style-type: none;
    margin: 0;
    padding: 0;
  }
  .t-noline,
  nav a {
    text-decoration: none;
  }
  .hover\:t-line:hover {
    text-decoration: underline;
    text-decoration-skip-ink: auto;
    text-decoration-thickness: var(--dt-link);
    text-underline-offset: var(--do-link);
  }
  .t-nowrap {
    white-space: nowrap;
  }
  .t-big {
    font-size: 150% !important;
  }
  .t-small,
  small {
    font-size: 75% !important;
  }
  .t-lighter {
    font-weight: var(--fw-lighter);
  }
  .t-normal {
    font-weight: var(--fw-normal);
  }
  .t-semibold {
    font-weight: var(--fw-semibold);
  }
  .t-bold {
    font-weight: var(--fw-bold);
  }
  .t-heavy {
    font-weight: var(--fw-heavy);
  }
  .t-italic {
    font-style: italic;
  }
  .t-right {
    text-align: right;
  }
  .t-center {
    text-align: center;
  }
  .t-left {
    text-align: left;
  }
  .t-uppercase {
    text-transform: uppercase;
  }
  .t-highlight,
  mark {
    background: var(--bgc-highlight);
    color: currentColor;
  }
  .t-long-read {
    font-size: var(--fs-long-read);
  }
  .t-base {
    font-family: var(--t-base);
  }
  .t-prose {
    font-family: var(--t-prose);
  }
  fieldset {
    border: var(--b-1);
  }
  label,
  legend {
    font-family: var(--t-base);
  }
  ::placeholder {
    color: var(--tc-input);
    opacity: 0.7;
  }
  input,
  select,
  textarea {
    background: var(--bgc-input);
    border: 0;
    border-radius: unset;
    color: var(--tc-input);
    font-family: var(--t-base);
    font-size: inherit;
    min-height: var(--mh-input);
    outline: 0 none;
    padding: var(--p-cell);
    text-align: start;
  }
  input:focus,
  select:focus,
  textarea:focus {
    box-shadow: 0 0 0 4px var(--focus-ring);
    outline: 0;
    position: relative;
    z-index: 1;
  }
  [type=color],
  select:not([multiple]) {
    height: var(--mh-input);
  }
  [type=color] {
    padding: 0.25em;
    width: var(--mh-input);
  }
  [type=checkbox],
  [type=radio] {
    display: inline;
    height: 0.85em;
    min-height: unset;
    width: 1em;
  }
  [type=search] {
    -webkit-appearance: textfield;
  }
  ::file-selector-button {
    background: var(--bgc-btn);
    border: 0;
    color: #fff;
    font-size: 1em;
  }
  :disabled:hover {
    cursor: not-allowed;
  }
  textarea:not([rows]) {
    min-height: 6em;
  }
  .btn,
  [type=button],
  [type=reset],
  [type=submit],
  button {
    align-items: center;
    -webkit-appearance: none;
    appearance: none;
    background: var(--bgc-btn);
    border: 1px solid transparent;
    color: var(--tc-btn);
    display: inline-flex;
    font-family: var(--t-base);
    font-size: inherit;
    font-weight: var(--fw-btn);
    height: var(--h-input);
    justify-content: center;
    margin: 0;
    padding: var(--sp-1) 1em;
    position: relative;
    text-decoration: none;
    transition: all 0.15s ease;
  }
  .btn:active,
  .btn:hover,
  [type=button]:active,
  [type=button]:hover,
  [type=reset]:active,
  [type=reset]:hover,
  [type=submit]:active,
  [type=submit]:hover,
  button:active,
  button:hover {
    background: var(--bgc-btn-hover);
    color: var(--tc-btn-hover);
    cursor: pointer;
  }
  [type=button]:focus-visible,
  [type=reset]:focus-visible,
  [type=submit]:focus-visible,
  button:focus-visible {
    box-shadow: 0 0 0 4px var(--focus-ring);
    outline: 0;
    z-index: 1;
  }
  .btn-icon {
    height: var(--mh-input);
    line-height: inherit;
    padding: 0;
    width: var(--mh-input);
  }
}
@layer forms-and-buttons {
  fieldset {
    border: var(--b-1);
  }
  label,
  legend {
    font-family: var(--t-base);
  }
  ::placeholder {
    color: var(--tc-input);
    opacity: 0.7;
  }
  input,
  select,
  textarea {
    background: var(--bgc-input);
    border: 0;
    border-radius: unset;
    color: var(--tc-input);
    font-family: var(--t-base);
    font-size: inherit;
    min-height: var(--mh-input);
    outline: 0 none;
    padding: var(--p-cell);
    text-align: start;
  }
  input:focus,
  select:focus,
  textarea:focus {
    box-shadow: 0 0 0 4px var(--focus-ring);
    outline: 0;
    position: relative;
    z-index: 1;
  }
  [type=color],
  select:not([multiple]) {
    height: var(--mh-input);
  }
  [type=color] {
    padding: 0.25em;
    width: var(--mh-input);
  }
  [type=checkbox],
  [type=radio] {
    display: inline;
    height: 0.85em;
    min-height: unset;
    width: 1em;
  }
  [type=search] {
    -webkit-appearance: textfield;
  }
  ::file-selector-button {
    background: var(--bgc-btn);
    border: 0;
    color: #fff;
    font-size: 1em;
  }
  :disabled:hover {
    cursor: not-allowed;
  }
  textarea:not([rows]) {
    min-height: 6em;
  }
  .btn,
  [type=button],
  [type=reset],
  [type=submit],
  button {
    align-items: center;
    -webkit-appearance: none;
    appearance: none;
    background: var(--bgc-btn);
    border: 1px solid transparent;
    color: var(--tc-btn);
    display: inline-flex;
    font-family: var(--t-base);
    font-size: inherit;
    font-weight: var(--fw-btn);
    height: var(--h-input);
    justify-content: center;
    margin: 0;
    padding: var(--sp-1) 1em;
    position: relative;
    text-decoration: none;
    transition: all 0.15s ease;
  }
  .btn:active,
  .btn:hover,
  [type=button]:active,
  [type=button]:hover,
  [type=reset]:active,
  [type=reset]:hover,
  [type=submit]:active,
  [type=submit]:hover,
  button:active,
  button:hover {
    background: var(--bgc-btn-hover);
    color: var(--tc-btn-hover);
    cursor: pointer;
  }
  [type=button]:focus-visible,
  [type=reset]:focus-visible,
  [type=submit]:focus-visible,
  button:focus-visible {
    box-shadow: 0 0 0 4px var(--focus-ring);
    outline: 0;
    z-index: 1;
  }
  .btn-icon {
    height: var(--mh-input);
    line-height: inherit;
    padding: 0;
    width: var(--mh-input);
  }
}
@layer layout {
  .container {
    container-type: inline-size;
  }
  .relative {
    position: relative;
  }
  .absolute {
    position: absolute;
  }
  .fixed {
    position: fixed;
  }
  .sticky {
    position: sticky;
  }
  .top {
    top: 0;
  }
  .right {
    right: 0;
  }
  .bottom {
    bottom: 0;
  }
  .left {
    left: 0;
  }
  .z-1 {
    z-index: 1;
  }
  .z-2 {
    z-index: 2;
  }
  .z-3 {
    z-index: 3;
  }
  .float-right {
    float: right;
  }
  .float-left {
    float: left;
  }
  .clearfix:after {
    clear: both;
    content: "";
    display: table;
  }
  .overflow-x {
    overflow-x: auto;
  }
  .overflow-y {
    overflow-y: auto;
  }
  .overflow-hidden {
    overflow: hidden;
  }
  .block {
    display: block;
  }
  .inline-block {
    display: inline-block;
  }
  .inline-flex {
    display: inline-flex;
  }
  .flex {
    display: flex;
  }
  .flex-wrap {
    flex-wrap: wrap;
  }
  .flex-column {
    flex-direction: column;
  }
  .flex-start {
    justify-content: flex-start;
  }
  .flex-center {
    justify-content: center;
  }
  .flex-end {
    justify-content: flex-end;
  }
  .flex-top {
    align-items: flex-start;
  }
  .flex-middle {
    align-items: center;
  }
  .flex-bottom {
    align-items: flex-end;
  }
  .flex-space-between {
    justify-content: space-between;
  }
  .flex-grow-equal > * {
    flex: 1;
  }
  .flex-grow-auto > * {
    flex: auto;
  }
  .grow {
    flex-grow: 1;
  }
  @container (max-width: 639px) {
    .sm\:hidden-below {
      display: none !important;
    }
  }
  @container (max-width: 959px) {
    .md\:hidden-below {
      display: none !important;
    }
  }
  @container (max-width: 1279px) {
    .lg\:hidden-below {
      display: none !important;
    }
  }
  .grid {
    display: grid;
  }
  .grid-dense {
    grid-auto-flow: dense;
  }
  [class*=equal-] {
    grid-template-columns: repeat(var(--cols), minmax(1rem, 1fr));
  }
  [class*=col-1],
  [class*=col-2],
  [class*=col-3],
  [class*=col-4] {
    grid-column: var(--col);
  }
  [class*=row-1],
  [class*=row-2],
  [class*=row-3],
  [class*=row-4] {
    grid-row: var(--row);
  }
  [class*=col-span-] {
    --col: auto;
    grid-column: var(--col)/span var(--cspan);
  }
  [class*=row-span-] {
    --row: auto;
    grid-row: var(--row)/span var(--rspan);
  }
  .equal-2-cols {
    --cols: 2 ;
  }
  .equal-3-cols {
    --cols: 3 ;
  }
  .equal-4-cols {
    --cols: 4 ;
  }
  .col-1 {
    --col: 1 ;
  }
  .col-2 {
    --col: 2 ;
  }
  .col-3 {
    --col: 3 ;
  }
  .col-4 {
    --col: 4 ;
  }
  .col-span-1 {
    --cspan: 1 ;
  }
  .col-span-2 {
    --cspan: 2 ;
  }
  .col-span-3 {
    --cspan: 3 ;
  }
  .col-span-4 {
    --cspan: 4 ;
  }
  .row-1 {
    --row: 1 ;
  }
  .row-2 {
    --row: 2 ;
  }
  .row-3 {
    --row: 3 ;
  }
  .row-4 {
    --row: 4 ;
  }
  .row-span-1 {
    --rspan: 1 ;
  }
  .row-span-2 {
    --rspan: 2 ;
  }
  .row-span-3 {
    --rspan: 3 ;
  }
  .row-span-4 {
    --rspan: 4 ;
  }
  @container (min-width: 640px) {
    .sm\:flex {
      display: flex;
    }
    .sm\:hidden {
      display: none !important;
    }
    .sm\:equal-2-cols {
      --cols: 2 ;
    }
    .sm\:equal-3-cols {
      --cols: 3 ;
    }
    .sm\:equal-4-cols {
      --cols: 4 ;
    }
    .sm\:col-1 {
      --col: 1 ;
    }
    .sm\:col-2 {
      --col: 2 ;
    }
    .sm\:col-3 {
      --col: 3 ;
    }
    .sm\:col-4 {
      --col: 4 ;
    }
    .sm\:col-span-1 {
      --cspan: 1 ;
    }
    .sm\:col-span-2 {
      --cspan: 2 ;
    }
    .sm\:col-span-3 {
      --cspan: 3 ;
    }
    .sm\:col-span-4 {
      --cspan: 4 ;
    }
    .sm\:row-1 {
      --row: 1 ;
    }
    .sm\:row-2 {
      --row: 2 ;
    }
    .sm\:row-3 {
      --row: 3 ;
    }
    .sm\:row-4 {
      --row: 4 ;
    }
    .sm\:row-span-1 {
      --rspan: 1 ;
    }
    .sm\:row-span-2 {
      --rspan: 2 ;
    }
    .sm\:row-span-3 {
      --rspan: 3 ;
    }
    .sm\:row-span-4 {
      --rspan: 4 ;
    }
  }
  @container (min-width: 960px) {
    .md\:flex {
      display: flex;
    }
    .md\:hidden {
      display: none !important;
    }
    .md\:equal-2-cols {
      --cols: 2 ;
    }
    .md\:equal-3-cols {
      --cols: 3 ;
    }
    .md\:equal-4-cols {
      --cols: 4 ;
    }
    .md\:col-1 {
      --col: 1 ;
    }
    .md\:col-2 {
      --col: 2 ;
    }
    .md\:col-3 {
      --col: 3 ;
    }
    .md\:col-4 {
      --col: 4 ;
    }
    .md\:col-span-1 {
      --cspan: 1 ;
    }
    .md\:col-span-2 {
      --cspan: 2 ;
    }
    .md\:col-span-3 {
      --cspan: 3 ;
    }
    .md\:col-span-4 {
      --cspan: 4 ;
    }
    .md\:row-1 {
      --row: 1 ;
    }
    .md\:row-2 {
      --row: 2 ;
    }
    .md\:row-3 {
      --row: 3 ;
    }
    .md\:row-4 {
      --row: 4 ;
    }
    .md\:row-span-1 {
      --rspan: 1 ;
    }
    .md\:row-span-2 {
      --rspan: 2 ;
    }
    .md\:row-span-3 {
      --rspan: 3 ;
    }
    .md\:row-span-4 {
      --rspan: 4 ;
    }
  }
  @container (min-width: 1280px) {
    .lg\:flex {
      display: flex;
    }
    .sm\:hidden {
      display: none !important;
    }
    .lg\:equal-2-cols {
      --cols: 2 ;
    }
    .lg\:equal-3-cols {
      --cols: 3 ;
    }
    .lg\:equal-4-cols {
      --cols: 4 ;
    }
    .lg\:col-1 {
      --col: 1 ;
    }
    .lg\:col-2 {
      --col: 2 ;
    }
    .lg\:col-3 {
      --col: 3 ;
    }
    .lg\:col-4 {
      --col: 4 ;
    }
    .lg\:col-span-1 {
      --cspan: 1 ;
    }
    .lg\:col-span-2 {
      --cspan: 2 ;
    }
    .lg\:col-span-3 {
      --cspan: 3 ;
    }
    .lg\:col-span-4 {
      --cspan: 4 ;
    }
    .lg\:row-1 {
      --row: 1 ;
    }
    .lg\:row-2 {
      --row: 2 ;
    }
    .lg\:row-3 {
      --row: 3 ;
    }
    .lg\:row-4 {
      --row: 4 ;
    }
    .lg\:row-span-1 {
      --rspan: 1 ;
    }
    .lg\:row-span-2 {
      --rspan: 2 ;
    }
    .lg\:row-span-3 {
      --rspan: 3 ;
    }
    .lg\:row-span-4 {
      --rspan: 4 ;
    }
  }
  .gap-1 {
    --gap: var(--sp-1) ;
  }
  .gap-1,
  .gap-2 {
    gap: var(--gap) !important;
  }
  .gap-2 {
    --gap: var(--sp-2) ;
  }
  .gap-3 {
    --gap: var(--sp-3) ;
  }
  .gap-3,
  .gap-4 {
    gap: var(--gap) !important;
  }
  .gap-4 {
    --gap: var(--sp-4) ;
  }
  .content-grid {
    --full: minmax(var(--sp-2), 1fr);
    --expand: minmax(0, var(--w-expand));
    --pop: minmax(0, var(--sp-2));
    --content: min(var(--w-cg), 100% - (var(--sp-2) * 2));
    display: grid;
    grid-template-columns: [full-start] var(--full) [expand-start] var(--expand) [popout-start] var(--pop) [content-start] var(--content) [content-end] var(--pop) [popout-end] var(--expand) [expand-end] var(--full) [full-end];
  }
  .content-grid > * {
    grid-column: content;
  }
  .popout {
    grid-column: popout;
  }
  .expand {
    grid-column: expand;
  }
  .full-bleed {
    grid-column: full;
  }
  .content-grid > hr + * {
    margin-top: 0;
  }
  .wrapper,
  [class^=wrapper-] {
    --w-max: var(--w-xl);
    --sp-inline: var(--sp-2);
    margin-inline: auto;
    width: min(100% - var(--sp-inline) * 2, var(--w-max));
  }
  .w-lg,
  .w-md,
  .w-sm,
  .w-xl,
  .w-xs {
    width: min(100%, var(--w-max));
  }
  .w-xs,
  .wrapper-xs {
    --w-max: var(--w-xs) ;
  }
  .w-sm,
  .wrapper-sm {
    --w-max: var(--w-sm) ;
  }
  .w-md,
  .wrapper-md {
    --w-max: var(--w-md) ;
  }
  .w-lg,
  .wrapper-lg {
    --w-max: var(--w-lg) ;
  }
  .w-xl,
  .wrapper-xl {
    --w-max: var(--w-xl) ;
  }
  .w-100\% {
    width: 100%;
  }
  .w-100vw {
    width: 100vw;
  }
  .w-max-100vw {
    max-width: 100vw;
  }
  .h-100\% {
    height: 100%;
  }
  .h-100dvh {
    height: 100dvh;
  }
  .h-max-100dvh {
    max-height: 100dvh;
  }
  .box {
    inset: 0;
  }
  .aspect-ratio-16x9 {
    aspect-ratio: 16/9;
  }
  .aspect-ratio-21x9 {
    aspect-ratio: 21/9;
  }
  .aspect-ratio-1x1 {
    aspect-ratio: 1/1;
  }
  .aspect-ratio-4x3 {
    aspect-ratio: 4/3;
  }
}
@layer decoration {
  .mx-auto {
    margin-inline: auto;
  }
  .m-0 {
    margin: 0;
  }
  .m-1 {
    margin: var(--sp-1);
  }
  .m-2 {
    margin: var(--sp-2);
  }
  .m-3 {
    margin: var(--sp-3);
  }
  .m-4 {
    margin: var(--sp-4);
  }
  .mt-0 {
    margin-top: 0;
  }
  .mt-1 {
    margin-top: var(--sp-1);
  }
  .mt-2 {
    margin-top: var(--sp-2);
  }
  .mt-3 {
    margin-top: var(--sp-3);
  }
  .mt-4 {
    margin-top: var(--sp-4);
  }
  .mr-0 {
    margin-right: 0;
  }
  .mr-1 {
    margin-right: var(--sp-1);
  }
  .mr-2 {
    margin-right: var(--sp-2);
  }
  .mr-3 {
    margin-right: var(--sp-3);
  }
  .mr-4 {
    margin-right: var(--sp-4);
  }
  .mb-0,
  .mb-1 {
    margin-bottom: var(--sp-1);
  }
  .mb-2 {
    margin-bottom: var(--sp-2);
  }
  .mb-3 {
    margin-bottom: var(--sp-3);
  }
  .mb-4 {
    margin-bottom: var(--sp-4);
  }
  .ml-0 {
    margin-left: 0;
  }
  .ml-1 {
    margin-left: var(--sp-1);
  }
  .ml-2 {
    margin-left: var(--sp-2);
  }
  .ml-3 {
    margin-left: var(--sp-3);
  }
  .ml-4 {
    margin-left: var(--sp-4);
  }
  .mx-1 {
    margin-inline: var(--sp-1);
  }
  .mx-2 {
    margin-inline: var(--sp-2);
  }
  .mx-3 {
    margin-inline: var(--sp-3);
  }
  .mx-4 {
    margin-inline: var(--sp-4);
  }
  .my-1 {
    margin-block: var(--sp-1);
  }
  .my-2 {
    margin-block: var(--sp-2);
  }
  .my-3 {
    margin-block: var(--sp-3);
  }
  .my-4 {
    margin-block: var(--sp-4);
  }
  .p-cell {
    padding: var(--p-cell);
  }
  .p-0 {
    padding: 0;
  }
  .p-1 {
    padding: var(--sp-1);
  }
  .p-2 {
    padding: var(--sp-2);
  }
  .p-3 {
    padding: var(--sp-3);
  }
  .p-4 {
    padding: var(--sp-4);
  }
  .pt-0 {
    padding-top: 0;
  }
  .pt-1 {
    padding-top: var(--sp-1);
  }
  .pt-2 {
    padding-top: var(--sp-2);
  }
  .pt-3 {
    padding-top: var(--sp-3);
  }
  .pt-4 {
    padding-top: var(--sp-4);
  }
  .pr-0 {
    padding-right: 0;
  }
  .pr-1 {
    padding-right: var(--sp-1);
  }
  .pr-2 {
    padding-right: var(--sp-2);
  }
  .pr-3 {
    padding-right: var(--sp-3);
  }
  .pr-4 {
    padding-right: var(--sp-4);
  }
  .pb-0 {
    padding-bottom: 0;
  }
  .pb-1 {
    padding-bottom: var(--sp-1);
  }
  .pb-2 {
    padding-bottom: var(--sp-2);
  }
  .pb-3 {
    padding-bottom: var(--sp-3);
  }
  .pb-4 {
    padding-bottom: var(--sp-4);
  }
  .pl-0 {
    padding-left: 0;
  }
  .pl-1 {
    padding-left: var(--sp-1);
  }
  .pl-2 {
    padding-left: var(--sp-2);
  }
  .pl-3 {
    padding-left: var(--sp-3);
  }
  .pl-4 {
    padding-left: var(--sp-4);
  }
  .px-1 {
    padding-inline: var(--sp-1);
  }
  .px-2 {
    padding-inline: var(--sp-2);
  }
  .px-3 {
    padding-inline: var(--sp-3);
  }
  .px-4 {
    padding-inline: var(--sp-4);
  }
  .py-1 {
    padding-block: var(--sp-1);
  }
  .py-2 {
    padding-block: var(--sp-2);
  }
  .py-3 {
    padding-block: var(--sp-3);
  }
  .py-4 {
    padding-block: var(--sp-4);
  }
  .b-0 {
    border: 0;
  }
  .b-1 {
    border: var(--b-1);
  }
  .b-2 {
    border: var(--b-2);
  }
  .b-3 {
    border: var(--b-3);
  }
  .bt-1 {
    border-top: var(--b-1);
  }
  .bt-2 {
    border-top: var(--b-2);
  }
  .bt-3 {
    border-top: var(--b-3);
  }
  .br-1 {
    border-right: var(--b-1);
  }
  .br-2 {
    border-right: var(--b-2);
  }
  .br-3 {
    border-right: var(--b-3);
  }
  .bb-1 {
    border-bottom: var(--b-1);
  }
  .bb-2 {
    border-bottom: var(--b-2);
  }
  .bb-3 {
    border-bottom: var(--b-3);
  }
  .bl-1 {
    border-left: var(--b-1);
  }
  .bl-2 {
    border-left: var(--b-2);
  }
  .bl-3 {
    border-left: var(--b-3);
  }
  .r-2 {
    border-radius: var(--r-2);
  }
  .r-3 {
    border-radius: var(--r-3);
  }
  .r-4 {
    border-radius: var(--r-4);
  }
  .r-pill {
    border-radius: 99em;
  }
  .r-2,
  .r-3,
  .r-4,
  .r-pill {
    overflow: hidden;
  }
  .img-cover {
    height: 100%;
    object-fit: cover;
    object-position: center;
    width: 100%;
  }
  .hover\:opacity-25\%\:hover,
  .opacity-25\% {
    opacity: 0.25;
  }
  .hover\:opacity-50\%\:hover,
  .opacity-50\% {
    opacity: 0.5;
  }
  .hover\:opacity-75\%\:hover,
  .opacity-75\% {
    opacity: 0.75;
  }
  .hover\:opacity-100\%\:hover {
    opacity: 1;
  }
}
@layer color-setup {
  .hover\:t-gray:hover,
  .t-gray {
    --tl: var(--l500);
    --tc: var(--c0) !important;
    --th: var(--gray);
    color: var(--tx);
  }
  .b-gray,
  .hover\:b-gray:hover {
    --bl: var(--l500);
    --bc: var(--c0) !important;
    --bh: var(--gray);
    border-color: var(--bx);
  }
  .bg-gray,
  .hover\:bg-gray:hover {
    --bgl: var(--l500);
    --bgc: var(--c0) !important;
    --bgh: var(--gray);
    background: var(--bgx);
  }
  .hover\:t-red:hover,
  .t-red {
    --tl: var(--l500);
    --tc: var(--c30);
    --th: var(--red);
    color: var(--tx);
  }
  .b-red,
  .hover\:b-red:hover {
    --bl: var(--l500);
    --bc: var(--c30);
    --bh: var(--red);
    border-color: var(--bx);
  }
  .bg-red,
  .hover\:bg-red:hover {
    --bgl: var(--l500);
    --bgc: var(--c30);
    --bgh: var(--red);
    background: var(--bgx);
  }
  .hover\:t-orange:hover,
  .t-orange {
    --tl: var(--l500);
    --tc: var(--c30);
    --th: var(--orange);
    color: var(--tx);
  }
  .b-orange,
  .hover\:b-orange:hover {
    --bl: var(--l500);
    --bc: var(--c30);
    --bh: var(--orange);
    border-color: var(--bx);
  }
  .bg-orange,
  .hover\:bg-orange:hover {
    --bgl: var(--l500);
    --bgc: var(--c30);
    --bgh: var(--orange);
    background: var(--bgx);
  }
  .hover\:t-green:hover,
  .t-green {
    --tl: var(--l500);
    --tc: var(--c30);
    --th: var(--green);
    color: var(--tx);
  }
  .b-green,
  .hover\:b-green:hover {
    --bl: var(--l500);
    --bc: var(--c30);
    --bh: var(--green);
    border-color: var(--bx);
  }
  .bg-green,
  .hover\:bg-green:hover {
    --bgl: var(--l500);
    --bgc: var(--c30);
    --bgh: var(--green);
    background: var(--bgx);
  }
  .hover\:t-blue:hover,
  .t-blue {
    --tl: var(--l500);
    --tc: var(--c30);
    --th: var(--blue);
    color: var(--tx);
  }
  .b-blue,
  .hover\:b-blue:hover {
    --bl: var(--l500);
    --bc: var(--c30);
    --bh: var(--blue);
    border-color: var(--bx);
  }
  .bg-blue,
  .hover\:bg-blue:hover {
    --bgl: var(--l500);
    --bgc: var(--c30);
    --bgh: var(--blue);
    background: var(--bgx);
  }
}
@layer color-shade {
  .hover\:t-100:active,
  .hover\:t-100:hover,
  .t-100 {
    --tl: var(--l100);
    --tc: var(--c10);
    color: var(--tx);
  }
  .hover\:t-200:active,
  .hover\:t-200:hover,
  .t-200 {
    --tl: var(--l200);
    --tc: var(--c15);
    color: var(--tx);
  }
  .hover\:t-300:active,
  .hover\:t-300:hover,
  .t-300 {
    --tl: var(--l300);
    --tc: var(--c20);
    color: var(--tx);
  }
  .hover\:t-400:active,
  .hover\:t-400:hover,
  .t-400 {
    --tl: var(--l400);
    --tc: var(--c25);
    color: var(--tx);
  }
  .hover\:t-500:active,
  .hover\:t-500:hover,
  .t-500 {
    --tl: var(--l500);
    --tc: var(--c30);
    color: var(--tx);
  }
  .hover\:t-600:active,
  .hover\:t-600:hover,
  .t-600 {
    --tl: var(--l600);
    --tc: var(--c25);
    color: var(--tx);
  }
  .hover\:t-700:active,
  .hover\:t-700:hover,
  .t-700 {
    --tl: var(--l700);
    --tc: var(--c20);
    color: var(--tx);
  }
  .hover\:t-800:active,
  .hover\:t-800:hover,
  .t-800 {
    --tl: var(--l800);
    --tc: var(--c15);
    color: var(--tx);
  }
  .hover\:t-900:active,
  .hover\:t-900:hover,
  .t-900 {
    --tl: var(--l900);
    --tc: var(--c10);
    color: var(--tx);
  }
  .b-100,
  .hover\:b-100:active,
  .hover\:b-100:hover {
    --bl: var(--l100);
    --bc: var(--c10);
    border-color: var(--bx);
  }
  .b-200,
  .hover\:b-200:active,
  .hover\:b-200:hover {
    --bl: var(--l200);
    --bc: var(--c15);
    border-color: var(--bx);
  }
  .b-300,
  .hover\:b-300:active,
  .hover\:b-300:hover {
    --bl: var(--l300);
    --bc: var(--c20);
    border-color: var(--bx);
  }
  .b-400,
  .hover\:b-400:active,
  .hover\:b-400:hover {
    --bl: var(--l400);
    --bc: var(--c25);
    border-color: var(--bx);
  }
  .b-500,
  .hover\:b-500:active,
  .hover\:b-500:hover {
    --bl: var(--l500);
    --bc: var(--c30);
    border-color: var(--bx);
  }
  .b-600,
  .hover\:b-600:active,
  .hover\:b-600:hover {
    --bl: var(--l600);
    --bc: var(--c25);
    border-color: var(--bx);
  }
  .b-700,
  .hover\:b-700:active,
  .hover\:b-700:hover {
    --bl: var(--l700);
    --bc: var(--c20);
    border-color: var(--bx);
  }
  .b-800,
  .hover\:b-800:active,
  .hover\:b-800:hover {
    --bl: var(--l800);
    --bc: var(--c15);
    border-color: var(--bx);
  }
  .b-900,
  .hover\:b-900:active,
  .hover\:b-900:hover {
    --bl: var(--l900);
    --bc: var(--c10);
    border-color: var(--bx);
  }
  .bg-100,
  .hover\:bg-100:active,
  .hover\:bg-100:hover {
    --bgl: var(--l100);
    --bgc: var(--c10);
    background: var(--bgx);
  }
  .bg-200,
  .hover\:bg-200:active,
  .hover\:bg-200:hover {
    --bgl: var(--l200);
    --bgc: var(--c15);
    background: var(--bgx);
  }
  .bg-300,
  .hover\:bg-300:active,
  .hover\:bg-300:hover {
    --bgl: var(--l300);
    --bgc: var(--c20);
    background: var(--bgx);
  }
  .bg-400,
  .hover\:bg-400:active,
  .hover\:bg-400:hover {
    --bgl: var(--l400);
    --bgc: var(--c25);
    background: var(--bgx);
  }
  .bg-500,
  .hover\:bg-500:active,
  .hover\:bg-500:hover {
    --bgl: var(--l500);
    --bgc: var(--c30);
    background: var(--bgx);
  }
  .bg-600,
  .hover\:bg-600:active,
  .hover\:bg-600:hover {
    --bgl: var(--l600);
    --bgc: var(--c25);
    background: var(--bgx);
  }
  .bg-700,
  .hover\:bg-700:active,
  .hover\:bg-700:hover {
    --bgl: var(--l700);
    --bgc: var(--c20);
    background: var(--bgx);
  }
  .bg-800,
  .hover\:bg-800:active,
  .hover\:bg-800:hover {
    --bgl: var(--l800);
    --bgc: var(--c15);
    background: var(--bgx);
  }
  .bg-900,
  .hover\:bg-900:active,
  .hover\:bg-900:hover {
    --bgl: var(--l900);
    --bgc: var(--c10);
    background: var(--bgx);
  }
  .theme-dark [class*=t-100].t-dark-invert {
    --tl: var(--l900) ;
  }
  .theme-dark [class*=t-200].t-dark-invert {
    --tl: var(--l800) ;
  }
  .theme-dark [class*=t-300].t-dark-invert {
    --tl: var(--l700) ;
  }
  .theme-dark [class*=t-400].t-dark-invert {
    --tl: var(--l600) ;
  }
  .theme-dark [class*=t-600].t-dark-invert {
    --tl: var(--l400) ;
  }
  .theme-dark [class*=t-700].t-dark-invert {
    --tl: var(--l300) ;
  }
  .theme-dark [class*=t-800].t-dark-invert {
    --tl: var(--l200) ;
  }
  .theme-dark [class*=t-900].t-dark-invert {
    --tl: var(--l100) ;
  }
  .theme-dark [class*=b-100].b-dark-invert {
    --bl: var(--l900) ;
  }
  .theme-dark [class*=b-200].b-dark-invert {
    --bl: var(--l800) ;
  }
  .theme-dark [class*=b-300].b-dark-invert {
    --bl: var(--l700) ;
  }
  .theme-dark [class*=b-400].b-dark-invert {
    --bl: var(--l600) ;
  }
  .theme-dark [class*=b-600].b-dark-invert {
    --bl: var(--l400) ;
  }
  .theme-dark [class*=b-700].b-dark-invert {
    --bl: var(--l300) ;
  }
  .theme-dark [class*=b-800].b-dark-invert {
    --bl: var(--l200) ;
  }
  .theme-dark [class*=b-900].b-dark-invert {
    --bl: var(--l100) ;
  }
  .theme-dark [class*=bg-100].bg-dark-invert {
    --bgl: var(--l900) ;
  }
  .theme-dark [class*=bg-200].bg-dark-invert {
    --bgl: var(--l800) ;
  }
  .theme-dark [class*=bg-300].bg-dark-invert {
    --bgl: var(--l700) ;
  }
  .theme-dark [class*=bg-400].bg-dark-invert {
    --bgl: var(--l600) ;
  }
  .theme-dark [class*=bg-600].bg-dark-invert {
    --bgl: var(--l400) ;
  }
  .theme-dark [class*=bg-700].bg-dark-invert {
    --bgl: var(--l300) ;
  }
  .theme-dark [class*=bg-800].bg-dark-invert {
    --bgl: var(--l200) ;
  }
  .theme-dark [class*=bg-900].bg-dark-invert {
    --bgl: var(--l100) ;
  }
}
@layer color-other {
  .bg-transparent:not(:hover) {
    background: transparent;
  }
  .hover\:t-white:hover,
  .t-white {
    color: #fff;
  }
  .b-white,
  .hover\:b-white:hover {
    border-color: #fff;
  }
  .bg-white,
  .hover\:bg-white:hover {
    background: #fff;
  }
  .hover\:t-black:hover,
  .t-black {
    color: #000;
  }
  .b-black,
  .hover\:b-black:hover {
    border-color: #000;
  }
  .bg-black,
  .hover\:bg-black:hover {
    background: #000;
  }
}
:root {
  --t-sans-serif: "Poppins";
}

#header-logo {
  display: flex;
  align-items: center;
}
#header-logo img {
  max-width: 320px;
  height: auto;
}

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

.header-links {
  list-style: none;
  display: flex;
  width: 100%;
  align-items: center;
  justify-content: flex-end;
  margin: 0;
  padding: 0;
}
.header-links nav {
  display: flex;
}
.header-links a {
  background-color: #fff;
  color: #18479f;
  font-weight: 400;
  font-size: 1.2rem;
  text-decoration: none;
  border-bottom: 3px #fff solid;
}
.header-links a:hover {
  border-bottom-color: #a1d7df;
}
.header-links a.current {
  color: #18479f;
  border-bottom-color: #18479f;
}

h1 {
  color: #374556;
  position: relative;
  padding-top: 20px;
  word-wrap: break-word;
}

h2 {
  color: #374556;
}

.stretch-image {
  overflow: hidden;
}
.stretch-image picture,
.stretch-image img {
  border-radius: 10px;
  object-fit: cover;
  width: 100%;
  height: 100%;
}

.raise-image {
  max-height: 12rem;
  overflow: hidden;
  border-radius: 10px;
  margin-bottom: 2rem;
  display: none;
}
.raise-image picture,
.raise-image img {
  object-fit: cover;
  width: 100%;
  height: 100%;
}

@media screen and (max-width: 425px) {
  .raise-image {
    display: block;
  }
  .avainlippu {
    text-align: center;
    margin-bottom: 0;
  }
  .avainlippu img {
    display: inline-block;
  }
}
.contact-details {
  display: flex;
  flex-wrap: wrap;
}
.contact-details div {
  flex-basis: 33.3333333333%;
  padding: 1em;
}
.contact-details div h3 {
  color: #18479f;
  padding-top: 0.5em;
  margin-top: 0;
  border-top: 1px #a1d7df solid;
}
.contact-details div h4 {
  color: #374556;
}
.contact-details div a {
  color: #18479f;
}

.contact-details.half div {
  flex-basis: 50%;
}

ul.values-showcase {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  align-items: start;
}
ul.values-showcase li {
  flex-basis: 50%;
  margin: 0;
}
ul.values-showcase img {
  max-width: 128px;
  margin: 0px auto;
}
ul.values-showcase h3 {
  font-size: 1.4em;
  text-align: center;
  color: #18479f;
}
ul.values-showcase p {
  font-size: 0.9em;
  text-align: center;
}

#main-footer {
  background-image: url(/assets/images/footer-background.svg);
  background-size: cover;
  background-position: center;
  color: #18479f;
}
#main-footer .wrapper-lg {
  display: flex;
  align-items: center;
}
#main-footer .wrapper-lg .col {
  flex: 1;
  flex-shrink: 0;
  flex-grow: auto;
}
#main-footer .wrapper-lg .col-wide {
  flex-grow: 0;
}
#main-footer nav ul {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  align-items: flex-end;
  justify-content: flex-end;
  flex-wrap: wrap;
}
#main-footer nav ul li {
  padding: 0 1em;
  margin: 0;
}
#main-footer nav ul li a {
  color: #18479f;
}
#main-footer nav ul li a:hover {
  text-decoration: underline;
}

@media screen and (max-width: 768px) {
  #header-logo img {
    max-width: 240px;
  }
  #header .header-nav .header-links a {
    font-size: 1em;
  }
  .stretch-image {
    display: none;
  }
  #main-footer .col-wide {
    display: none;
  }
}
@media screen and (max-width: 640px) {
  #header {
    display: block !important;
  }
  #header .header-links {
    flex-direction: column;
    align-items: start;
  }
  #header .header-links li {
    margin-inline: 0;
  }
  .stretch-image {
    display: none;
  }
  ul.values-showcase li {
    flex-basis: 100%;
    margin: 0;
  }
  ul.values-showcase h3 {
    font-size: 1.2em;
  }
  ul.values-showcase img {
    max-width: 64px;
  }
  #main-footer .wrapper-lg {
    display: block;
  }
  #main-footer .wrapper-lg .col {
    padding: 1em 0;
    text-align: center;
  }
  #main-footer .wrapper-lg nav ul {
    justify-content: center;
  }
  .flags {
    justify-content: center;
    align-items: center;
  }
}
.flags {
  display: flex;
  align-items: center;
}

/*# sourceMappingURL=styles.css.map */