@charset "UTF-8";@font-face{font-family:open sans;font-weight:400;font-style:normal;src:url(OpenSans-Regular-webfont.woff)format('woff');font-display:swap}@font-face{font-family:open sans;font-weight:600;font-style:normal;src:url(OpenSans-Semibold-webfont.woff)format('woff');font-display:swap}@font-face{font-family:open sans;font-weight:400;font-style:italic;src:local('Open Sans Italic'),local('OpenSans-Italic'),url(OpenSans-Italic-webfont.woff)format('woff');font-display:swap}@font-face{font-family:open sans;font-weight:600;font-style:italic;src:local('Open Sans Semibold Italic'),local('OpenSans-SemiboldItalic'),url(OpenSans-SemiboldItalic-webfont.woff)format('woff');font-display:swap}@font-face{font-family:montserrat;font-style:normal;font-weight:700;src:url(Montserrat-Bold.woff2)format('woff2');font-display:swap} :root { --navy: #1A365D; --navy-700:#142a49; --navy-300:#2c4f86; --brass: #D4AF37; --brass-700:#a9842a; --brass-ink:#7e6320; --cyan: #0FF0FC; --ink: #16202e; --body: #41505f; --muted: #586673; --bg: #f3f6fa; --surface: #ffffff; --surface-2:#eef2f8; --border: #e2e8f1; --border-strong:#cdd7e5; --link: var(--navy); --link-hover: var(--navy-700); --accent: var(--brass); --shadow-1: 0 1px 2px rgba(16,24,40,.06), 0 1px 3px rgba(16,24,40,.10); --shadow-2: 0 6px 14px rgba(16,24,40,.08), 0 12px 28px rgba(16,24,40,.10); --shadow-bar: 0 1px 0 rgba(16,24,40,.05), 0 2px 8px rgba(16,24,40,.08); --radius: 12px; --radius-sm: 8px; --maxw: 74rem; --measure: 44rem; --pad: clamp(1rem, 4vw, 2rem); } @media (prefers-color-scheme: dark) { :root { --ink:#f3f6fb; --body:#aeb9c8; --muted:#8593a6; --bg:#0e1622; --surface:#161f2e; --surface-2:#1c2738; --border:#26334a; --border-strong:#32425e; --link:var(--cyan); --link-hover:#7ff6fb; --shadow-1: 0 1px 2px rgba(0,0,0,.35); --shadow-2: 0 8px 24px rgba(0,0,0,.45); --shadow-bar: 0 2px 10px rgba(0,0,0,.5); } } *, *::before, *::after { box-sizing: border-box; } html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; } body { margin: 0; min-height: 100vh; display: flex; flex-direction: column; background: var(--bg); color: var(--body); font-family: "Open Sans", system-ui, sans-serif; font-size: 17px; line-height: 1.65; -webkit-font-smoothing: antialiased; } main { flex: 1 0 auto; } h1, h2, h3, h4 { font-family: "Montserrat", system-ui, sans-serif; font-weight: 700; color: var(--ink); line-height: 1.18; letter-spacing: -0.01em; } p { margin: 0 0 1rem; } a { color: var(--link); text-decoration: none; transition: color .15s ease; } a:hover { color: var(--link-hover); text-decoration: underline; } ::selection { color: #fff; background: var(--navy-300); } img, svg { max-width: 100%; } .wrap { max-width: var(--maxw); margin-inline: auto; padding-inline: var(--pad); } .skip { position: absolute; left: -999px; top: 0; background: var(--navy); color: #fff; padding: .6rem 1rem; z-index: 100; } .skip:focus { left: .5rem; top: .5rem; } .topbar { position: sticky; top: 0; z-index: 50; background: var(--navy); color: #fff; box-shadow: var(--shadow-bar); } .topbar__inner { max-width: var(--maxw); margin-inline: auto; padding: .55rem var(--pad); display: flex; align-items: center; gap: 1.25rem; flex-wrap: wrap; } .brand { display: inline-flex; align-items: center; gap: .65rem; color: #fff; font-family: "Montserrat", sans-serif; font-weight: 700; letter-spacing: .01em; white-space: nowrap; } .brand:hover { color: #fff; text-decoration: none; } .brand svg.poh { height: 2.2rem; max-height: 2.2rem; width: auto; } .brand__name { font-size: .98rem; } nav.menu { margin-left: auto; } nav.menu ul { list-style: none; margin: 0; padding: 0; display: flex; gap: .25rem; flex-wrap: wrap; } nav.menu a { display: inline-block; color: #dce6f5; font-weight: 600; font-size: .95rem; padding: .45rem .7rem; border-radius: var(--radius-sm); transition: background .15s ease, color .15s ease; } nav.menu a:hover { color: #fff; text-decoration: none; } nav.menu a { position: relative; } nav.menu a.active, nav.menu a.ancestor { color: #fff; } nav.menu a.active::after, nav.menu a.ancestor::after { content: ""; position: absolute; left: 50%; transform: translateX(-50%); bottom: .12rem; width: 90%; height: 2px; border-radius: 2px; background: linear-gradient(90deg, rgba(212,175,55,0) 0, var(--brass) 3px, var(--brass) calc(100% - 3px), rgba(212,175,55,0) 100%); view-transition-name: nav-underline; } @view-transition { navigation: auto; } ::view-transition-group(nav-underline) { animation-duration: .3s; } @media (prefers-reduced-motion: reduce) { ::view-transition-group(nav-underline) { animation-duration: 0s; } } nav.lang ul { list-style: none; margin: 0; padding: 0; display: flex; gap: .15rem; } nav.lang a { color: #aebfd8; font-weight: 600; font-size: .82rem; padding: .3rem .45rem; border-radius: var(--radius-sm); } nav.lang a:hover { color: #fff; background: rgba(255,255,255,.10); text-decoration: none; } nav.lang a.active { color: var(--brass); } nav.search { display: inline-flex; align-items: center; } nav.search .pf-lazy-btn { color: #aebfd8; background: transparent; border: 0; border-radius: var(--radius-sm); padding: .35rem .45rem; cursor: pointer; font: inherit; display: inline-flex; align-items: center; transition: color .15s ease, background .15s ease, opacity .15s ease; } nav.search .pf-lazy-btn:hover { color: #fff; background: rgba(255,255,255,.10); } nav.search .pf-lazy-btn.is-loading { opacity: .5; cursor: progress; } nav.search .pf-trigger-btn { color: #aebfd8 !important; background: transparent !important; border: 0 !important; box-shadow: none !important; border-radius: var(--radius-sm) !important; padding: .35rem .45rem !important; cursor: pointer; font: inherit; display: inline-flex !important; align-items: center; transition: color .15s ease, background .15s ease; } nav.search .pf-trigger-btn:hover { color: #fff !important; background: rgba(255,255,255,.10) !important; } nav.search .pf-trigger-text, nav.search .pf-trigger-shortcut { display: none !important; } nav.search .pf-trigger-icon { width: 1.2rem !important; height: 1.2rem !important; color: #aebfd8 !important; } nav.search .pf-trigger-icon svg { stroke: currentColor !important; fill: none !important; } nav.search .pf-trigger-btn:hover .pf-trigger-icon { color: #fff !important; } :root { --pagefind-ui-scale: 1; --pagefind-ui-primary: var(--navy); --pagefind-ui-text: var(--ink); --pagefind-ui-background: var(--surface); --pagefind-ui-border: var(--border); --pagefind-ui-tag: var(--surface-2); --pagefind-ui-border-radius: var(--radius-sm); --pagefind-ui-font: "Open Sans", system-ui, sans-serif; } @media (max-width: 48em) { .topbar__inner { row-gap: 0; column-gap: .75rem; } .brand { gap: .5rem; } .brand__name { font-size: .9rem; } nav.menu { margin-left: 0; width: 100%; order: 1; } nav.menu ul { justify-content: flex-start; } nav.menu a { padding-inline: .55rem; } nav.lang, nav.search { margin-left: auto; } nav.lang ~ nav.search { margin-left: 0; } } @media (max-width: 22.5em) { .brand svg.poh { height: 1.9rem; max-height: 1.9rem; } .brand__name { font-size: .8rem; } } .hero { background: radial-gradient(110% 140% at 85% -20%, rgba(212,175,55,.16), transparent 55%), linear-gradient(160deg, var(--navy) 0%, var(--navy-700) 100%); color: #eef3fb; } .hero__inner { max-width: var(--maxw); margin-inline: auto; padding: clamp(3rem, 8vw, 5.5rem) var(--pad) clamp(2.5rem, 6vw, 4rem); } .hero .kicker { color: var(--brass); } .hero h1 { color: #fff; font-size: clamp(2rem, 4.6vw, 3.2rem); max-width: 20ch; margin: .2rem 0 1rem; } .hero .lead { color: #c9d6ea; font-size: clamp(1.05rem, 1.6vw, 1.3rem); max-width: 60ch; margin-bottom: 1.8rem; } .kicker { text-transform: uppercase; letter-spacing: .14em; font-size: .76rem; font-weight: 700; color: var(--brass-ink); margin: 0 0 .25rem; } .btn, .article a.btn { display: inline-flex; align-items: center; gap: .5rem; font-family: "Montserrat", sans-serif; font-weight: 700; font-size: .95rem; letter-spacing: .01em; padding: .7rem 1.25rem; border-radius: var(--radius-sm); border: 1px solid transparent; cursor: pointer; transition: transform .12s ease, box-shadow .15s ease, background .15s ease; } .btn--primary { background: var(--brass); color: #2a2206; box-shadow: var(--shadow-1); } .btn--primary:hover { background: #e2bd45; color: #2a2206; text-decoration: none; transform: translateY(-1px); box-shadow: var(--shadow-2); } .btn--ghost { background: transparent; color: #fff; border-color: rgba(255,255,255,.4); } .btn--ghost:hover { background: rgba(255,255,255,.1); color: #fff; text-decoration: none; } .section { padding: clamp(2.5rem, 6vw, 4.5rem) 0; } .section--tint { background: var(--surface-2); } .section__head { max-width: 64rem; margin: 0 auto clamp(1.8rem, 4vw, 2.8rem); text-align: center; } .section__head h2 { font-size: clamp(1.5rem, 2.6vw, 2.1rem); margin: .2rem 0 .6rem; text-wrap: balance; } .section__head p { color: var(--muted); font-size: 1.08rem; margin: 0; } .grid.cards { display: grid; gap: 1.25rem; grid-template-columns: repeat(auto-fit, minmax(16rem, 1fr)); } .card { display: flex; flex-direction: column; background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius); padding: 1.5rem 1.5rem 1.35rem; box-shadow: var(--shadow-1); color: var(--body); transition: transform .15s ease, box-shadow .15s ease, border-color .15s ease; } a.card:hover { text-decoration: none; color: var(--body); transform: translateY(-3px); box-shadow: var(--shadow-2); border-color: var(--border-strong); } .card__icon { display: inline-flex; align-items: center; justify-content: center; width: 2.9rem; height: 2.9rem; margin-bottom: 1rem; border-radius: 10px; background: rgba(26,54,93,.08); color: var(--navy); } @media (prefers-color-scheme: dark) { .card__icon { background: rgba(15,240,252,.12); color: var(--cyan); } } .card__icon svg { width: 1.6rem; height: 1.6rem; } .card__title { font-size: 1.18rem; margin: 0 0 .4rem; } .card__desc { color: var(--muted); font-size: .98rem; margin: 0 0 1rem; flex: 1 0 auto; } .card__more { font-family:"Montserrat",sans-serif; font-weight:700; font-size:.9rem; color: var(--link); } a.card:hover .card__more { color: var(--link-hover); } .card--accent { border-top: 3px solid var(--brass); } .page--bands { padding-bottom: 0; } .band { position: relative; width: 100%; overflow: hidden; } .band--a { background: var(--surface) radial-gradient(135% 100% at 100% 0%, rgba(26,54,93,.05), rgba(26,54,93,0) 60%) no-repeat; } .band--b { background: var(--surface-2) radial-gradient(135% 100% at 0% 100%, rgba(26,54,93,.07), rgba(26,54,93,0) 60%) no-repeat; } .band__inner { position: relative; z-index: 1; max-width: var(--maxw); margin-inline: auto; padding: clamp(2.2rem, 5vw, 3.8rem) var(--pad); } .band + .band .band__inner::before { content: ""; position: absolute; top: 0; left: 50%; transform: translateX(-50%); width: min(46rem, calc(100% - 2 * var(--pad))); height: 1px; background: linear-gradient(90deg, transparent, var(--border-strong) 18%, var(--border-strong) 82%, transparent); opacity: .6; } .band__glyph { position: absolute; inset: 0; z-index: 0; pointer-events: none; width: 100%; height: 100%; color: var(--navy); opacity: .10; -webkit-mask-image: linear-gradient(to top, #000 0%, transparent 58%), linear-gradient(to right, #000, rgba(0,0,0,.3) 50%, #000); mask-image: linear-gradient(to top, #000 0%, transparent 58%), linear-gradient(to right, #000, rgba(0,0,0,.3) 50%, #000); -webkit-mask-composite: source-in; mask-composite: intersect; } @media (prefers-color-scheme: dark) { .band__glyph { color: var(--cyan); opacity: .12; } } @media (max-width: 52em) { .band__glyph { opacity: .07; } } .band__body { max-width: var(--measure); margin-inline: auto; } .band__body--lead { max-width: var(--measure); margin-inline: auto; color: var(--body); font-size: 1.12rem; } .band__body--center { max-width: var(--measure); margin-inline: auto; } @media (prefers-color-scheme: dark) { .band--a { background: var(--surface) radial-gradient(135% 100% at 100% 0%, rgba(15,240,252,.05), rgba(15,240,252,0) 60%) no-repeat; } .band--b { background: var(--surface-2) radial-gradient(135% 100% at 0% 100%, rgba(15,240,252,.06), rgba(15,240,252,0) 60%) no-repeat; } } .band__body h2 { font-size: clamp(1.4rem, 2.4vw, 1.95rem); margin: 0 0 .8rem; } .band__body h3 { font-size: 1.15rem; margin: 1.4rem 0 .5rem; } .band__body p { margin: 0 0 1rem; } .band__body ul, .band__body ol { padding-left: 1.2rem; } .band__body li { margin: .35rem 0; } .band__body strong { color: var(--ink); } .svc-list { margin-top: 1.3rem; } .svc { border-top: 1px solid var(--border); } .svc:last-child { border-bottom: 1px solid var(--border); } .svc > summary { list-style: none; cursor: pointer; display: flex; align-items: center; justify-content: space-between; gap: 1rem; padding: 1rem .25rem; font-family: "Montserrat", sans-serif; font-weight: 700; color: var(--ink); } .svc > summary::-webkit-details-marker { display: none; } .svc > summary:hover { color: var(--link); } .svc__chev { flex: none; width: .6rem; height: .6rem; border-right: 2px solid var(--brass); border-bottom: 2px solid var(--brass); transform: rotate(45deg); transition: transform .2s ease; } .svc[open] > summary .svc__chev { transform: rotate(-135deg); } .svc__body { padding: 0 .25rem 1.2rem; color: var(--body); } .svc__body p { margin: 0 0 .6rem; } .svc__link { font-family: "Montserrat", sans-serif; font-weight: 700; } .page { padding: clamp(2rem, 5vw, 3.5rem) 0 clamp(2.5rem,6vw,4rem); } .breadcrumb { font-size: .85rem; color: var(--muted); margin-bottom: 1.2rem; } .breadcrumb a { color: var(--muted); font-weight: 600; } .breadcrumb a:hover { color: var(--link); } .breadcrumb span[aria-current] { color: var(--body); } .page__head { position: relative; overflow: hidden; border-bottom: 2px solid var(--brass); } .page__head .wrap { position: relative; z-index: 1; } .page__glyph { position: absolute; inset: 0; z-index: 0; pointer-events: none; width: 100%; height: 100%; color: var(--navy); opacity: .13; -webkit-mask-image: radial-gradient(120% 95% at 50% 42%, transparent 6%, #000 62%); mask-image: radial-gradient(120% 95% at 50% 42%, transparent 6%, #000 62%); } @media (prefers-color-scheme: dark) { .page__glyph { color: var(--cyan); opacity: .15; } } @media (max-width: 52em) { .page__glyph { opacity: .09; } } .page__header { max-width: var(--measure); margin: 0 auto 2rem; } .page__header h1 { font-size: clamp(1.7rem, 3.2vw, 2.5rem); margin: .3rem 0 .6rem; } .page__header .lead { color: var(--muted); font-size: 1.15rem; margin: 0; } .article { max-width: var(--measure); margin-inline: auto; } .article h2 { font-size: 1.5rem; margin: 2.2rem 0 .8rem; } .article h3 { font-size: 1.2rem; margin: 1.8rem 0 .6rem; } .article ul, .article ol { padding-left: 1.3rem; } .article li { margin: .35rem 0; } .article strong { color: var(--ink); } .article hr { border: 0; border-top: 1px solid var(--border); margin: 2.5rem 0; } .article code { background: var(--surface-2); padding: .12em .4em; border-radius: 5px; font-size: .9em; } .article p > a[href^="mailto:"]:only-child, .band__body p > a[href^="mailto:"]:only-child { display: inline-flex; align-items: center; gap: .5rem; margin-top: 1rem; background: transparent; color: var(--link); border: 1.5px solid var(--border-strong); font-family:"Montserrat",sans-serif; font-weight: 700; padding: .65rem 1.2rem; border-radius: var(--radius-sm); transition: border-color .15s ease, color .15s ease, background .15s ease; } .article p > a[href^="mailto:"]:only-child:hover, .band__body p > a[href^="mailto:"]:only-child:hover { text-decoration: none; color: var(--link-hover); border-color: var(--brass); background: rgba(212,175,55,.08); } .article blockquote { margin: 1.5rem 0; padding: 1rem 1.25rem; background: var(--surface); border-left: 4px solid var(--brass); border-radius: var(--radius-sm); box-shadow: var(--shadow-1); color: var(--body); } .article blockquote p:last-child { margin-bottom: 0; } .site-footer { flex-shrink: 0; background: var(--navy-700); color: #c2d0e6; } .site-footer a { color: #dfe8f6; } .site-footer__inner { max-width: var(--maxw); margin-inline: auto; padding: 2.5rem var(--pad); display: grid; gap: 1.5rem 2rem; grid-template-columns: minmax(14rem, 1.4fr) repeat(auto-fit, minmax(9rem, 1fr)); align-items: start; } .site-footer .brand svg.poh { height: 3.4rem; max-height: 3.4rem; } .site-footer__inner p:nth-child(2) { margin-top:1rem; max-width:24ch; color: #aebccf; } .site-footer h4, .site-footer .footcol { color: #fff; font-size: .82rem; font-weight: 700; text-transform: uppercase; letter-spacing: .1em; margin: 0 0 .7rem; } .site-footer ul { list-style: none; margin: 0; padding: 0; } .site-footer li { margin: .3rem 0; font-size: .92rem; } .site-footer__legal { border-top: 1px solid rgba(255,255,255,.12); padding: 1rem var(--pad); font-size: .82rem; color: #93a6c4; max-width: var(--maxw); margin-inline: auto; } @media (max-width: 48em) { .site-footer__inner { grid-template-columns: 1fr; } .site-footer__umbrellas { display: none; } } @media print { .topbar, .site-footer, nav { display: none; } .page__glyph, .band__glyph, .card__icon, .btn, main [aria-hidden="true"] { display: none; } body { background: #fff; color: #000; } } svg.poh { stroke: var(--logo0, #fff); fill: var(--logo1, currentColor); stroke-width: .25; } .topbar svg.poh, .site-footer svg.poh { fill: #fff; stroke: var(--navy); } svg.poh circle { fill: none; } svg.poh circle:nth-child(1) { stroke: var(--cyan); } svg.poh circle:nth-child(2) { stroke: var(--brass); } svg.poh text { font-size: 3.5px; stroke: none; fill: #fff; font-weight: 700; text-transform: uppercase; } svg.poh text:nth-child(5) { transform: translate(24px,9px); } svg.poh text:nth-child(6) { transform: translate(24px,13px); font-weight: 400; font-size: 3px; } svg.poh text:nth-child(7) { transform: translate(24px,17px); } q:lang(en) { quotes: "\201C" "\201D" "\2018" "\2019"; } q:lang(fi), q:lang(sv) { quotes: "\00BB" "\00BB" "\203A" "\203A"; } q:lang(de) { quotes: "\201E" "\201C" "\201A" "\2018"; } q:before { content: open-quote; } q:after { content: close-quote; } dt { display: inline; font-weight: 700; } dt:after { content: ": "; } dd { display: inline; margin: 0; } dd:after { content: ""; display: block; }