{"id":1617,"date":"2026-04-25T19:22:51","date_gmt":"2026-04-25T19:22:51","guid":{"rendered":"https:\/\/kemora.fi\/?page_id=1617"},"modified":"2026-04-26T07:57:10","modified_gmt":"2026-04-26T07:57:10","slug":"1617-2","status":"publish","type":"page","link":"https:\/\/kemora.fi\/en\/1617-2\/","title":{"rendered":""},"content":{"rendered":"\n<!DOCTYPE html>\n<html lang=\"fi\">\n<head>\n    <meta charset=\"UTF-8\">\n    <meta name=\"viewport\" content=\"width=device-width, initial-scale=1.0\">\n    <title>Interaktiivinen Ratakartta &#8211; Kemora<\/title>\n    \n    <link rel=\"stylesheet\" href=\"https:\/\/unpkg.com\/leaflet@1.9.4\/dist\/leaflet.css\" \/>\n    \n    <style>\n        :root {\n            --primary-dark: #222222;\n            --accent-orange: #FD9800;\n        }\n\n        \/* Esikatselulaatikko sivulla *\/\n        .preview-box {\n            max-width: 500px;\n            margin: 50px auto;\n            border: 3px solid var(--accent-orange);\n            cursor: pointer;\n            background: #000;\n        }\n        .preview-box img { width: 100%; display: block; }\n\n       \/* 1. Muutetaan overlayn tausta l\u00e4pin\u00e4kyv\u00e4ksi *\/\n#map-overlay {\n    display: none;\n    position: fixed !important;\n    top: 0 !important;\n    left: 0 !important;\n    width: 100vw !important;\n    height: 100vh !important;\n    background: rgba(0, 0, 0, 0) !important; \/* T\u00e4ysin l\u00e4pin\u00e4kyv\u00e4 *\/\n    z-index: 99999 !important;\n    margin: 0 !important;\n    padding: 0 !important;\n}\n\/* 2. Poistetaan Leafletin oletustaustat kaikilta tasoilta *\/\n#map-container, \n.leaflet-container, \n.leaflet-pane, \n.leaflet-tile-pane {\n    background: transparent !important;\n    background-color: rgba(0, 0, 0, 0) !important;\n}\n\n        \/* SULKUNAPPI - Pakotettu oikeaan yl\u00e4kulmaan *\/\n        #close-map {\n            position: fixed !important;\n            top: 30px !important;\n            right: 30px !important;\n            z-index: 100001 !important;\n            background: var(--accent-orange) !important;\n            color: white !important;\n            border: none !important;\n            font-size: 35px !important;\n            width: 60px !important;\n            height: 60px !important;\n            border-radius: 8px !important;\n            cursor: pointer !important;\n            display: flex !important;\n            align-items: center !important;\n            justify-content: center !important;\n            box-shadow: 0 5px 20px rgba(0,0,0,0.6) !important;\n        }\n\n        \/* MINIMAP - Pakotettu oikeaan alakulmaan *\/\n        #minimap-ui {\n            position: fixed !important;\n            bottom: 30px !important;\n            right: 30px !important;\n            width: 280px !important;\n            height: 110px !important;\n            z-index: 100000 !important;\n            border: 2px solid var(--accent-orange) !important;\n            background-color: rgba(0,0,0,0.8) !important;\n            background-size: contain !important;\n            background-repeat: no-repeat !important;\n            background-position: center !important;\n            pointer-events: none !important;\n            overflow: hidden !important;\n        }\n\n        #aim-box {\n            border: 2px solid var(--accent-orange);\n            position: absolute;\n            background: rgba(253, 152, 0, 0.1);\n        }\n\n        \/* Poistetaan Leafletin oletuskerrokset jotka voivat aiheuttaa \"savua\" *\/\n        .leaflet-pane, .leaflet-control-container {\n            z-index: 10 !important;\n        }\n        .leaflet-container {\n            background: #000 !important;\n            outline: none !important;\n        }\n        \n        \/* HD H\u00e4ivytys *\/\n        .hd-img { transition: opacity 1s ease; opacity: 0; }\n        .hd-ready { opacity: 1; }\n    <\/style>\n<\/head>\n<body>\n\n    <div class=\"preview-box\" onclick=\"launchMap()\">\n        <img decoding=\"async\" src=\"https:\/\/kemora.fi\/wp-content\/uploads\/2026\/04\/Kemora-kartta-v3-3-scaled.webp\">\n    <\/div>\n\n    <div id=\"map-overlay\">\n        <button id=\"close-map\" onclick=\"exitMap()\">&times;<\/button>\n        \n        <div id=\"map-container\"><\/div>\n        \n        <div id=\"minimap-ui\" style=\"background-image: url('https:\/\/kemora.fi\/wp-content\/uploads\/2026\/04\/Kemora-kartta-v3-3-scaled.webp');\">\n            <div id=\"aim-box\"><\/div>\n        <\/div>\n    <\/div>\n\n    <script src=\"https:\/\/unpkg.com\/leaflet@1.9.4\/dist\/leaflet.js\"><\/script>\n\n    <script>\n        let trackMap;\n        const imgW = 6467, imgH = 2563;\n        const lowRes = 'https:\/\/kemora.fi\/wp-content\/uploads\/2026\/04\/Kemora-kartta-v3-3-scaled.webp';\n        const highRes = 'https:\/\/kemora.fi\/wp-content\/uploads\/2026\/04\/Kemora-kartta-v3-2.webp';\n\n        function launchMap() {\n            document.getElementById('map-overlay').style.display = 'block';\n            document.body.style.overflow = 'hidden';\n\n            if (!trackMap) {\n                initTrack();\n            } else {\n                refreshMap();\n            }\n        }\n\n        function exitMap() {\n            document.getElementById('map-overlay').style.display = 'none';\n            document.body.style.overflow = 'auto';\n        }\n\n        function refreshMap() {\n            setTimeout(() => {\n                trackMap.invalidateSize();\n                const bounds = [[-imgH, 0], [0, imgW]];\n                trackMap.fitBounds(bounds, { padding: [0,0] });\n            }, 150);\n        }\n\n        function initTrack() {\n            trackMap = L.map('map-container', {\n                crs: L.CRS.Simple,\n                minZoom: -3,\n                maxZoom: 2,\n                zoomSnap: 0,\n                attributionControl: false,\n                maxBoundsViscosity: 1.0\n            });\n\n            const bounds = [[-imgH, 0], [0, imgW]];\n            \n            \/\/ 1. Matala reso\n            const lowLayer = L.imageOverlay(lowRes, bounds).addTo(trackMap);\n            trackMap.fitBounds(bounds);\n            refreshMap();\n\n            \/\/ 2. HD lataus\n            const hdImgObj = new Image();\n            hdImgObj.src = highRes;\n            hdImgObj.onload = () => {\n                const hdLayer = L.imageOverlay(highRes, bounds, { className: 'hd-img' }).addTo(trackMap);\n                setTimeout(() => {\n                    hdLayer.getElement().classList.add('hd-ready');\n                    setTimeout(() => trackMap.removeLayer(lowLayer), 1000);\n                }, 200);\n            };\n\n            \/\/ 3. Minimap seuranta\n            const aim = document.getElementById('aim-box');\n            const mmWidth = 280;\n            const mmHeight = 110;\n\n            trackMap.on('move', () => {\n                const b = trackMap.getBounds();\n                \n                \/\/ Lasketaan sijainti suhteessa kuvan mittoihin\n                const leftPercent = b.getWest() \/ imgW;\n                const topPercent = Math.abs(b.getNorth()) \/ imgH;\n                const widthPercent = (b.getEast() - b.getWest()) \/ imgW;\n                const heightPercent = (b.getNorth() - b.getSouth()) \/ imgH;\n\n                aim.style.left = (leftPercent * mmWidth) + \"px\";\n                aim.style.top = (topPercent * mmHeight) + \"px\";\n                aim.style.width = (widthPercent * mmWidth) + \"px\";\n                aim.style.height = (heightPercent * mmHeight) + \"px\";\n            });\n        }\n\n        window.onkeydown = e => { if(e.key === 'Escape') exitMap(); };\n    <\/script>\n<\/body>\n<\/html>\n","protected":false},"excerpt":{"rendered":"<p>Interaktiivinen Ratakartta &#8211; Kemora &times;<\/p>","protected":false},"author":1,"featured_media":0,"parent":0,"menu_order":0,"comment_status":"closed","ping_status":"closed","template":"","meta":{"_monsterinsights_skip_tracking":false,"_monsterinsights_sitenote_active":false,"_monsterinsights_sitenote_note":"","_monsterinsights_sitenote_category":0,"site-sidebar-layout":"default","site-content-layout":"","ast-site-content-layout":"default","site-content-style":"default","site-sidebar-style":"default","ast-global-header-display":"","ast-banner-title-visibility":"","ast-main-header-display":"","ast-hfb-above-header-display":"","ast-hfb-below-header-display":"","ast-hfb-mobile-header-display":"","site-post-title":"","ast-breadcrumbs-content":"","ast-featured-img":"","footer-sml-layout":"","ast-disable-related-posts":"","theme-transparent-header-meta":"","adv-header-id-meta":"","stick-header-meta":"","header-above-stick-meta":"","header-main-stick-meta":"","header-below-stick-meta":"","astra-migrate-meta-layouts":"set","ast-page-background-enabled":"default","ast-page-background-meta":{"desktop":{"background-color":"","background-image":"","background-repeat":"repeat","background-position":"center center","background-size":"auto","background-attachment":"scroll","background-type":"","background-media":"","overlay-type":"","overlay-color":"","overlay-opacity":"","overlay-gradient":""},"tablet":{"background-color":"","background-image":"","background-repeat":"repeat","background-position":"center center","background-size":"auto","background-attachment":"scroll","background-type":"","background-media":"","overlay-type":"","overlay-color":"","overlay-opacity":"","overlay-gradient":""},"mobile":{"background-color":"","background-image":"","background-repeat":"repeat","background-position":"center center","background-size":"auto","background-attachment":"scroll","background-type":"","background-media":"","overlay-type":"","overlay-color":"","overlay-opacity":"","overlay-gradient":""}},"ast-content-background-meta":{"desktop":{"background-color":"var(--ast-global-color-5)","background-image":"","background-repeat":"repeat","background-position":"center center","background-size":"auto","background-attachment":"scroll","background-type":"","background-media":"","overlay-type":"","overlay-color":"","overlay-opacity":"","overlay-gradient":""},"tablet":{"background-color":"var(--ast-global-color-5)","background-image":"","background-repeat":"repeat","background-position":"center center","background-size":"auto","background-attachment":"scroll","background-type":"","background-media":"","overlay-type":"","overlay-color":"","overlay-opacity":"","overlay-gradient":""},"mobile":{"background-color":"var(--ast-global-color-5)","background-image":"","background-repeat":"repeat","background-position":"center center","background-size":"auto","background-attachment":"scroll","background-type":"","background-media":"","overlay-type":"","overlay-color":"","overlay-opacity":"","overlay-gradient":""}},"footnotes":""},"class_list":["post-1617","page","type-page","status-publish","hentry"],"yoast_head":"<!-- This site is optimized with the Yoast SEO plugin v27.7 - https:\/\/yoast.com\/product\/yoast-seo-wordpress\/ -->\n<title>- kemora<\/title>\n<meta name=\"robots\" content=\"index, follow, max-snippet:-1, max-image-preview:large, max-video-preview:-1\" \/>\n<link rel=\"canonical\" href=\"https:\/\/kemora.fi\/en\/1617-2\/\" \/>\n<meta property=\"og:locale\" content=\"en_US\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"- kemora\" \/>\n<meta property=\"og:description\" content=\"Interaktiivinen Ratakartta &#8211; Kemora &times;\" \/>\n<meta property=\"og:url\" content=\"https:\/\/kemora.fi\/en\/1617-2\/\" \/>\n<meta property=\"og:site_name\" content=\"kemora\" \/>\n<meta property=\"article:modified_time\" content=\"2026-04-26T07:57:10+00:00\" \/>\n<meta property=\"og:image\" content=\"https:\/\/kemora.fi\/wp-content\/uploads\/2026\/04\/Kemora-kartta-v3-3-scaled.webp\" \/>\n<meta name=\"twitter:card\" content=\"summary_large_image\" \/>\n<meta name=\"twitter:label1\" content=\"Est. reading time\" \/>\n\t<meta name=\"twitter:data1\" content=\"1 minute\" \/>\n<script type=\"application\/ld+json\" class=\"yoast-schema-graph\">{\"@context\":\"https:\\\/\\\/schema.org\",\"@graph\":[{\"@type\":\"WebPage\",\"@id\":\"https:\\\/\\\/kemora.fi\\\/1617-2\\\/\",\"url\":\"https:\\\/\\\/kemora.fi\\\/1617-2\\\/\",\"name\":\"- kemora\",\"isPartOf\":{\"@id\":\"https:\\\/\\\/kemora.fi\\\/#website\"},\"primaryImageOfPage\":{\"@id\":\"https:\\\/\\\/kemora.fi\\\/1617-2\\\/#primaryimage\"},\"image\":{\"@id\":\"https:\\\/\\\/kemora.fi\\\/1617-2\\\/#primaryimage\"},\"thumbnailUrl\":\"https:\\\/\\\/kemora.fi\\\/wp-content\\\/uploads\\\/2026\\\/04\\\/Kemora-kartta-v3-3-scaled.webp\",\"datePublished\":\"2026-04-25T19:22:51+00:00\",\"dateModified\":\"2026-04-26T07:57:10+00:00\",\"inLanguage\":\"en-US\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\\\/\\\/kemora.fi\\\/1617-2\\\/\"]}]},{\"@type\":\"ImageObject\",\"inLanguage\":\"en-US\",\"@id\":\"https:\\\/\\\/kemora.fi\\\/1617-2\\\/#primaryimage\",\"url\":\"https:\\\/\\\/kemora.fi\\\/wp-content\\\/uploads\\\/2026\\\/04\\\/Kemora-kartta-v3-3-scaled.webp\",\"contentUrl\":\"https:\\\/\\\/kemora.fi\\\/wp-content\\\/uploads\\\/2026\\\/04\\\/Kemora-kartta-v3-3-scaled.webp\"},{\"@type\":\"WebSite\",\"@id\":\"https:\\\/\\\/kemora.fi\\\/#website\",\"url\":\"https:\\\/\\\/kemora.fi\\\/\",\"name\":\"kemora\",\"description\":\"Moottorirata Keskipohjanmaalla\",\"publisher\":{\"@id\":\"https:\\\/\\\/kemora.fi\\\/#organization\"},\"potentialAction\":[{\"@type\":\"SearchAction\",\"target\":{\"@type\":\"EntryPoint\",\"urlTemplate\":\"https:\\\/\\\/kemora.fi\\\/?s={search_term_string}\"},\"query-input\":{\"@type\":\"PropertyValueSpecification\",\"valueRequired\":true,\"valueName\":\"search_term_string\"}}],\"inLanguage\":\"en-US\"},{\"@type\":\"Organization\",\"@id\":\"https:\\\/\\\/kemora.fi\\\/#organization\",\"name\":\"Kemora\",\"url\":\"https:\\\/\\\/kemora.fi\\\/\",\"logo\":{\"@type\":\"ImageObject\",\"inLanguage\":\"en-US\",\"@id\":\"https:\\\/\\\/kemora.fi\\\/#\\\/schema\\\/logo\\\/image\\\/\",\"url\":\"https:\\\/\\\/kemora.fi\\\/wp-content\\\/uploads\\\/2025\\\/06\\\/kemora-ei-taustaa.webp\",\"contentUrl\":\"https:\\\/\\\/kemora.fi\\\/wp-content\\\/uploads\\\/2025\\\/06\\\/kemora-ei-taustaa.webp\",\"width\":788,\"height\":638,\"caption\":\"Kemora\"},\"image\":{\"@id\":\"https:\\\/\\\/kemora.fi\\\/#\\\/schema\\\/logo\\\/image\\\/\"}}]}<\/script>\n<!-- \/ Yoast SEO plugin. -->","yoast_head_json":{"title":"- kemora","robots":{"index":"index","follow":"follow","max-snippet":"max-snippet:-1","max-image-preview":"max-image-preview:large","max-video-preview":"max-video-preview:-1"},"canonical":"https:\/\/kemora.fi\/en\/1617-2\/","og_locale":"en_US","og_type":"article","og_title":"- kemora","og_description":"Interaktiivinen Ratakartta &#8211; Kemora &times;","og_url":"https:\/\/kemora.fi\/en\/1617-2\/","og_site_name":"kemora","article_modified_time":"2026-04-26T07:57:10+00:00","og_image":[{"url":"https:\/\/kemora.fi\/wp-content\/uploads\/2026\/04\/Kemora-kartta-v3-3-scaled.webp","type":"","width":"","height":""}],"twitter_card":"summary_large_image","twitter_misc":{"Est. reading time":"1 minute"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"WebPage","@id":"https:\/\/kemora.fi\/1617-2\/","url":"https:\/\/kemora.fi\/1617-2\/","name":"- kemora","isPartOf":{"@id":"https:\/\/kemora.fi\/#website"},"primaryImageOfPage":{"@id":"https:\/\/kemora.fi\/1617-2\/#primaryimage"},"image":{"@id":"https:\/\/kemora.fi\/1617-2\/#primaryimage"},"thumbnailUrl":"https:\/\/kemora.fi\/wp-content\/uploads\/2026\/04\/Kemora-kartta-v3-3-scaled.webp","datePublished":"2026-04-25T19:22:51+00:00","dateModified":"2026-04-26T07:57:10+00:00","inLanguage":"en-US","potentialAction":[{"@type":"ReadAction","target":["https:\/\/kemora.fi\/1617-2\/"]}]},{"@type":"ImageObject","inLanguage":"en-US","@id":"https:\/\/kemora.fi\/1617-2\/#primaryimage","url":"https:\/\/kemora.fi\/wp-content\/uploads\/2026\/04\/Kemora-kartta-v3-3-scaled.webp","contentUrl":"https:\/\/kemora.fi\/wp-content\/uploads\/2026\/04\/Kemora-kartta-v3-3-scaled.webp"},{"@type":"WebSite","@id":"https:\/\/kemora.fi\/#website","url":"https:\/\/kemora.fi\/","name":"kemora","description":"Moottorirata Keskipohjanmaalla","publisher":{"@id":"https:\/\/kemora.fi\/#organization"},"potentialAction":[{"@type":"SearchAction","target":{"@type":"EntryPoint","urlTemplate":"https:\/\/kemora.fi\/?s={search_term_string}"},"query-input":{"@type":"PropertyValueSpecification","valueRequired":true,"valueName":"search_term_string"}}],"inLanguage":"en-US"},{"@type":"Organization","@id":"https:\/\/kemora.fi\/#organization","name":"Kemora","url":"https:\/\/kemora.fi\/","logo":{"@type":"ImageObject","inLanguage":"en-US","@id":"https:\/\/kemora.fi\/#\/schema\/logo\/image\/","url":"https:\/\/kemora.fi\/wp-content\/uploads\/2025\/06\/kemora-ei-taustaa.webp","contentUrl":"https:\/\/kemora.fi\/wp-content\/uploads\/2025\/06\/kemora-ei-taustaa.webp","width":788,"height":638,"caption":"Kemora"},"image":{"@id":"https:\/\/kemora.fi\/#\/schema\/logo\/image\/"}}]}},"_links":{"self":[{"href":"https:\/\/kemora.fi\/en\/wp-json\/wp\/v2\/pages\/1617","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/kemora.fi\/en\/wp-json\/wp\/v2\/pages"}],"about":[{"href":"https:\/\/kemora.fi\/en\/wp-json\/wp\/v2\/types\/page"}],"author":[{"embeddable":true,"href":"https:\/\/kemora.fi\/en\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/kemora.fi\/en\/wp-json\/wp\/v2\/comments?post=1617"}],"version-history":[{"count":17,"href":"https:\/\/kemora.fi\/en\/wp-json\/wp\/v2\/pages\/1617\/revisions"}],"predecessor-version":[{"id":1638,"href":"https:\/\/kemora.fi\/en\/wp-json\/wp\/v2\/pages\/1617\/revisions\/1638"}],"wp:attachment":[{"href":"https:\/\/kemora.fi\/en\/wp-json\/wp\/v2\/media?parent=1617"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}