Private/Reporting/ReportStyles.ps1
|
# ----------------------------------------------------------------------------- # ReportStyles.ps1 — design tokens and CSS for HTML reports. # # The CSS is a here-string, but it's isolated from rendering logic. When # something visual changes (color, shadow, spacing), only this file is # touched. The palette hashtable below mirrors the CSS custom properties, # so if any future PowerShell code ever needs a color value, it can read # it here rather than duplicating hex codes across files. # # Neobrutal design language: # - Thick black borders (3-4px solid) # - Flat saturated colors (no gradients) # - Heavy drop shadows (6-10px offset, 0 blur, solid black) # - 900-weight typography for headings # - Tabular-numeric monospace for data # - Print CSS strips shadows and cream background # ----------------------------------------------------------------------------- # --- Design tokens ---------------------------------------------------------- $script:ReportPalette = @{ Bg = '#ffffff' Card = '#f5f1e8' # cream paper feel Ink = '#000000' # all borders, all shadows Muted = '#6b6b6b' Blue = '#2e71b8' # primary — banner, links Green = '#7fd865' GreenLt = '#c7f464' Amber = '#ffd43b' AmberLt = '#ffe66d' Red = '#ef4444' RedLt = '#ffb3ba' Pink = '#ff6b9d' # "current session" accent Purple = '#b794f4' Mint = '#4ecdc4' } function Get-ReportPalette { <# .SYNOPSIS Returns the palette hashtable. Kept as a function (not a bare $script:-scoped var read by callers) so dependencies flow through a testable seam. #> $script:ReportPalette } # --- CSS block -------------------------------------------------------------- function Get-ReportCss { <# .SYNOPSIS Returns the <style>...</style> block for the HTML report. One self-contained unit, no external fonts or stylesheets, print-ready. #> @' <style> :root { --bg: #ffffff; --card: #f5f1e8; --ink: #000000; --muted: #6b6b6b; --blue: #2e71b8; --blue-lt: #a7c8e8; --green: #7fd865; --green-lt: #c7f464; --amber: #ffd43b; --amber-lt: #ffe66d; --red: #ef4444; --red-lt: #ffb3ba; --pink: #ff6b9d; --purple: #b794f4; --mint: #4ecdc4; --shadow: 6px 6px 0 var(--ink); --shadow-lg: 10px 10px 0 var(--ink); --border: 3px solid var(--ink); --border-lg: 4px solid var(--ink); } * { box-sizing: border-box; } html, body { margin: 0; padding: 0; background: var(--bg); color: var(--ink); font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Arial, sans-serif; font-size: 15px; line-height: 1.45; font-weight: 500; -webkit-font-smoothing: antialiased; } .container { max-width: 1080px; margin: 2.5rem auto; padding: 0 1.5rem; } .mono { font-family: "JetBrains Mono", "Cascadia Mono", "Consolas", ui-monospace, monospace; font-variant-numeric: tabular-nums; font-weight: 600; } /* ============================================================ BANNER */ .banner { background: var(--blue); color: #fff; border: var(--border-lg); box-shadow: var(--shadow-lg); padding: 2rem 2.25rem; margin-bottom: 1.75rem; display: grid; grid-template-columns: 1fr auto; gap: 1.5rem; align-items: center; } .banner h1 { margin: 0; font-size: 2.25rem; font-weight: 900; letter-spacing: -0.03em; line-height: 1.05; } .banner .version { display: inline-block; background: var(--amber-lt); color: var(--ink); border: var(--border); padding: 0.15em 0.55em; margin-left: 0.5em; font-family: "JetBrains Mono", monospace; font-size: 0.7em; font-weight: 700; vertical-align: middle; box-shadow: 3px 3px 0 var(--ink); } .banner .tagline { margin: 0.6rem 0 0 0; font-size: 1rem; font-weight: 500; opacity: 0.95; } .banner .brand { text-align: right; line-height: 1; } .banner .brand-mark { font-size: 2.6rem; font-weight: 900; letter-spacing: -0.06em; background: #fff; color: var(--ink); border: var(--border); padding: 0.3rem 0.7rem; display: inline-block; box-shadow: 4px 4px 0 var(--ink); } .banner .brand-sub { margin-top: 0.4rem; font-size: 0.8rem; font-weight: 700; letter-spacing: 0.2em; text-transform: uppercase; opacity: 0.9; } /* ============================================================ META STRIP */ .meta-strip { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 0.9rem; margin-bottom: 1.75rem; } .meta-item { background: var(--card); border: var(--border); box-shadow: var(--shadow); padding: 0.9rem 1rem; } .meta-label { display: block; font-size: 0.7rem; font-weight: 800; letter-spacing: 0.15em; text-transform: uppercase; color: var(--muted); margin-bottom: 0.3rem; } .meta-value { font-family: "JetBrains Mono", monospace; font-size: 0.95rem; font-weight: 700; color: var(--ink); word-break: break-word; } /* ============================================================ LOGOFF */ .logoff { display: grid; grid-template-columns: auto 1fr; gap: 1.5rem; align-items: center; padding: 1.5rem 2rem; border: var(--border-lg); box-shadow: var(--shadow-lg); margin-bottom: 1.75rem; } .logoff.success { background: var(--green-lt); } .logoff.mixed { background: var(--amber-lt); } .logoff.failure { background: var(--red-lt); } .logoff-icon { font-size: 3.5rem; line-height: 1; font-weight: 900; width: 5rem; height: 5rem; display: flex; align-items: center; justify-content: center; background: #fff; border: var(--border); box-shadow: 4px 4px 0 var(--ink); } .logoff-count { font-size: 2.2rem; font-weight: 900; letter-spacing: -0.02em; line-height: 1; } .logoff-sub { margin-top: 0.4rem; font-size: 1rem; font-weight: 600; } /* ============================================================ SECTION TITLE */ .section-title { font-size: 1.3rem; font-weight: 900; letter-spacing: 0.02em; text-transform: uppercase; margin: 2.25rem 0 1rem 0; padding-bottom: 0.4rem; border-bottom: var(--border-lg); display: flex; align-items: center; gap: 0.6rem; } .section-title .badge { display: inline-block; background: var(--ink); color: var(--amber-lt); font-family: "JetBrains Mono", monospace; font-size: 0.75rem; font-weight: 700; padding: 0.1em 0.55em; } /* ============================================================ SUMMARY */ .summary-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); gap: 0.9rem; } .stat-card { background: var(--card); border: var(--border); box-shadow: var(--shadow); padding: 1rem 1.1rem; position: relative; overflow: hidden; } .stat-card .stat-label { font-size: 0.7rem; font-weight: 800; letter-spacing: 0.12em; text-transform: uppercase; color: var(--muted); margin-bottom: 0.3rem; } .stat-card .stat-value { font-family: "JetBrains Mono", monospace; font-size: 2.25rem; font-weight: 900; letter-spacing: -0.03em; line-height: 1; color: var(--ink); } .stat-card.active { background: var(--green-lt); } .stat-card.disc { background: var(--amber-lt); } .stat-card.disabled { background: var(--red-lt); } .stat-card.offline { background: #e0e0e0; } .stat-card.errored { background: var(--red-lt); } /* ============================================================ ALERT BLOCK */ .alert { background: var(--amber-lt); border: var(--border-lg); box-shadow: var(--shadow); padding: 1.25rem 1.5rem; margin-bottom: 1.25rem; } .alert.danger { background: var(--red-lt); } .alert h3 { margin: 0 0 0.4rem 0; font-size: 1.1rem; font-weight: 900; letter-spacing: 0.02em; text-transform: uppercase; } .alert p { margin: 0; font-size: 0.95rem; font-weight: 500; } /* ============================================================ SERVER CARD */ .server-card { background: var(--card); border: var(--border); box-shadow: var(--shadow); margin-bottom: 1.5rem; overflow: hidden; } .server-header { background: var(--ink); color: #fff; padding: 0.85rem 1.25rem; display: flex; justify-content: space-between; align-items: center; gap: 1rem; flex-wrap: wrap; } .server-name { font-family: "JetBrains Mono", monospace; font-size: 1.05rem; font-weight: 700; letter-spacing: 0.01em; } .server-chips { display: flex; gap: 0.4rem; flex-wrap: wrap; } .chip { display: inline-flex; align-items: center; gap: 0.35em; padding: 0.2em 0.7em; font-family: "JetBrains Mono", monospace; font-size: 0.8rem; font-weight: 700; border: 2px solid #fff; color: #fff; } .chip.active { background: var(--green); color: var(--ink); border-color: var(--ink); } .chip.disc { background: var(--amber); color: var(--ink); border-color: var(--ink); } /* ============================================================ SESSION TABLE */ table.sessions { width: 100%; border-collapse: collapse; font-size: 0.9rem; } table.sessions th { background: var(--bg); padding: 0.6rem 0.9rem; text-align: left; font-size: 0.7rem; font-weight: 800; letter-spacing: 0.12em; text-transform: uppercase; color: var(--muted); border-bottom: var(--border); } table.sessions td { padding: 0.6rem 0.9rem; border-bottom: 1px solid #e5e0d4; vertical-align: middle; } table.sessions tbody tr:last-child td { border-bottom: none; } /* Right-anchor the rightmost column so the timestamp sits flush against the row's right edge. Without this, table-layout: auto distributes the row's free width across the last cell, leaving a visible empty stripe on the right side of every row when the report pastes into a wider editor (HaloPSA, Outlook). */ table.sessions th:last-child, table.sessions td:last-child { text-align: right; } .state-pill { display: inline-block; padding: 0.12em 0.65em; font-family: "JetBrains Mono", monospace; font-size: 0.78rem; font-weight: 700; border: 2px solid var(--ink); text-transform: uppercase; letter-spacing: 0.03em; } .state-pill.active { background: var(--green-lt); } .state-pill.disc { background: var(--amber-lt); } .state-pill.other { background: #e0e0e0; } .mark { display: inline-block; width: 1.25em; text-align: center; font-weight: 900; } .mark.active { color: var(--green); } .mark.disc { color: #c48a00; } .mark.current { color: var(--pink); } .user-cell { font-family: "JetBrains Mono", monospace; font-weight: 700; } .user-cell.disabled { color: var(--red); text-decoration: line-through; } .disabled-badge { display: inline-block; margin-left: 0.4em; background: var(--red); color: #fff; font-family: "JetBrains Mono", monospace; font-size: 0.7rem; font-weight: 700; padding: 0.08em 0.45em; border: 2px solid var(--ink); letter-spacing: 0.05em; } td.idle.hot { color: var(--red); font-weight: 800; } /* ============================================================ PILLS */ .pill-list { display: flex; flex-wrap: wrap; gap: 0.4rem; } .pill { display: inline-block; background: var(--card); border: 2px solid var(--ink); padding: 0.3em 0.7em; font-family: "JetBrains Mono", monospace; font-size: 0.82rem; font-weight: 600; box-shadow: 2px 2px 0 var(--ink); } /* ============================================================ ERROR GROUPS */ .error-group { background: var(--card); border: var(--border); box-shadow: var(--shadow); margin-bottom: 1rem; overflow: hidden; } .error-group-header { background: var(--red); color: #fff; padding: 0.75rem 1.1rem; display: flex; justify-content: space-between; align-items: center; gap: 1rem; } .error-group-header .msg { font-weight: 700; letter-spacing: 0.01em; } .error-group-header .count { font-family: "JetBrains Mono", monospace; font-weight: 700; background: var(--ink); padding: 0.15em 0.6em; border: 2px solid #fff; } .error-group-body { padding: 0.9rem 1.1rem; } /* ============================================================ FOOTER */ .footer { margin-top: 3rem; padding-top: 1.5rem; border-top: var(--border); font-size: 0.85rem; color: var(--muted); display: flex; justify-content: space-between; flex-wrap: wrap; gap: 1rem; } .footer code { background: var(--ink); color: var(--green-lt); padding: 0.1em 0.4em; font-family: "JetBrains Mono", monospace; font-size: 0.85rem; font-weight: 700; } details summary { cursor: pointer; font-weight: 700; color: var(--ink); } details[open] summary { margin-bottom: 0.5rem; } /* ============================================================ PRINT */ @media print { html, body { background: #fff; } .container { max-width: none; margin: 0; padding: 1cm; } .banner, .server-header, .server-card, .stat-card, .meta-item, .logoff, .alert, .error-group { box-shadow: none !important; } .section-title { page-break-after: avoid; } .server-card, .error-group, .alert { page-break-inside: avoid; } table.sessions { page-break-inside: auto; } table.sessions tr { page-break-inside: avoid; } } </style> '@ } # --- Copy-to-clipboard widget ---------------------------------------------- function Get-ReportCopyWidget { <# .SYNOPSIS Returns a self-contained "Copy for Halo / Outlook" button + script. Why: rich-text editors (HaloPSA, in particular) strip <style> tags on paste, even from inside the CF_HTML fragment. The CF_HTML write we do from PowerShell therefore pastes unstyled. The browser, when you Ctrl+A → Ctrl+C, runs its native copy path which serializes the selection with computed styles inlined per element — and THAT markup pastes beautifully. Triggering the same path from a button is reliable: select the report content into a Range and call document.execCommand('copy'). Browser security requires a user gesture, so auto-copy on load is not an option; a click is the gesture. Hidden in print media so it doesn't appear in PDF exports. #> @' <button type="button" id="liss-copy-btn" style="position:fixed;top:1rem;left:50%;transform:translateX(-50%);z-index:9999; padding:0.7em 1.4em;font-family:'Inter',-apple-system,sans-serif; font-size:0.9rem;font-weight:800;letter-spacing:0.08em; text-transform:uppercase;background:#7fd865;color:#000; border:3px solid #000;box-shadow:4px 4px 0 #000;cursor:pointer; transition:background 80ms ease;"> Copy for Halo / Outlook </button> <style media="screen"> /* Hover/active need a single transform property so they don't fight the translateX(-50%) used to center the button. */ #liss-copy-btn:hover { transform: translate(calc(-50% - 1px), -1px); box-shadow: 5px 5px 0 #000; } #liss-copy-btn:active { transform: translate(calc(-50% + 2px), 2px); box-shadow: 2px 2px 0 #000; } </style> <style media="print"> #liss-copy-btn { display: none !important; } </style> <script> (function () { var btn = document.getElementById('liss-copy-btn'); if (!btn) return; var original = btn.textContent; btn.addEventListener('click', function () { var target = document.querySelector('.container') || document.body; // setStartBefore / setEndAfter on the first/last ELEMENT children // skips the leading/trailing whitespace text nodes that sit between // the container's tags and its children — those produce phantom blank // lines in the paste otherwise. if (!target.firstElementChild || !target.lastElementChild) return; var sel = window.getSelection(); var range = document.createRange(); btn.style.visibility = 'hidden'; // not selectable while we copy range.setStartBefore(target.firstElementChild); range.setEndAfter(target.lastElementChild); sel.removeAllRanges(); sel.addRange(range); var ok = false; try { ok = document.execCommand('copy'); } catch (e) { ok = false; } sel.removeAllRanges(); btn.style.visibility = 'visible'; btn.textContent = ok ? 'Copied!' : 'Copy failed'; btn.style.background = ok ? '#c7f464' : '#ffb3ba'; setTimeout(function () { btn.textContent = original; btn.style.background = '#7fd865'; }, 1800); }); })(); </script> '@ } # --- HTML escape helper ----------------------------------------------------- function ConvertTo-HtmlSafe { <# .SYNOPSIS Minimal HTML escape for interpolating user/server names safely. Covers the characters that matter in practice; we never interpolate anything where full XSS-style escape is needed (this is an offline report, not a web page). #> param([string]$Text) if (-not $Text) { return '' } $Text = $Text -replace '&', '&' $Text = $Text -replace '<', '<' $Text = $Text -replace '>', '>' $Text = $Text -replace '"', '"' $Text = $Text -replace "'", ''' return $Text } # SIG # Begin signature block # MIItnAYJKoZIhvcNAQcCoIItjTCCLYkCAQExDzANBglghkgBZQMEAgEFADB5Bgor # BgEEAYI3AgEEoGswaTA0BgorBgEEAYI3AgEeMCYCAwEAAAQQH8w7YFlLCE63JNLG # KX7zUQIBAAIBAAIBAAIBAAIBADAxMA0GCWCGSAFlAwQCAQUABCC+wGu1aYpbA/k9 # cuhKOaHuStZxWT+y3MTZJz0XsmQ0WKCCJp8wggWNMIIEdaADAgECAhAOmxiO+dAt # 5+/bUOIIQBhaMA0GCSqGSIb3DQEBDAUAMGUxCzAJBgNVBAYTAlVTMRUwEwYDVQQK # EwxEaWdpQ2VydCBJbmMxGTAXBgNVBAsTEHd3dy5kaWdpY2VydC5jb20xJDAiBgNV # BAMTG0RpZ2lDZXJ0IEFzc3VyZWQgSUQgUm9vdCBDQTAeFw0yMjA4MDEwMDAwMDBa # Fw0zMTExMDkyMzU5NTlaMGIxCzAJBgNVBAYTAlVTMRUwEwYDVQQKEwxEaWdpQ2Vy # dCBJbmMxGTAXBgNVBAsTEHd3dy5kaWdpY2VydC5jb20xITAfBgNVBAMTGERpZ2lD # ZXJ0IFRydXN0ZWQgUm9vdCBHNDCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoC # ggIBAL/mkHNo3rvkXUo8MCIwaTPswqclLskhPfKK2FnC4SmnPVirdprNrnsbhA3E # MB/zG6Q4FutWxpdtHauyefLKEdLkX9YFPFIPUh/GnhWlfr6fqVcWWVVyr2iTcMKy # unWZanMylNEQRBAu34LzB4TmdDttceItDBvuINXJIB1jKS3O7F5OyJP4IWGbNOsF # xl7sWxq868nPzaw0QF+xembud8hIqGZXV59UWI4MK7dPpzDZVu7Ke13jrclPXuU1 # 5zHL2pNe3I6PgNq2kZhAkHnDeMe2scS1ahg4AxCN2NQ3pC4FfYj1gj4QkXCrVYJB # MtfbBHMqbpEBfCFM1LyuGwN1XXhm2ToxRJozQL8I11pJpMLmqaBn3aQnvKFPObUR # WBf3JFxGj2T3wWmIdph2PVldQnaHiZdpekjw4KISG2aadMreSx7nDmOu5tTvkpI6 # nj3cAORFJYm2mkQZK37AlLTSYW3rM9nF30sEAMx9HJXDj/chsrIRt7t/8tWMcCxB # YKqxYxhElRp2Yn72gLD76GSmM9GJB+G9t+ZDpBi4pncB4Q+UDCEdslQpJYls5Q5S # UUd0viastkF13nqsX40/ybzTQRESW+UQUOsxxcpyFiIJ33xMdT9j7CFfxCBRa2+x # q4aLT8LWRV+dIPyhHsXAj6KxfgommfXkaS+YHS312amyHeUbAgMBAAGjggE6MIIB # NjAPBgNVHRMBAf8EBTADAQH/MB0GA1UdDgQWBBTs1+OC0nFdZEzfLmc/57qYrhwP # TzAfBgNVHSMEGDAWgBRF66Kv9JLLgjEtUYunpyGd823IDzAOBgNVHQ8BAf8EBAMC # AYYweQYIKwYBBQUHAQEEbTBrMCQGCCsGAQUFBzABhhhodHRwOi8vb2NzcC5kaWdp # Y2VydC5jb20wQwYIKwYBBQUHMAKGN2h0dHA6Ly9jYWNlcnRzLmRpZ2ljZXJ0LmNv # bS9EaWdpQ2VydEFzc3VyZWRJRFJvb3RDQS5jcnQwRQYDVR0fBD4wPDA6oDigNoY0 # aHR0cDovL2NybDMuZGlnaWNlcnQuY29tL0RpZ2lDZXJ0QXNzdXJlZElEUm9vdENB # LmNybDARBgNVHSAECjAIMAYGBFUdIAAwDQYJKoZIhvcNAQEMBQADggEBAHCgv0Nc # Vec4X6CjdBs9thbX979XB72arKGHLOyFXqkauyL4hxppVCLtpIh3bb0aFPQTSnov # Lbc47/T/gLn4offyct4kvFIDyE7QKt76LVbP+fT3rDB6mouyXtTP0UNEm0Mh65Zy # oUi0mcudT6cGAxN3J0TU53/oWajwvy8LpunyNDzs9wPHh6jSTEAZNUZqaVSwuKFW # juyk1T3osdz9HNj0d1pcVIxv76FQPfx2CWiEn2/K2yCNNWAcAgPLILCsWKAOQGPF # mCLBsln1VWvPJ6tsds5vIy30fnFqI2si/xK4VC0nftg62fC2h5b9W9FcrBjDTZ9z # twGpn1eqXijiuZQwggXfMIIEx6ADAgECAhBOQOQ3VO3mjAAAAABR05R/MA0GCSqG # SIb3DQEBCwUAMIG+MQswCQYDVQQGEwJVUzEWMBQGA1UEChMNRW50cnVzdCwgSW5j # LjEoMCYGA1UECxMfU2VlIHd3dy5lbnRydXN0Lm5ldC9sZWdhbC10ZXJtczE5MDcG # A1UECxMwKGMpIDIwMDkgRW50cnVzdCwgSW5jLiAtIGZvciBhdXRob3JpemVkIHVz # ZSBvbmx5MTIwMAYDVQQDEylFbnRydXN0IFJvb3QgQ2VydGlmaWNhdGlvbiBBdXRo # b3JpdHkgLSBHMjAeFw0yMTA1MDcxNTQzNDVaFw0zMDExMDcxNjEzNDVaMGkxCzAJ # BgNVBAYTAlVTMRYwFAYDVQQKDA1FbnRydXN0LCBJbmMuMUIwQAYDVQQDDDlFbnRy # dXN0IENvZGUgU2lnbmluZyBSb290IENlcnRpZmljYXRpb24gQXV0aG9yaXR5IC0g # Q1NCUjEwggIiMA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoICAQCngY/3FEW2YkPy # 2K7TJV5IT1G/xX2fUBw10dZ+YSqUGW0nRqSmGl33VFFqgCLGqGZ1TVSDyV5oG6v2 # W2Swra0gvVTvRmttAudFrnX2joq5Mi6LuHccUk15iF+lOhjJUCyXJy2/2gB9Y3/v # MuxGh2Pbmp/DWiE2e/mb1cqgbnIs/OHxnnBNCFYVb5Cr+0i6udfBgniFZS5/tcnA # 4hS3NxFBBuKK4Kj25X62eAUBw2DtTwdBLgoTSeOQm3/dvfqsv2RR0VybtPVc51z/ # O5uloBrXfQmywrf/bhy8yH3m6Sv8crMU6UpVEoScRCV1HfYq8E+lID1oJethl3wP # 5bY9867DwRG8G47M4EcwXkIAhnHjWKwGymUfe5SmS1dnDH5erXhnW1XjXuvH2OxM # bobL89z4n4eqclgSD32m+PhCOTs8LOQyTUmM4OEAwjignPqEPkHcblauxhpb9Gdo # BQHNG7+uh7ydU/Yu6LZr5JnexU+HWKjSZR7IH9Vybu5ZHFc7CXKd18q3kMbNe0WS # kUIDTH0/yvKquMIOhvMQn0YupGaGaFpoGHApOBGAYGuKQ6NzbOOzazf/5p1nAZKG # 3y9I0ftQYNVc/iHTAUJj/u9wtBfAj6ju08FLXxLq/f0uDodEYOOp9MIYo+P9zgyE # Ig3zp3jak/PbOM+5LzPG/wc8Xr5F0wIDAQABo4IBKzCCAScwDgYDVR0PAQH/BAQD # AgGGMBIGA1UdEwEB/wQIMAYBAf8CAQEwHQYDVR0lBBYwFAYIKwYBBQUHAwMGCCsG # AQUFBwMIMDsGA1UdIAQ0MDIwMAYEVR0gADAoMCYGCCsGAQUFBwIBFhpodHRwOi8v # d3d3LmVudHJ1c3QubmV0L3JwYTAzBggrBgEFBQcBAQQnMCUwIwYIKwYBBQUHMAGG # F2h0dHA6Ly9vY3NwLmVudHJ1c3QubmV0MDAGA1UdHwQpMCcwJaAjoCGGH2h0dHA6 # Ly9jcmwuZW50cnVzdC5uZXQvZzJjYS5jcmwwHQYDVR0OBBYEFIK61j2Xzp/PceiS # N6/9s7VpNVfPMB8GA1UdIwQYMBaAFGpyJnrQHu995ztpUdRsjZ+QEmarMA0GCSqG # SIb3DQEBCwUAA4IBAQAfXkEEtoNwJFMsVXMdZTrA7LR7BJheWTgTCaRZlEJeUL9P # bG4lIJCTWEAN9Rm0Yu4kXsIBWBUCHRAJb6jU+5J+Nzg+LxR9jx1DNmSzZhNfFMyl # cfdbIUvGl77clfxwfREc0yHd0CQ5KcX+Chqlz3t57jpv3ty/6RHdFoMI0yyNf02o # FHkvBWFSOOtg8xRofcuyiq3AlFzkJg4sit1Gw87kVlHFVuOFuE2bRXKLB/GK+0m4 # X9HyloFdaVIk8Qgj0tYjD+uL136LwZNr+vFie1jpUJuXbheIDeHGQ5jXgWG2hZ1H # 7LGerj8gO0Od2KIc4NR8CMKvdgb4YmZ6tvf6yK81MIIGgzCCBGugAwIBAgIQNa+3 # e500H2r8j4RGqzE1KzANBgkqhkiG9w0BAQ0FADBpMQswCQYDVQQGEwJVUzEWMBQG # A1UECgwNRW50cnVzdCwgSW5jLjFCMEAGA1UEAww5RW50cnVzdCBDb2RlIFNpZ25p # bmcgUm9vdCBDZXJ0aWZpY2F0aW9uIEF1dGhvcml0eSAtIENTQlIxMB4XDTIxMDUw # NzE5MTk1MloXDTQwMTIyOTIzNTkwMFowYzELMAkGA1UEBhMCVVMxFjAUBgNVBAoT # DUVudHJ1c3QsIEluYy4xPDA6BgNVBAMTM0VudHJ1c3QgRXh0ZW5kZWQgVmFsaWRh # dGlvbiBDb2RlIFNpZ25pbmcgQ0EgLSBFVkNTMjCCAiIwDQYJKoZIhvcNAQEBBQAD # ggIPADCCAgoCggIBAL69pznJpX3sXWXx9Cuph9DnrRrFGjsYzuGhUY1y+s5YH1y4 # JEIPRtUxl9BKTeObMMm6l6ic/kU2zyeA53u4bsEkt9+ndNyF8qMkWEXMlJQ7AuvE # jXxG9VxmguOkwdMfrG4MUyMO1Dr62kLxg1RfNTJW8rV4m1cASB6pYWEnDnMDQ7bW # cJL71IWaMMaz5ppeS+8dKthmqxZG/wvYD6aJSgJRV0E8QThOl8dRMm1njmahXk2f # NSKv1Wq3f0BfaDXMafrxBfDqhabqMoXLwcHKg2lFSQbcCWy6SWUZjPm3NyeMZJ41 # 4+Xs5wegnahyvG+FOiymFk49nM8I5oL1RH0owL2JrWwv3C94eRHXHHBL3Z0ITF4u # +o29p91j9n/wUjGEbjrY2VyFRJ5jBmnQhlh4iZuHu1gcpChsxv5pCpwerBFgal7J # aWUu7UMtafF4tzstNfKqT+If4wFvkEaq1agNBFegtKzjbb2dGyiAJ0bH2qpnlfHR # h3vHyCXphAyPiTbSvjPhhcAz1aA8GYuvOPLlk4C/xsOre5PEPZ257kV2wNRobzBe # PLQ2+ddFQuASBoDbpSH85wV6KI20jmB798i1SkesFGaXoFppcjFXa1OEzWG6cwcV # cDt7AfynP4wtPYeM+wjX5S8Xg36Cq08J8inhflV3ZZQFHVnUCt2TfuMUXeK7AgMB # AAGjggErMIIBJzASBgNVHRMBAf8ECDAGAQH/AgEAMB0GA1UdDgQWBBTOiU+CUaoV # ooRiyjEjYdJh+/j+eDAfBgNVHSMEGDAWgBSCutY9l86fz3Hokjev/bO1aTVXzzAz # BggrBgEFBQcBAQQnMCUwIwYIKwYBBQUHMAGGF2h0dHA6Ly9vY3NwLmVudHJ1c3Qu # bmV0MDEGA1UdHwQqMCgwJqAkoCKGIGh0dHA6Ly9jcmwuZW50cnVzdC5uZXQvY3Ni # cjEuY3JsMA4GA1UdDwEB/wQEAwIBhjATBgNVHSUEDDAKBggrBgEFBQcDAzBEBgNV # HSAEPTA7MDAGBFUdIAAwKDAmBggrBgEFBQcCARYaaHR0cDovL3d3dy5lbnRydXN0 # Lm5ldC9ycGEwBwYFZ4EMAQMwDQYJKoZIhvcNAQENBQADggIBAD4AVLgq849mr2EW # xFiTZPRBi2RVjRs1M6GbkdirRsqrX7y+fnDk0tcHqJYH14bRVwoI0NB4Tfgq37IE # 85rh13zwwQB6wUCh34qMt8u0HQFh8piapt24gwXKqSwW3JwtDv6nl+RQqZeVwUsq # jFHjxALga3w1TVO8S5QTi1MYFl6mCqe4NMFssess5DF9DCzGfOGkVugtdtWyE3Xq # gwCuAHfGb6k97mMUgVAW/FtPEhkOWw+N6kvOBkyJS64gzI5HpnXWZe4vMOhdNI8f # gk1cQqbyFExQIJwJonQkXDnYiTKFPK+M5Wqe5gQ6pRP/qh3NR0suAgW0ao/rhU+B # 7wrbfZ8pj6XCP1I4UkGVO7w+W1QwQiMJY95QjYk1RfqruA+Poq17ehGT8Y8ohHto # eUdq6GQpTR/0HS9tHsiUhjzTWpl6a3yrNfcrOUtPuT8Wku8pjI2rrAEazHFEOctA # PiASzghw40f+3IDXCADRC2rqIbV5ZhfpaqpW3c0VeLEDwBStPkcYde0KU0syk83/ # gLGQ1hPl5EF4Iu1BguUO37DOlSFF5osB0xn39CtVrNlWc2MQ4LigbctUlpigmSFR # BqqmDDorY8t52kO50hLM3o9VeukJ8+Ka0yXBezaS2uDlUmfN4+ZUCqWd1HOj0y9d # BmSFA3d/YNjCvHTJlZFot7d+YRl1MIIGtDCCBJygAwIBAgIQDcesVwX/IZkuQEMi # DDpJhjANBgkqhkiG9w0BAQsFADBiMQswCQYDVQQGEwJVUzEVMBMGA1UEChMMRGln # aUNlcnQgSW5jMRkwFwYDVQQLExB3d3cuZGlnaWNlcnQuY29tMSEwHwYDVQQDExhE # aWdpQ2VydCBUcnVzdGVkIFJvb3QgRzQwHhcNMjUwNTA3MDAwMDAwWhcNMzgwMTE0 # MjM1OTU5WjBpMQswCQYDVQQGEwJVUzEXMBUGA1UEChMORGlnaUNlcnQsIEluYy4x # QTA/BgNVBAMTOERpZ2lDZXJ0IFRydXN0ZWQgRzQgVGltZVN0YW1waW5nIFJTQTQw # OTYgU0hBMjU2IDIwMjUgQ0ExMIICIjANBgkqhkiG9w0BAQEFAAOCAg8AMIICCgKC # AgEAtHgx0wqYQXK+PEbAHKx126NGaHS0URedTa2NDZS1mZaDLFTtQ2oRjzUXMmxC # qvkbsDpz4aH+qbxeLho8I6jY3xL1IusLopuW2qftJYJaDNs1+JH7Z+QdSKWM06qc # hUP+AbdJgMQB3h2DZ0Mal5kYp77jYMVQXSZH++0trj6Ao+xh/AS7sQRuQL37QXbD # hAktVJMQbzIBHYJBYgzWIjk8eDrYhXDEpKk7RdoX0M980EpLtlrNyHw0Xm+nt5pn # YJU3Gmq6bNMI1I7Gb5IBZK4ivbVCiZv7PNBYqHEpNVWC2ZQ8BbfnFRQVESYOszFI # 2Wv82wnJRfN20VRS3hpLgIR4hjzL0hpoYGk81coWJ+KdPvMvaB0WkE/2qHxJ0ucS # 638ZxqU14lDnki7CcoKCz6eum5A19WZQHkqUJfdkDjHkccpL6uoG8pbF0LJAQQZx # st7VvwDDjAmSFTUms+wV/FbWBqi7fTJnjq3hj0XbQcd8hjj/q8d6ylgxCZSKi17y # Vp2NL+cnT6Toy+rN+nM8M7LnLqCrO2JP3oW//1sfuZDKiDEb1AQ8es9Xr/u6bDTn # YCTKIsDq1BtmXUqEG1NqzJKS4kOmxkYp2WyODi7vQTCBZtVFJfVZ3j7OgWmnhFr4 # yUozZtqgPrHRVHhGNKlYzyjlroPxul+bgIspzOwbtmsgY1MCAwEAAaOCAV0wggFZ # MBIGA1UdEwEB/wQIMAYBAf8CAQAwHQYDVR0OBBYEFO9vU0rp5AZ8esrikFb2L9RJ # 7MtOMB8GA1UdIwQYMBaAFOzX44LScV1kTN8uZz/nupiuHA9PMA4GA1UdDwEB/wQE # AwIBhjATBgNVHSUEDDAKBggrBgEFBQcDCDB3BggrBgEFBQcBAQRrMGkwJAYIKwYB # BQUHMAGGGGh0dHA6Ly9vY3NwLmRpZ2ljZXJ0LmNvbTBBBggrBgEFBQcwAoY1aHR0 # cDovL2NhY2VydHMuZGlnaWNlcnQuY29tL0RpZ2lDZXJ0VHJ1c3RlZFJvb3RHNC5j # cnQwQwYDVR0fBDwwOjA4oDagNIYyaHR0cDovL2NybDMuZGlnaWNlcnQuY29tL0Rp # Z2lDZXJ0VHJ1c3RlZFJvb3RHNC5jcmwwIAYDVR0gBBkwFzAIBgZngQwBBAIwCwYJ # YIZIAYb9bAcBMA0GCSqGSIb3DQEBCwUAA4ICAQAXzvsWgBz+Bz0RdnEwvb4LyLU0 # pn/N0IfFiBowf0/Dm1wGc/Do7oVMY2mhXZXjDNJQa8j00DNqhCT3t+s8G0iP5kvN # 2n7Jd2E4/iEIUBO41P5F448rSYJ59Ib61eoalhnd6ywFLerycvZTAz40y8S4F3/a # +Z1jEMK/DMm/axFSgoR8n6c3nuZB9BfBwAQYK9FHaoq2e26MHvVY9gCDA/JYsq7p # GdogP8HRtrYfctSLANEBfHU16r3J05qX3kId+ZOczgj5kjatVB+NdADVZKON/gnZ # ruMvNYY2o1f4MXRJDMdTSlOLh0HCn2cQLwQCqjFbqrXuvTPSegOOzr4EWj7PtspI # HBldNE2K9i697cvaiIo2p61Ed2p8xMJb82Yosn0z4y25xUbI7GIN/TpVfHIqQ6Ku # /qjTY6hc3hsXMrS+U0yy+GWqAXam4ToWd2UQ1KYT70kZjE4YtL8Pbzg0c1ugMZyZ # Zd/BdHLiRu7hAWE6bTEm4XYRkA6Tl4KSFLFk43esaUeqGkH/wyW4N7OigizwJWeu # kcyIPbAvjSabnf7+Pu0VrFgoiovRDiyx3zEdmcif/sYQsfch28bZeUz2rtY/9TCA # 6TD8dC3JE3rYkrhLULy7Dc90G6e8BlqmyIjlgp2+VqsS9/wQD7yFylIz0scmbKvF # oW2jNrbM1pD2T7m3XDCCBu0wggTVoAMCAQICEAqA7xhLjfEFgtHEdqeVdGgwDQYJ # KoZIhvcNAQELBQAwaTELMAkGA1UEBhMCVVMxFzAVBgNVBAoTDkRpZ2lDZXJ0LCBJ # bmMuMUEwPwYDVQQDEzhEaWdpQ2VydCBUcnVzdGVkIEc0IFRpbWVTdGFtcGluZyBS # U0E0MDk2IFNIQTI1NiAyMDI1IENBMTAeFw0yNTA2MDQwMDAwMDBaFw0zNjA5MDMy # MzU5NTlaMGMxCzAJBgNVBAYTAlVTMRcwFQYDVQQKEw5EaWdpQ2VydCwgSW5jLjE7 # MDkGA1UEAxMyRGlnaUNlcnQgU0hBMjU2IFJTQTQwOTYgVGltZXN0YW1wIFJlc3Bv # bmRlciAyMDI1IDEwggIiMA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoICAQDQRqwt # Esae0OquYFazK1e6b1H/hnAKAd/KN8wZQjBjMqiZ3xTWcfsLwOvRxUwXcGx8AUjn # i6bz52fGTfr6PHRNv6T7zsf1Y/E3IU8kgNkeECqVQ+3bzWYesFtkepErvUSbf+EI # YLkrLKd6qJnuzK8Vcn0DvbDMemQFoxQ2Dsw4vEjoT1FpS54dNApZfKY61HAldytx # NM89PZXUP/5wWWURK+IfxiOg8W9lKMqzdIo7VA1R0V3Zp3DjjANwqAf4lEkTlCDQ # 0/fKJLKLkzGBTpx6EYevvOi7XOc4zyh1uSqgr6UnbksIcFJqLbkIXIPbcNmA98Os # kkkrvt6lPAw/p4oDSRZreiwB7x9ykrjS6GS3NR39iTTFS+ENTqW8m6THuOmHHjQN # C3zbJ6nJ6SXiLSvw4Smz8U07hqF+8CTXaETkVWz0dVVZw7knh1WZXOLHgDvundrA # tuvz0D3T+dYaNcwafsVCGZKUhQPL1naFKBy1p6llN3QgshRta6Eq4B40h5avMcpi # 54wm0i2ePZD5pPIssoszQyF4//3DoK2O65Uck5Wggn8O2klETsJ7u8xEehGifgJY # i+6I03UuT1j7FnrqVrOzaQoVJOeeStPeldYRNMmSF3voIgMFtNGh86w3ISHNm0Ia # adCKCkUe2LnwJKa8TIlwCUNVwppwn4D3/Pt5pwIDAQABo4IBlTCCAZEwDAYDVR0T # AQH/BAIwADAdBgNVHQ4EFgQU5Dv88jHt/f3X85FxYxlQQ89hjOgwHwYDVR0jBBgw # FoAU729TSunkBnx6yuKQVvYv1Ensy04wDgYDVR0PAQH/BAQDAgeAMBYGA1UdJQEB # /wQMMAoGCCsGAQUFBwMIMIGVBggrBgEFBQcBAQSBiDCBhTAkBggrBgEFBQcwAYYY # aHR0cDovL29jc3AuZGlnaWNlcnQuY29tMF0GCCsGAQUFBzAChlFodHRwOi8vY2Fj # ZXJ0cy5kaWdpY2VydC5jb20vRGlnaUNlcnRUcnVzdGVkRzRUaW1lU3RhbXBpbmdS # U0E0MDk2U0hBMjU2MjAyNUNBMS5jcnQwXwYDVR0fBFgwVjBUoFKgUIZOaHR0cDov # L2NybDMuZGlnaWNlcnQuY29tL0RpZ2lDZXJ0VHJ1c3RlZEc0VGltZVN0YW1waW5n # UlNBNDA5NlNIQTI1NjIwMjVDQTEuY3JsMCAGA1UdIAQZMBcwCAYGZ4EMAQQCMAsG # CWCGSAGG/WwHATANBgkqhkiG9w0BAQsFAAOCAgEAZSqt8RwnBLmuYEHs0QhEnmNA # ciH45PYiT9s1i6UKtW+FERp8FgXRGQ/YAavXzWjZhY+hIfP2JkQ38U+wtJPBVBaj # YfrbIYG+Dui4I4PCvHpQuPqFgqp1PzC/ZRX4pvP/ciZmUnthfAEP1HShTrY+2DE5 # qjzvZs7JIIgt0GCFD9ktx0LxxtRQ7vllKluHWiKk6FxRPyUPxAAYH2Vy1lNM4kze # kd8oEARzFAWgeW3az2xejEWLNN4eKGxDJ8WDl/FQUSntbjZ80FU3i54tpx5F/0Kr # 15zW/mJAxZMVBrTE2oi0fcI8VMbtoRAmaaslNXdCG1+lqvP4FbrQ6IwSBXkZagHL # hFU9HCrG/syTRLLhAezu/3Lr00GrJzPQFnCEH1Y58678IgmfORBPC1JKkYaEt2Od # Dh4GmO0/5cHelAK2/gTlQJINqDr6JfwyYHXSd+V08X1JUPvB4ILfJdmL+66Gp3CS # BXG6IwXMZUXBhtCyIaehr0XkBoDIGMUG1dUtwq1qmcwbdUfcSYCn+OwncVUXf53V # JUNOaMWMts0VlRYxe5nK+At+DI96HAlXHAL5SlfYxJ7La54i71McVWRP66bW+yER # NpbJCjyCYG2j+bdpxo/1Cy4uPcU3AWVPGrbn5PhDBf3Froguzzhk++ami+r3Qrx5 # bIbY3TVzgiFI7Gq3zWcwggb3MIIE36ADAgECAhBUqhzmzdht2UDqAdaKxc8tMA0G # CSqGSIb3DQEBCwUAMGMxCzAJBgNVBAYTAlVTMRYwFAYDVQQKEw1FbnRydXN0LCBJ # bmMuMTwwOgYDVQQDEzNFbnRydXN0IEV4dGVuZGVkIFZhbGlkYXRpb24gQ29kZSBT # aWduaW5nIENBIC0gRVZDUzIwHhcNMjMxMTExMDIzNDE2WhcNMjYxMTExMDIzNDE1 # WjCB0jELMAkGA1UEBhMCVVMxETAPBgNVBAgTCE5ldyBZb3JrMQ8wDQYDVQQHEwZS # b3NseW4xEzARBgsrBgEEAYI3PAIBAxMCVVMxGTAXBgsrBgEEAYI3PAIBAhMITmV3 # IFlvcmsxHjAcBgNVBAoTFUxJU1MgQ29uc3VsdGluZyBDb3JwLjEdMBsGA1UEDxMU # UHJpdmF0ZSBPcmdhbml6YXRpb24xEDAOBgNVBAUTBzEyMDM3MDQxHjAcBgNVBAMT # FUxJU1MgQ29uc3VsdGluZyBDb3JwLjCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCC # AgoCggIBAKNsPm91CdVgVgztDDAOq1XypBtPfEFiuIjryZikaVh3+iPoixSaa4MA # MZe8gR//KdBwqwyfKHRLj79VfmtcRQJtcuuzfdRXlmnvZOcfwOuhnl7dp3ZyON2B # +m/wTxvRulpTfOf7Xa/XD+vseSMZk5Cr3VGs5c8CnfFPxboSGjxPI5iNfEe/hJvI # BS/aYVL/sZqNdCqarwUCC0YuaVCbOiOlpV1h3hfrVQq9eB5FVI8u7YRh0jetAt96 # LoiYwXxmLdxXtMHAZPhLCfJndTVwOgo6P08j+BFViHtHZGOLgH9gC32OPZvGAM69 # IoessdwAK31fBO/alVk2TBnjjaCMiLD7goDYIP9GzDE+o8rO8pcyse4a1s+uF4By # DiotV0/3L1XFneFA9llG1PgmpU0P7myHJGa2BTUuNcZ5NVNEdINGCg3rDEb2oRje # ukOn83iRtsTnV8kdd4BXuEFptjNqj9M6fvk+LJxsZZ7pKaNGlugPH/hb93+2WXd3 # ImzPCLBOQBs9Ms7rgjlGzfZP/cTJibogaYNYhb6mblEHpm5UhBNrJk9ONRNfDjDB # Lz7eeAWtZGHerL3vpaBHCC4QA1aIKMmolnXjBCAsEhqbJnKZEb/fVjfU7fX5/TQJ # lu+w6AZ6y4rBITex0QMGUlcYh1pnQf0tTikfyH250Gyr1pBaD1rvAgMBAAGjggE1 # MIIBMTAMBgNVHRMBAf8EAjAAMB0GA1UdDgQWBBS8w1GaCwrKaNGXgF9k+1HbSv8Y # uTAfBgNVHSMEGDAWgBTOiU+CUaoVooRiyjEjYdJh+/j+eDBnBggrBgEFBQcBAQRb # MFkwIwYIKwYBBQUHMAGGF2h0dHA6Ly9vY3NwLmVudHJ1c3QubmV0MDIGCCsGAQUF # BzAChiZodHRwOi8vYWlhLmVudHJ1c3QubmV0L2V2Y3MyLWNoYWluLnA3YzAxBgNV # HR8EKjAoMCagJKAihiBodHRwOi8vY3JsLmVudHJ1c3QubmV0L2V2Y3MyLmNybDAO # BgNVHQ8BAf8EBAMCB4AwEwYDVR0lBAwwCgYIKwYBBQUHAwMwIAYDVR0gBBkwFzAH # BgVngQwBAzAMBgpghkgBhvpsCgECMA0GCSqGSIb3DQEBCwUAA4ICAQBoCI/Q8Bgz # wIuP21o96o9uMEbhUfRQ6JBB2/1jfNHJewHbMk9D3ftAEYj7nJSWeLpk8TOSPeeg # tpsG8BEj3KZxDKg08jxWcDMCi0SBh31I3gMQowFh8fD3QjgMpb4gW5r9TZttLn2G # txzBuoamhesLb3Bfr492InciZbSXgipiaKUa5ocj1mOuo9Y8I/SlN8yhuREULW59 # JsvWwcNDInmTyxNuQ/4HoeBzXn7I3CY+rlm4aXOmnhE3Fbe3jINEFkCIROTOQ+Ps # gFlOFaz0gGuT8gfmSxiCrMzE90Nfucuay/RxCRsh9Xqu9uxyHCQCuJ4gvvGj431f # UpCOAzRM/ogk9Udna8Gs22tmCrfMQAT+KNtuewT0EYH4qqpkrAxm9RQwUk7cMG35 # ebua7D3pe4OwKe8TldRibPxKBMWueJll+Ku/jWRIL2urhwD1wqZtguYqoLqXHWQR # bd7nt60I+VxIusDiK80OyHXK7gAy1ibC7eAlpaOTOcJ92RAX6cIzKmutaxZLNZtl # u6n/aSBs7saPOb+848VgadEmBXQzOyRspay8JwQ+7C5Tuqa8/S7Qr6yKD7Sosm31 # ZOk8v59Oy+0Q4YiO0gkua/yZpnxGeutJVYteE8t7muhHk3zoGkMmG/K6CvxK3rxz # LuvDI0xr73Ai+rIuifNtzu4NvT8hBzGkwTGCBlMwggZPAgEBMHcwYzELMAkGA1UE # BhMCVVMxFjAUBgNVBAoTDUVudHJ1c3QsIEluYy4xPDA6BgNVBAMTM0VudHJ1c3Qg # RXh0ZW5kZWQgVmFsaWRhdGlvbiBDb2RlIFNpZ25pbmcgQ0EgLSBFVkNTMgIQVKoc # 5s3YbdlA6gHWisXPLTANBglghkgBZQMEAgEFAKCBhDAYBgorBgEEAYI3AgEMMQow # CKACgAChAoAAMBkGCSqGSIb3DQEJAzEMBgorBgEEAYI3AgEEMBwGCisGAQQBgjcC # AQsxDjAMBgorBgEEAYI3AgEVMC8GCSqGSIb3DQEJBDEiBCBXGZgUin4kkNjN0quS # Zdwig7HwPuERo9CREJgF9zvH8TANBgkqhkiG9w0BAQEFAASCAgB2UqRyG6zkHpTW # 9bVZTZ4lSIOdw7bPWEdG6QEFcor5p0ig0gYxXnVCKL9SiMm9Jl7ICy4kIHv+Hzld # 5ozkewwmhz4tvhsFPell+GvX6VRTBfGybIU5rd7bAj8J1PXiaDuUVi89fBXU1th3 # AWPiMzFGziCh0uht0OlSD1SzCsESZbzG3Ad52X1woJFKzVMDybLdg1pL+iHicu9Y # KLZI/LwPk6hpeklLfo2hX4VS+5YahSdVd00iqPJZOxYWr+EAsd3HSJINxhvP+A9V # hZPjnHyQb3EfGBa4SFgG5s0ILvZMF+8+PyQVTHYMoUb5b9fKVuDL7MXdtyBlRytj # Hx3GCw4JZ5P8nCpkG/doKUYqCTNdlh6jWJozSLk4CzPX0hBmzp6wHwf9VpmDLLCL # CUvWqi9dCipnJkt2/Q/0rlon+ShqLrTeevdr70FqIB+tG3Sr05CkW9ySp4t1scSv # JzVHomhTtAIBCivv0eEMq9urA/itzd5Sjyo8GBijdWu3rEywXJHljmLtqbdDzT6N # eybQw7F5LUaLPXayRTxdGXZhG0oU/DXrro9DDPR38ukWvJeKiVWG4sKkcmiW3QZ1 # wjkHrYMtPefKQOMOWSra9z8LJbjNTBdzCerkPoIV8zp+0OyKUIZYQX0LGEYiwibr # y5a2Psnif8sovCfJq2Z2q/cmbNDUJ6GCAyYwggMiBgkqhkiG9w0BCQYxggMTMIID # DwIBATB9MGkxCzAJBgNVBAYTAlVTMRcwFQYDVQQKEw5EaWdpQ2VydCwgSW5jLjFB # MD8GA1UEAxM4RGlnaUNlcnQgVHJ1c3RlZCBHNCBUaW1lU3RhbXBpbmcgUlNBNDA5 # NiBTSEEyNTYgMjAyNSBDQTECEAqA7xhLjfEFgtHEdqeVdGgwDQYJYIZIAWUDBAIB # BQCgaTAYBgkqhkiG9w0BCQMxCwYJKoZIhvcNAQcBMBwGCSqGSIb3DQEJBTEPFw0y # NjA0MjQyMzIyMzZaMC8GCSqGSIb3DQEJBDEiBCA8Xbgm/4xv3ADs5WuPmjfEeGHK # eq8UVDa/e8OKciQFcTANBgkqhkiG9w0BAQEFAASCAgBzEHWAIz3nZzewrKnEV97v # vLCoe0P+7wtW4G9AR9whqmYvzjuZ6MVkX5EqRPWgbgHbdDZeqIdzflpKWHi5HzuV # kDPRzkx42b/LgeetxlU9+GOeyTT1GW6cIWywDJmxI77fdrC6El/40YjwegLMEDBX # ivn0LEth7IXHA6PXTdW5lnF2TmG/IMU7jeuTC9JWsgFdkcNCU4lkn5J39j5mLlI5 # ewS4XIF4r1WkNSdkpt8tUkgV8PCIrB7kvPANq6qQt4nx/CADnb9kqSSoLCNiZWQ5 # 97/fhJoGNcRYGmLjVnFUZPYo/Oxo1puGiR2aZORPlXIxu2RzshQURaLO5sgSxkeo # 5IBMqnAcVWqimdJv7gjVq26/brnoclCPFiNbZcGG1x6Nhlp3SpFnBvV6eCJreqxn # 8nwK5wHxgT8yAZMEjin24SeqtXd3IRIs8/IqM2KVdsuUV6G2ewB434s+wAgQ1UM7 # 1SKx2UjtiHySg4Gvj4hI1NexUIvde+8ttjBe3bfwNNctuGLnbhkkCwevWW3BtCTN # IAjR/vDfdyUfr9L+GAprVqSV6XDylhDdxvMAmGSAJsdNdmCkfDNRUTwZB/Vx16dp # 3i0SiN40W8OEhz6V21+gyovVUmrewhkSPEUq8NL6l6mmiRF7rQ3k9MPbm46XTh4n # fKqP2YJ0E1IQX/nw+/HYWg== # SIG # End signature block |