/* SoEF — generated by build/extract.js. Do not edit by hand; edit src/ + re-run. */
/* All rules scoped under .soef-dash to avoid theme conflicts. */
/* ---- defensive normalize vs aggressive host resets (e.g. forest-wp-theme Tailwind preflight) — restores UA defaults the src assumed, scoped to .soef-dash ---- */
.soef-dash p{margin:revert}
.soef-dash ul,.soef-dash ol{list-style:revert;margin:revert;padding:revert}
.soef-dash li{margin:revert}
.soef-dash a{color:revert;text-decoration:revert}
.soef-dash h1,.soef-dash h2,.soef-dash h3,.soef-dash h4,.soef-dash h5,.soef-dash h6{font-size:revert;font-weight:revert;margin:revert}
.soef-dash img,.soef-dash svg,.soef-dash video{max-width:100%}

.soef-dash{
  --forest:#0B3D2D; --forest-2:#1C543F; --green:#3A7D44; --green-mid:#6BA368;
  --green-soft:#A3C9A8; --mint:#D4F8E5; --panel:#EDEDED; --panel-2:#F9FAFB;
  --ink:#111826; --muted:#5b6b6b; --line:#e6e8e6; --bg:#ffffff;
  --font-head:'Poppins','Helvetica Neue',Arial,sans-serif;
  --font-body:'Inter','Helvetica Neue',Arial,sans-serif;
  --maxw:1180px;
}
.soef-dash *{box-sizing:border-box;margin:0;padding:0}
.soef-dash{background:var(--bg);color:var(--ink);font-family:var(--font-body);line-height:1.6;-webkit-font-smoothing:antialiased}
.soef-dash h1,.soef-dash h2,.soef-dash h3,.soef-dash .num,.soef-dash .eyebrow{font-family:var(--font-head)}
.soef-dash .wrap{max-width:var(--maxw);margin:0 auto;padding:0 32px}
.soef-dash .topnav{background:transparent;position:absolute;top:0;left:0;right:0;z-index:50;padding:28px 52px;display:flex;align-items:center;gap:14px}
.soef-dash .brand{display:flex;align-items:center;gap:10px}
.soef-dash .brand .mark{width:50px;height:50px;background:transparent;display:flex;align-items:center;justify-content:center;color:#fff;font-size:15px}
.soef-dash .brand .mark .icn{width:80%;height:80%}
.soef-dash .brand b{font-size:14px;font-weight:600;display:block;line-height:1.1;color:#fff}
.soef-dash .brand span{font-size:9.5px;letter-spacing:.12em;text-transform:uppercase;color:#fff;opacity:1;font-weight:600}
.soef-dash .topnav .sp{flex:1}
.soef-dash .topnav .langs{display:flex;gap:6px}
.soef-dash .topnav .langs a{font-size:11px;font-weight:600;text-decoration:none;color:#fff;border:1px solid rgba(255,255,255,.4);border-radius:16px;padding:5px 11px}
.soef-dash .topnav .langs a.on{background:#fff;color:var(--forest);border-color:#fff}
.soef-dash .topnav .pdf{font-size:11px;color:#fff;text-decoration:none;font-weight:600;border:1px solid rgba(255,255,255,.5);border-radius:20px;padding:6px 14px}
.soef-dash .hero{position:relative;color:#fff;text-align:center;padding:130px 32px 70px;min-height:56vw;display:flex;flex-direction:column;justify-content:center;
  background:url('img/hero-autumn.jpg') center/cover no-repeat,#0B3D2D;overflow:hidden}
.soef-dash .hero .hero-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;border:0}
.soef-dash .hero .hero-scrim{position:absolute;inset:0;background:linear-gradient(180deg,rgba(11,61,45,.58),rgba(11,61,45,.80));z-index:1}
.soef-dash .hero>:not(.hero-bg):not(.hero-scrim){position:relative;z-index:2}
@media(prefers-reduced-motion:reduce){.soef-dash .hero .hero-bg{display:none}}
.soef-dash .hero .eyebrow{font-size:clamp(14px,1.6vw,32px);font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:#fff;opacity:1;margin-bottom:1vw;text-shadow:0 1px 3px rgba(0,0,0,.45)}
.soef-dash .hero h1{font-size:clamp(34px,4.7vw,92px);font-weight:600;line-height:1.06;letter-spacing:-.025em;max-width:none;margin:0 auto 1vw;color:#fff}
.soef-dash .hero h1 em{font-style:normal;color:#fff}
.soef-dash .hero .sub{font-size:clamp(15px,1.4vw,28px);opacity:1;max-width:60vw;margin:0 auto;text-shadow:0 1px 3px rgba(0,0,0,.4)}
.soef-dash .hstats{display:grid;grid-template-columns:repeat(3,1fr);gap:2vw;width:76vw;max-width:1500px;margin:6vw auto 0}
.soef-dash .hcard{background:rgba(255,255,255,.04);border:2px solid rgba(255,255,255,.75);border-radius:16px;padding:1.4vw 1.6vw;min-height:clamp(108px,8vw,128px);display:flex;flex-direction:column;justify-content:center}
.soef-dash .hcard .num{font-size:clamp(26px,3.1vw,62px);font-weight:600;letter-spacing:-.02em;line-height:1;color:#fff;white-space:nowrap}
.soef-dash .hcard .cap{font-size:clamp(12px,1.05vw,21px);opacity:1;margin-top:.6vw}
.soef-dash .hcard .src{font-size:10px;opacity:.5;margin-top:10px;letter-spacing:.02em}
.soef-dash .hero .srcline{font-size:11.5px;opacity:.6;margin-top:26px}
.soef-dash .hero .funder{margin-top:34px;display:flex;flex-direction:column;align-items:center;gap:16px}
.soef-dash .hero .funder .fline{font-size:12px;letter-spacing:.05em;text-transform:uppercase;color:#fff;opacity:1;font-weight:600}
.soef-dash .hero .flogos{display:flex;align-items:center;justify-content:center;gap:30px;flex-wrap:wrap}
.soef-dash .hero .flogos img{width:auto;object-fit:contain;filter:brightness(0) invert(1);opacity:.95}
.soef-dash .hero .flogos img.l-mtk{height:26px}
.soef-dash .hero .flogos img.l-mhy{height:22px}
.soef-dash .hero .flogos img.l-saatio{height:48px}
.soef-dash .sec{padding:74px 0;border-top:1px solid var(--line)}
.soef-dash .grid{display:grid;grid-template-columns:0.92fr 1.08fr;gap:48px;align-items:center}
.soef-dash .sec.rev .grid{direction:rtl}
.soef-dash .sec.rev .grid>*{direction:ltr}
.soef-dash .eyebrow{font-size:17px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--green);margin-bottom:14px}
.soef-dash .sec h2{font-size:42px;font-weight:600;letter-spacing:-.02em;line-height:1.05;margin-bottom:14px}
.soef-dash .q{font-size:15px;font-style:italic;color:var(--green);margin-bottom:22px}
.soef-dash .lead{font-size:17px;line-height:1.75;margin-bottom:18px}
.soef-dash .lead b{font-weight:600}
.soef-dash .checks{list-style:none;display:flex;flex-direction:column;gap:12px;margin:8px 0 22px}
.soef-dash .checks li{display:flex;gap:12px;align-items:flex-start;font-size:17px;line-height:1.5}
.soef-dash .checks .ic{flex:none;width:30px;height:30px;border-radius:8px;background:var(--forest);color:#fff;display:flex;align-items:center;justify-content:center;font-size:15px}
.soef-dash .pill{display:inline-flex;align-items:center;gap:10px;background:var(--panel-2);border:1px solid var(--line);border-radius:10px;padding:10px 16px;font-size:13.5px;font-weight:600;margin-bottom:18px}
.soef-dash .pill .ic{width:26px;height:26px;border-radius:7px;background:var(--forest);color:#fff;display:flex;align-items:center;justify-content:center;font-size:13px}
.soef-dash .iconcard{display:flex;gap:24px;align-items:center}
.soef-dash .iconcard .ci{flex:none;width:72px;height:72px;border-radius:18px;background:var(--forest);display:flex;align-items:center;justify-content:center}
.soef-dash .iconcard .ci svg{width:38px;height:38px}
.soef-dash .iconcard .statbody{flex:1}
@media(max-width:560px){.soef-dash .iconcard{flex-direction:column;align-items:flex-start}}
.soef-dash .statcard{background:var(--panel-2);border:1px solid var(--line);border-radius:16px;padding:26px 28px}
.soef-dash .statrow{display:grid;gap:18px}
.soef-dash .statrow.c3{grid-template-columns:repeat(3,1fr)}
.soef-dash .statrow.c2{grid-template-columns:repeat(2,1fr)}
.soef-dash .stat .num{font-size:42px;font-weight:600;color:var(--green);line-height:1;letter-spacing:-.02em;white-space:nowrap}
.soef-dash .stat .lbl{font-size:14px;color:var(--green);margin-top:6px;font-weight:600}
.soef-dash .statcard .cardfoot{font-size:10.5px;color:var(--muted);margin-top:16px;letter-spacing:.02em}
.soef-dash .statcard .big{display:flex;align-items:baseline;gap:14px}
.soef-dash .statcard .big .num{font-size:42px;font-weight:600;color:var(--green);letter-spacing:-.02em;white-space:nowrap}
.soef-dash .statcard .big .cap{font-size:16px;color:var(--green);font-weight:500}
.soef-dash .flow{display:flex;align-items:center;gap:14px;margin-top:18px;flex-wrap:wrap}
.soef-dash .flow .node{display:flex;flex-direction:column;align-items:center;gap:6px;font-size:10.5px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--muted)}
.soef-dash .flow .node .ic{width:42px;height:42px;border-radius:11px;background:var(--forest);color:#fff;display:flex;align-items:center;justify-content:center;font-size:19px}
.soef-dash .flow .arr{color:var(--green);display:flex;align-items:center}
.soef-dash .flow .arrico{width:24px;height:24px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.soef-dash .riskcard{background:var(--panel-2);border:1px solid var(--line);border-radius:16px;padding:26px 28px;align-self:start}
.soef-dash .riskcard .hd{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:18px}
.soef-dash .riskcard .hd .num{font-size:42px;font-weight:600;color:var(--green);letter-spacing:-.02em;line-height:1}
.soef-dash .riskcard .hd .yr{font-size:16px;color:var(--green);font-weight:500}
.soef-dash .riskcard .hd .trend{font-size:17px;font-weight:600;color:var(--green);display:flex;align-items:center;gap:8px}
.soef-dash .risk3{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;text-align:center}
.soef-dash .risk3 .col .tag{font-size:10.5px;font-weight:500;letter-spacing:.06em;color:#fff;background:var(--forest-2);border-radius:8px;padding:8px 10px;display:block;width:100%;margin:0 auto 12px}
.soef-dash .risk3 .col .ic{width:55px;height:55px;border-radius:14px;background:var(--forest-2);color:#fff;display:flex;align-items:center;justify-content:center;font-size:18px;margin:0 auto 8px}
.soef-dash .risk3 .col .nm{font-size:10.5px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--green)}
.soef-dash .riskreport{display:inline-flex;align-items:center;gap:10px;color:var(--green);font-weight:600;font-size:13px;text-decoration:none;margin-bottom:16px}
.soef-dash .riskreport .ic{width:26px;height:26px;border-radius:7px;background:var(--forest-2);color:#fff;display:flex;align-items:center;justify-content:center;font-style:italic;font-weight:700;font-size:14px}
.soef-dash .riskcard .src{font-size:10px;color:var(--muted);text-align:center;margin-top:16px}
.soef-dash .caveat{margin-top:16px;border:1px solid var(--line);border-left:3px solid var(--green);background:var(--panel-2);border-radius:12px;padding:14px 16px;font-size:12px;line-height:1.55;color:var(--ink)}
.soef-dash .caveat b{display:block;font-size:10px;letter-spacing:.06em;text-transform:uppercase;color:var(--green);margin-bottom:4px}
.soef-dash .illo{display:flex;flex-direction:column;align-items:center;justify-content:center}
.soef-dash .illo img{width:100%;max-width:640px;height:auto;display:block}
.soef-dash .illo .quote{font-size:12px;font-style:italic;color:var(--muted);text-align:center;max-width:380px;margin-top:14px;line-height:1.55}
.soef-dash .illo figcaption{font-size:10px;color:var(--muted);font-style:italic;margin-top:10px;letter-spacing:.04em}
.soef-dash .secsrc{font-size:11px;color:var(--muted);font-family:ui-monospace,monospace;margin-top:30px;padding-top:14px;border-top:1px solid var(--line)}
.soef-dash .secsrc b{color:var(--ink)}
.soef-dash .dq{background:var(--green);border-radius:clamp(48px,4.5vw,100px) clamp(48px,4.5vw,100px) 0 0;padding:60px 0 56px}
.soef-dash .dq .wrap{color:#eaf5ee;padding:0 32px}
.soef-dash .dq .hd{display:flex;justify-content:space-between;align-items:flex-start;gap:20px;margin-bottom:34px}
.soef-dash .dq h2{color:#fff;font-size:32px;font-weight:600;letter-spacing:-.01em}
.soef-dash .dq .hd p{font-size:11px;letter-spacing:.06em;color:var(--green-soft);margin-top:6px}
.soef-dash .dq .verified{font-size:10px;font-weight:700;letter-spacing:.08em;color:#fff;border:1px solid rgba(255,255,255,.35);border-radius:20px;padding:7px 14px;white-space:nowrap}
.soef-dash .dqgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:38px 48px}
.soef-dash .dqitem{display:grid;grid-template-columns:auto 1fr;column-gap:16px;row-gap:4px;align-items:start}
.soef-dash .dqitem .ic{grid-row:1 / span 2}
.soef-dash .dqitem .ic{width:40px;height:40px;border-radius:11px;background:rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;font-size:18px}
.soef-dash .dqitem h4{color:#fff;font-size:16px;font-weight:600}
.soef-dash .dqitem p{font-size:13px;line-height:1.55;opacity:.85}
.soef-dash .foot{background:var(--forest-2);color:#cfe0d6;padding:54px 32px 30px}
.soef-dash .foot .cols{display:grid;grid-template-columns:2fr 1fr;gap:40px;align-items:baseline}
.soef-dash .foot h4{color:#fff;font-size:12px;text-transform:uppercase;letter-spacing:.08em;margin-bottom:12px}
.soef-dash .foot h4.bt{font-family:var(--font-head);font-size:26px;text-transform:none;letter-spacing:-.01em;margin-bottom:14px}
.soef-dash .foot p{font-size:12.5px;line-height:1.7}
.soef-dash .foot ul{list-style:none}
.soef-dash .foot li{padding:3px 0}
.soef-dash .foot a{color:var(--green-soft);text-decoration:none;font-size:12.5px}
.soef-dash .foot p a{text-decoration:underline}
.soef-dash .foot a:hover{text-decoration:underline}
.soef-dash .foot .ctico{display:flex;gap:10px}
.soef-dash .foot .ctico a{width:34px;height:34px;border-radius:8px;background:rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center}
.soef-dash .foot .logo{display:flex;align-items:center;gap:10px;margin-top:28px}
.soef-dash .foot .logo .mark{width:30px;height:30px;border-radius:7px;background:rgba(255,255,255,.12);display:flex;align-items:center;justify-content:center;font-size:15px}
.soef-dash .foot .logo b{color:#fff;font-size:14px;font-weight:600;display:block;line-height:1.1}
.soef-dash .foot .logo span{font-size:9px;letter-spacing:.12em;text-transform:uppercase;color:var(--green-soft)}
.soef-dash .foot .meta{margin-top:30px;padding-top:18px;border-top:1px solid rgba(255,255,255,.12);font-size:10.5px;opacity:.6;line-height:1.6;display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap}
.soef-dash body.hide-src .secsrc,.soef-dash body.hide-src .statcard .cardfoot,.soef-dash body.hide-src .hcard .src,.soef-dash body.hide-src .hero .srcline,.soef-dash body.hide-src .riskcard .src{display:none!important}
.soef-dash body.hide-caveat .caveat{display:none!important}
@media(max-width:880px){.soef-dash .hero h1{font-size:32px;white-space:normal}
.soef-dash .hero{min-height:0;padding:110px 24px 56px}
.soef-dash .hero .sub{max-width:none;font-size:16px}
.soef-dash .hstats{grid-template-columns:1fr}
.soef-dash .grid,.soef-dash .sec.rev .grid{grid-template-columns:1fr;direction:ltr;gap:34px}
.soef-dash .sec .illo{order:2}
.soef-dash .eyebrow{font-size:13px;letter-spacing:.1em}
.soef-dash .statrow.c3{grid-template-columns:1fr}
.soef-dash .dqgrid{grid-template-columns:1fr}
.soef-dash .dqitem p{font-size:14px}
.soef-dash .dq h2{font-size:24px}
.soef-dash .foot .cols{grid-template-columns:1fr}
.soef-dash .foot .cols li a{display:inline-block;padding:7px 0;font-size:13.5px}
.soef-dash .dq .hd{flex-direction:column}}
@media(max-width:640px){.soef-dash .topnav{flex-wrap:wrap;gap:6px;padding:14px 16px}
.soef-dash .topnav .brand{gap:7px}
.soef-dash .topnav .brand .mark{width:34px;height:34px}
.soef-dash .topnav .brand b{font-size:12.5px}
.soef-dash .topnav .sp{flex:1 1 0;height:auto}
.soef-dash .topnav .langs{gap:5px}
.soef-dash .topnav .langs a{font-size:11px;padding:4px 8px;display:inline-flex;align-items:center}
.soef-dash .topnav a.pdf{font-size:11px;padding:4px 9px;display:inline-flex;align-items:center}
.soef-dash .hero{padding-top:104px}
.soef-dash .riskcard .hd{flex-direction:column;align-items:flex-start;gap:8px}
.soef-dash .risk3{grid-template-columns:repeat(3,1fr);gap:8px}
.soef-dash .risk3 .col .tag{font-size:9.5px;padding:6px 4px;margin-bottom:8px}
.soef-dash .risk3 .col .ic{width:46px;height:46px;border-radius:12px}
.soef-dash .risk3 .col .nm{font-size:9.5px}}
.soef-dash .icn{width:60%;height:60%;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.soef-dash .srcend{background:#fff;border-top:1px solid var(--line)}
.soef-dash .srcend h2{font-size:28px;margin-bottom:6px}
.soef-dash .srcend ul{list-style:none;margin:16px 0 10px;display:flex;flex-direction:column;gap:9px}
.soef-dash .srcend li{font-size:14px;color:var(--ink);line-height:1.5}
.soef-dash .srcend li b{color:var(--green);font-weight:600}
.soef-dash .srcend .note{font-size:11.5px;color:var(--muted);font-family:ui-monospace,monospace;margin-top:6px}
.soef-dash .foot .srcfoot{margin-top:30px;padding-top:22px;border-top:1px solid rgba(255,255,255,.12)}
.soef-dash .foot .srcfoot h4{color:#fff;font-size:11px;text-transform:uppercase;letter-spacing:.08em;margin-bottom:10px}
.soef-dash .foot .srcfoot ul{list-style:none;display:flex;flex-direction:column;gap:6px}
.soef-dash .foot .srcfoot li{font-size:11.5px;color:#cfe0d6;line-height:1.5}
.soef-dash .foot .srcfoot li b{color:#fff;font-weight:600}
.soef-dash .embedcta{background:var(--panel-2);border-top:1px solid var(--line);text-align:center}
.soef-dash .embedcta h2{font-size:30px}
.soef-dash .embedcta .lead{max-width:640px;margin:0 auto 22px}
.soef-dash .embedcta .go{display:inline-flex;align-items:center;gap:10px;background:var(--green);color:#fff;text-decoration:none;font-weight:600;font-size:15px;border-radius:30px;padding:14px 28px}
.soef-dash .embedcta .go:hover{background:var(--forest)}
.soef-dash a:focus-visible,.soef-dash button:focus-visible{outline:3px solid #D4F8E5;outline-offset:2px;border-radius:6px}
.soef-dash .skip{position:absolute;left:-9999px;top:10px;background:#fff;color:var(--forest);padding:10px 16px;border-radius:8px;font-weight:700;z-index:200;text-decoration:none}
.soef-dash .skip:focus{left:16px}
@media print{.soef-dash .topnav,.soef-dash .embedcta,.soef-dash .skip{display:none!important}
.soef-dash .hero{background:#fff!important;min-height:0;padding:24px}
.soef-dash .hero *{color:#000!important;text-shadow:none!important}
.soef-dash{color:#000}
.soef-dash .sec,.soef-dash .dq,.soef-dash .foot,.soef-dash .riskcard,.soef-dash .statcard,.soef-dash .dqitem{break-inside:avoid}}
.soef-dash .footlogos{display:flex;flex-direction:column;align-items:center;gap:20px;margin:32px auto 0;padding-top:28px;border-top:1px solid rgba(255,255,255,.12);max-width:700px}
.soef-dash .footlogos .fl-tier{display:flex;flex-direction:column;align-items:center;gap:12px}
.soef-dash .footlogos .fl-row{display:flex;align-items:center;justify-content:center;gap:36px;flex-wrap:wrap}
.soef-dash .footlogos .fl-lab{font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:#fff;opacity:.5;font-weight:600;text-align:center}
.soef-dash .footlogos img{filter:brightness(0) invert(1);opacity:.85;width:auto;object-fit:contain}
.soef-dash .footlogos a{display:inline-flex;align-items:center;text-decoration:none;transition:opacity .15s ease}
.soef-dash .footlogos a:hover img{opacity:1}
.soef-dash .footlogos .fl-saatio{height:50px}
.soef-dash .footlogos .fl-mtk{height:28px}
.soef-dash .footlogos .fl-mhy{height:26px}
.soef-dash .footlogos .fl-smy{height:22px}
.soef-dash .footlogos .fl-koko{height:20px}
.soef-dash .footlogos .fl-qbi{height:17px}

/* ---- skins: forest (Azo Sans · forest.fi default) · smy (Raleway) · soef (Poppins/Inter) ---- */
.soef-dash{--font-head:var(--wp--preset--font-family--azo-sans,'azo-sans-web','Azo Sans','Helvetica Neue',Arial,sans-serif);--font-body:var(--wp--preset--font-family--azo-sans,'azo-sans-web','Azo Sans','Helvetica Neue',Arial,sans-serif);}
.soef-dash.skin-forest{--font-head:var(--wp--preset--font-family--azo-sans,'azo-sans-web','Azo Sans','Helvetica Neue',Arial,sans-serif);--font-body:var(--wp--preset--font-family--azo-sans,'azo-sans-web','Azo Sans','Helvetica Neue',Arial,sans-serif);}
.soef-dash.skin-smy{--font-head:'Raleway','Helvetica Neue',Arial,sans-serif;--font-body:'Raleway','Helvetica Neue',Arial,sans-serif;}
.soef-dash.skin-soef{--font-head:'Poppins','Helvetica Neue',Arial,sans-serif;--font-body:'Inter','Helvetica Neue',Arial,sans-serif;}

/* ---- tableau (scoped under .soef-dash .soef-tableau) ---- */
.soef-dash .soef-tableau{--forest:#0B3D2D;--forest-2:#1C543F;--green:#3A7D44;--green-soft:#A3C9A8;--mint:#D4F8E5;--panel-2:#F9FAFB;--ink:#111826;--muted:#5b6b6b;--line:#e6e8e6}
.soef-dash .soef-tableau *{box-sizing:border-box;margin:0;padding:0}
.soef-dash .soef-tableau{font-family:'Inter',-apple-system,Segoe UI,Arial,sans-serif;color:var(--ink);background:#fff;line-height:1.6}
.soef-dash .soef-tableau .topnav{background:var(--forest);color:#fff;padding:16px 32px;display:flex;align-items:center;gap:14px}
.soef-dash .soef-tableau .topnav .brand{display:flex;align-items:center;gap:10px}
.soef-dash .soef-tableau .topnav .mark{width:34px;height:34px;display:flex;align-items:center;justify-content:center;color:#fff}
.soef-dash .soef-tableau .topnav .icn{width:78%;height:78%;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.soef-dash .soef-tableau .topnav b{font-size:14px;font-weight:600;display:block;line-height:1.1}
.soef-dash .soef-tableau .topnav span{font-size:9.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--green-soft);font-weight:600}
.soef-dash .soef-tableau .topnav .sp{flex:1}
.soef-dash .soef-tableau .topnav .back{font-size:12px;font-weight:600;color:#fff;text-decoration:none;border:1px solid rgba(255,255,255,.45);border-radius:20px;padding:7px 15px}
.soef-dash .soef-tableau .topnav .back:hover{background:rgba(255,255,255,.12)}
.soef-dash .soef-tableau .hd{max-width:1180px;margin:0 auto;padding:40px 32px 18px}
.soef-dash .soef-tableau .hd .eyebrow{font-size:13px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--green);margin-bottom:12px}
.soef-dash .soef-tableau .hd h1{font-family:'Poppins',sans-serif;font-size:34px;font-weight:600;letter-spacing:-.02em;margin-bottom:12px}
.soef-dash .soef-tableau .hd p{font-size:14.5px;color:var(--muted);max-width:780px}
.soef-dash .soef-tableau .hd .note{margin-top:14px;font-size:12px;color:var(--muted);background:var(--panel-2);border:1px solid var(--line);border-left:3px solid var(--green);border-radius:10px;padding:11px 14px;max-width:780px}
.soef-dash .soef-tableau .vizwrap{max-width:1320px;margin:18px auto 40px;padding:0 32px}
.soef-dash .soef-tableau .vizbox{border:1px solid var(--line);border-radius:14px;overflow:hidden;background:var(--panel-2);min-height:820px}
.soef-dash .soef-tableau tableau-viz{display:block;width:100%}
.soef-dash .soef-tableau .foot{background:var(--forest-2);color:#cfe0d6;padding:26px 32px;font-size:11.5px;line-height:1.7;text-align:center}
.soef-dash .soef-tableau .foot a{color:var(--green-soft);text-decoration:none}
@media(max-width:680px){.soef-dash .soef-tableau .hd h1{font-size:26px}
.soef-dash .soef-tableau .vizbox{min-height:620px}}
.soef-dash .soef-tableau .footlogos{display:flex;flex-direction:column;align-items:center;gap:20px;margin:32px auto 0;padding-top:28px;border-top:1px solid rgba(255,255,255,.12);max-width:700px}
.soef-dash .soef-tableau .footlogos .fl-tier{display:flex;flex-direction:column;align-items:center;gap:12px}
.soef-dash .soef-tableau .footlogos .fl-row{display:flex;align-items:center;justify-content:center;gap:36px;flex-wrap:wrap}
.soef-dash .soef-tableau .footlogos .fl-lab{font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:#fff;opacity:.5;font-weight:600;text-align:center}
.soef-dash .soef-tableau .footlogos img{filter:brightness(0) invert(1);opacity:.85;width:auto;object-fit:contain}
.soef-dash .soef-tableau .footlogos a{display:inline-flex;align-items:center;text-decoration:none;transition:opacity .15s ease}
.soef-dash .soef-tableau .footlogos a:hover img{opacity:1}
.soef-dash .soef-tableau .footlogos .fl-saatio{height:50px}
.soef-dash .soef-tableau .footlogos .fl-mtk{height:28px}
.soef-dash .soef-tableau .footlogos .fl-mhy{height:26px}
.soef-dash .soef-tableau .footlogos .fl-smy{height:22px}
.soef-dash .soef-tableau .footlogos .fl-koko{height:20px}
.soef-dash .soef-tableau .footlogos .fl-qbi{height:17px}

/* ---- landing (from src/index.html, scoped under .soef-dash .soef-landing) ---- */
.soef-dash .soef-landing{--forest:#0B3D2D;--forest-2:#1C543F;--green:#3A7D44;--green-soft:#A3C9A8;--mint:#D4F8E5}
.soef-dash .soef-landing *{box-sizing:border-box;margin:0;padding:0}
.soef-dash .soef-landing{min-height:100%}
.soef-dash .soef-landing{font-family:var(--font-body);color:#fff;min-height:100vh;
  display:flex;align-items:center;justify-content:center;text-align:center;padding:56px 24px;
  background:url('img/hero-autumn.jpg') center/cover no-repeat,#0B3D2D}
.soef-dash .soef-landing .bgvideo{position:fixed;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;border:0}
.soef-dash .soef-landing .bgscrim{position:fixed;inset:0;background:linear-gradient(180deg,rgba(11,61,45,.62),rgba(11,61,45,.86));z-index:1}
@media(prefers-reduced-motion:reduce){.soef-dash .soef-landing .bgvideo{display:none}}
.soef-dash .soef-landing .wrap{width:100%;max-width:760px;position:relative;z-index:2}
.soef-dash .soef-landing .brand{display:inline-flex;align-items:center;gap:10px;margin-bottom:34px}
.soef-dash .soef-landing .brand .mark{width:42px;height:42px;display:flex;align-items:center;justify-content:center}
.soef-dash .soef-landing .brand .mark svg{width:80%;height:80%;fill:none;stroke:#fff;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.soef-dash .soef-landing .brand b{font-family:var(--font-head);font-size:16px;font-weight:600;line-height:1.15}
.soef-dash .soef-landing .eyebrow{font-size:12px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:#fff;opacity:.92;margin-bottom:16px;text-shadow:0 1px 3px rgba(0,0,0,.45)}
.soef-dash .soef-landing h1{font-family:var(--font-head);font-size:clamp(30px,5vw,52px);font-weight:600;line-height:1.08;letter-spacing:-.025em;max-width:720px;margin:0 auto 16px;text-shadow:0 1px 4px rgba(0,0,0,.4)}
.soef-dash .soef-landing .sub{font-size:15px;opacity:.9;max-width:520px;margin:0 auto 40px;line-height:1.6;text-shadow:0 1px 3px rgba(0,0,0,.4)}
.soef-dash .soef-landing .langs{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;max-width:620px;margin:0 auto}
.soef-dash .soef-landing .langs a{flex:1 1 170px;text-decoration:none;color:#fff;background:rgba(255,255,255,.06);border:2px solid rgba(255,255,255,.55);
  border-radius:16px;padding:26px 22px;transition:.15s;display:block}
.soef-dash .soef-landing .langs a:hover{background:rgba(255,255,255,.16);border-color:#fff;transform:translateY(-2px)}
.soef-dash .soef-landing .langs .code{font-family:var(--font-head);font-size:30px;font-weight:700;letter-spacing:.02em}
.soef-dash .soef-landing .langs .nm{font-size:13px;opacity:.88;margin-top:6px}
.soef-dash .soef-landing .credits{margin-top:52px;display:flex;flex-direction:column;align-items:center;gap:24px}
.soef-dash .soef-landing .credits .flabel{font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:#fff;opacity:.85;font-weight:600}
.soef-dash .soef-landing .credits .row{display:flex;align-items:center;justify-content:center;gap:32px;flex-wrap:wrap}
.soef-dash .soef-landing .credits .grp{display:flex;flex-direction:column;align-items:center;gap:13px}
.soef-dash .soef-landing .credits img{filter:brightness(0) invert(1);opacity:.92;width:auto;object-fit:contain}
.soef-dash .soef-landing .lg-saatio{height:56px}
.soef-dash .soef-landing .lg-mtk{height:26px}
.soef-dash .soef-landing .lg-mhy{height:38px}
.soef-dash .soef-landing .lg-smy{height:34px}
.soef-dash .soef-landing .lg-koko{height:22px}
.soef-dash .soef-landing .lg-qbi{height:20px}
.soef-dash .soef-landing .credits .div{width:100%;max-width:420px;height:1px;background:rgba(255,255,255,.16);margin:4px 0}
.soef-dash .soef-landing .foot{margin-top:40px;font-size:11px;opacity:.6;line-height:1.7}
.soef-dash .soef-landing .foot a{color:var(--green-soft);text-decoration:none}
@media(max-width:560px){.soef-dash .soef-landing .langs a{flex:1 1 100%}
.soef-dash .soef-landing .credits .row{gap:24px}}

/* ===== Tableau-sivun hero-paivitys (impeccable 2026-06-17) ===== */
.soef-dash .soef-tableau .hd{max-width:none;margin:0;padding:58px 32px 64px;text-align:center;color:#fff;background:linear-gradient(180deg,rgba(11,61,45,.66),rgba(11,61,45,.88)),url('img/hero-autumn.jpg') center/cover no-repeat}
.soef-dash .soef-tableau .hd>*{max-width:760px;margin-left:auto;margin-right:auto}
.soef-dash .soef-tableau .hd .eyebrow{color:#fff;opacity:.92;font-size:13px;letter-spacing:.16em;margin-bottom:16px;text-shadow:0 1px 3px rgba(0,0,0,.4)}
.soef-dash .soef-tableau .hd h1{color:#fff;font-size:clamp(30px,4vw,52px);line-height:1.08;letter-spacing:-.025em;margin-bottom:16px;text-shadow:0 1px 4px rgba(0,0,0,.35)}
.soef-dash .soef-tableau .hd .lead{color:#fff;opacity:.96;font-size:clamp(16px,1.6vw,21px);line-height:1.55;margin-bottom:14px;text-shadow:0 1px 3px rgba(0,0,0,.3)}
.soef-dash .soef-tableau .hd p{color:#fff;opacity:.85;font-size:15px;line-height:1.65;text-shadow:0 1px 2px rgba(0,0,0,.28)}
.soef-dash .soef-tableau .hd .note{margin:24px auto 0;max-width:680px;text-align:left;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.28);border-left:1px solid rgba(255,255,255,.28);border-radius:12px;padding:13px 17px;color:rgba(255,255,255,.9);font-size:12px;line-height:1.6;text-shadow:none}
.soef-dash .soef-tableau .hd .note em{color:#fff}
.soef-dash .soef-tableau .vizwrap{margin-top:26px}
