:root{--bg:#ECEEF1;--bg-alt:#E2E5EA;--text:#2B3240;--accent:#6B7B9E;--accent-dk:#536180;--muted:#5B8A8A;--serif:'Lora', serif;--sans:'Source Sans 3', sans-serif}*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%}body{background-color:var(--bg);color:var(--text);font-family:var(--sans);font-size:1rem;line-height:1.6}h1,h2,h3,h4{font-family:var(--serif);color:var(--text);line-height:1.25;margin-bottom:.5em}h1{font-size:2.25rem}h2{font-size:1.75rem}h3{font-size:1.35rem}h4{font-size:1.1rem}p{margin-bottom:1em}a{color:var(--accent);text-decoration:none;transition:color .2s ease}a:hover,a:focus{color:var(--accent-dk);text-decoration:underline}img{max-width:100%;height:auto;display:block}.site-nav{position:sticky;top:0;z-index:100;padding:1rem 1.5rem;background-color:var(--bg)}.site-nav__home{font-family:var(--serif);font-size:1.25rem;font-weight:700;color:var(--text)}.site-nav__home:hover{color:var(--accent);text-decoration:none}main{max-width:900px;margin:0 auto;padding:2rem 1.5rem}.site-footer{max-width:900px;margin:0 auto;padding:2rem 1.5rem;border-top:1px solid rgba(0,0,0,8%);text-align:center;font-size:.85rem;color:rgba(43,50,64,.6)}@media(max-width:768px){h1{font-size:1.75rem}h2{font-size:1.4rem}h3{font-size:1.15rem}.site-nav{padding:.75rem 1rem}main{padding:1.5rem 1rem}.kohde-page{padding:1.5rem 1.25rem;border-radius:0;box-shadow:none}}@media(min-width:769px) and (max-width:1024px){main{padding:2rem}}.kohde-page{max-width:800px;margin:0 auto;padding:2rem 1rem;background:#fff;border-radius:.5rem;box-shadow:0 1px 4px rgba(0,0,0,6%);padding:2.5rem}.kohde-header{margin-bottom:2rem}.kohde-header h1{margin-bottom:.5rem}.kohde-meta{display:flex;gap:1rem;font-size:1.1rem;color:var(--muted);margin-bottom:.75rem}.kohde-kunta::before{content:"📍 "}.kohde-reviewed{color:var(--muted);font-size:.85rem}.kohde-tags{display:flex;flex-wrap:wrap;gap:.5rem}.kohde-tag{background:var(--bg-alt);color:var(--text);padding:.2rem .75rem;border-radius:1rem;font-size:.85rem;font-family:var(--sans)}.kohde-gallery{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1rem;margin-bottom:2rem}.kohde-gallery figure{margin:0}.kohde-gallery img{width:100%;height:auto;border-radius:.5rem;box-shadow:0 2px 8px rgba(0,0,0,.1)}.kohde-gallery figcaption{font-size:.85rem;color:var(--muted);margin-top:.4rem;font-style:italic}.kohde-body{font-size:1.05rem;line-height:1.7;margin-bottom:2rem}.kohde-sources,.kohde-parking,.kohde-facilities,.kohde-nav{margin-bottom:2rem}.kohde-sources h2,.kohde-parking h2,.kohde-facilities h2,.kohde-maps h2,.kohde-nav h2{font-size:1.1rem;font-family:var(--sans);font-weight:600;margin-bottom:.75rem}.kohde-facilities-list{list-style:none;padding:0;display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:.75rem}.kohde-facilities-list li{background:var(--bg);padding:.75rem 1rem;border-radius:.5rem}.kohde-maps{margin-bottom:2rem}.kohde-location{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem}.kohde-coords{font-family:var(--sans);font-size:.85rem;color:var(--text);background:var(--bg);padding:.35rem .7rem;border-radius:.3rem;border:1px dashed var(--bg-alt);cursor:pointer;transition:border-color .2s}.kohde-coords:hover{border-color:var(--accent)}.kohde-coords--copied{border-color:var(--muted)}.kohde-embed-map{width:100%;height:300px;border-radius:.4rem;margin-bottom:1rem;border:1px solid var(--bg-alt)}.kohde-map-thumbs{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.75rem;margin-bottom:1rem}.kohde-map-thumb{display:block;text-decoration:none;border-radius:.4rem;overflow:hidden;background:var(--bg);box-shadow:0 1px 4px rgba(0,0,0,.1);transition:box-shadow .2s,transform .15s}.kohde-map-thumb:hover{box-shadow:0 3px 12px rgba(0,0,0,.15);transform:translateY(-2px);text-decoration:none}.kohde-map-thumb img{width:100%;height:120px;object-fit:cover;display:block}.kohde-map-thumb__label{display:block;padding:.35rem .5rem;font-family:var(--sans);font-size:.75rem;color:var(--text);text-align:center;line-height:1.3}.kohde-map-links{display:flex;flex-wrap:wrap;gap:.75rem}.kohde-map-link{display:inline-block;background:var(--accent);color:var(--bg);padding:.6rem 1.2rem;border-radius:.4rem;text-decoration:none;font-family:var(--sans);font-weight:600;transition:background-color .2s}.kohde-map-link:hover{background:var(--accent-dk);color:var(--bg);text-decoration:none}.kohde-source-links{display:flex;flex-wrap:wrap;gap:.75rem}.kohde-source-link{display:inline-block;background:var(--bg-alt);color:var(--text);padding:.5rem 1rem;border-radius:.4rem;text-decoration:none;font-family:var(--sans);font-size:.9rem;transition:background-color .2s}.kohde-source-link:hover{background:var(--accent);color:#fff;text-decoration:none}.kohteet-page{max-width:1100px;margin:0 auto;padding:2rem 1rem}.kohteet-page h1{margin-bottom:2rem}.kohteet-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1.5rem}.kohde-card{display:block;background:#fff;border-radius:.75rem;overflow:hidden;text-decoration:none;color:var(--text);box-shadow:0 2px 8px rgba(0,0,0,8%);transition:transform .2s,box-shadow .2s}.kohde-card:hover{transform:translateY(-3px);box-shadow:0 4px 16px rgba(0,0,0,.12);text-decoration:none;color:var(--text)}.kohde-card__image img{width:100%;height:200px;object-fit:cover;display:block}.kohde-card__placeholder{width:100%;height:200px;background:linear-gradient(135deg,var(--accent),var(--muted));display:flex;align-items:center;justify-content:center}.kohde-card__placeholder span{font-family:var(--serif);font-size:3rem;color:var(--bg);opacity:.8}.kohde-card__content{padding:1rem 1.25rem 1.25rem}.kohde-card__title{font-family:var(--serif);font-size:1.15rem;margin:0 0 .4rem}.kohde-card__kunta{font-size:.9rem;color:var(--muted)}.kohde-card__ala{font-size:.9rem;color:var(--muted);margin-left:.75rem}.kohde-card__tags{display:flex;gap:.4rem;margin-top:.6rem}@media(max-width:768px){.kohteet-grid{grid-template-columns:1fr}}main:has(.kartta-page){max-width:none;padding:0 15px 15px}body:has(.kartta-page) .site-footer{display:none}.kartta-page{position:relative;width:100%;height:calc(100dvh - 3rem - 15px)}#map{width:100%;height:100%}.map--popup-open .leaflet-control-container{opacity:0;pointer-events:none;transition:opacity .2s}.map--popup-open .map-crosshair{opacity:0}.map--popup-open .map-coords-bar{opacity:0;pointer-events:none}@media(max-width:768px){.leaflet-control-zoom{display:none}}.leaflet-container{font-family:var(--sans)}.map-tooltip{background:var(--bg);color:var(--text);border:1px solid var(--bg-alt);box-shadow:0 2px 8px rgba(0,0,0,.12);font-family:var(--serif);font-size:.95rem;padding:.3rem .6rem;border-radius:.3rem}.map-popup-container .leaflet-popup-content-wrapper{background:var(--bg);color:var(--text);border-radius:.5rem;box-shadow:0 4px 20px rgba(0,0,0,.15)}.map-popup-container .leaflet-popup-tip{background:var(--bg)}.map-popup-container .leaflet-popup-content{margin:0;max-height:50vh;overflow-y:auto}.map-popup{padding:1rem 1.25rem}.map-popup h3{font-family:var(--serif);font-size:1.2rem;margin:0 0 .4rem;line-height:1.3}.map-popup h3 a{color:var(--text);text-decoration:none}.map-popup h3 a:hover{color:var(--accent)}.map-popup__meta{font-size:.9rem;color:var(--muted);margin:0 0 .5rem}.map-popup__desc{font-size:.85rem;line-height:1.45;color:var(--text);margin:0 0 .6rem}.map-popup__facilities{font-size:.8rem;color:var(--muted);margin-bottom:.6rem;line-height:1.4}.map-popup__reviewed{color:var(--muted);font-size:.85em;font-weight:400}.map-popup__tags{display:flex;flex-wrap:wrap;gap:.35rem;margin-bottom:.6rem}.map-popup__tag{background:var(--bg-alt);color:var(--text);padding:.15rem .5rem;border-radius:.8rem;font-size:.72rem;font-family:var(--sans)}.map-popup__links{display:flex;gap:.75rem;padding-top:.5rem;border-top:1px solid var(--bg-alt)}.map-popup__link{font-size:.8rem;font-weight:600;color:var(--accent);text-decoration:none}.map-popup__link:hover{color:var(--accent-dk);text-decoration:underline}.map-crosshair{pointer-events:none;position:absolute;top:50%;left:50%;width:28px;height:28px;transform:translate(-50%,-50%);z-index:1000}.map-crosshair::before,.map-crosshair::after{content:'';position:absolute;background:rgba(43,50,64,.5)}.map-crosshair::before{top:0;left:50%;width:2px;height:100%;transform:translateX(-50%)}.map-crosshair::after{top:50%;left:0;width:100%;height:2px;transform:translateY(-50%)}.map-coords-bar{background:var(--bg);padding:.3rem .7rem;border-radius:.3rem;box-shadow:0 2px 8px rgba(0,0,0,.15);font-family:var(--sans);font-size:.78rem;color:var(--text);cursor:pointer;user-select:none;transition:border-color .2s;border:1px solid transparent;display:flex;gap:1.2rem;align-items:center}.map-coords-bar:hover{border-color:var(--accent)}.map-coords-bar--copied{border-color:var(--muted)}.map-coords-bar span{white-space:nowrap}.map-coords-bar .coords-label{color:rgba(43,50,64,.5);font-size:.7rem}.map-toggle{background:var(--bg);padding:.4rem .7rem;border-radius:.4rem;box-shadow:0 2px 8px rgba(0,0,0,.15);font-family:var(--sans);font-size:.8rem;color:var(--text)}.map-toggle label{display:flex;align-items:center;gap:.4rem;cursor:pointer;user-select:none}.map-toggle input[type=checkbox]{accent-color:var(--accent)}.kunta-tooltip{background:rgba(236,238,241,.9);color:var(--accent-dk);border:none;box-shadow:0 1px 4px rgba(0,0,0,.1);font-family:var(--sans);font-size:.8rem;font-weight:600;padding:.2rem .5rem;border-radius:.2rem}.map-label{background:0 0;border:none;white-space:nowrap}.map-label span{font-family:var(--sans);font-size:.75rem;font-weight:600;color:var(--text);background:rgba(236,238,241,.9);padding:.1rem .4rem;border-radius:.2rem;box-shadow:0 1px 3px rgba(0,0,0,.15)}.map-search{margin:10px 0 0 10px}.map-search__input{width:220px;padding:.5rem .75rem;border:1px solid rgba(0,0,0,.15);border-radius:.4rem;background:var(--bg);font-family:var(--sans);font-size:.9rem;color:var(--text);box-shadow:0 2px 8px rgba(0,0,0,.12);outline:none}.map-search__input:focus{border-color:var(--accent);box-shadow:0 2px 8px rgba(0,0,0,.12),0 0 0 2px rgba(107,123,158,.25)}.map-search__input::placeholder{color:rgba(43,50,64,.4)}.map-legend{background:var(--bg);border-radius:.4rem;box-shadow:0 2px 8px rgba(0,0,0,.15);font-family:var(--sans);font-size:.8rem;line-height:1.6}.map-legend__btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;background:var(--bg);color:var(--accent);font-family:var(--serif);font-size:1rem;font-weight:700;border-radius:.4rem;cursor:pointer}.map-legend__btn:hover{color:var(--accent-dk)}.map-legend__content{display:none;padding:.5rem .7rem .6rem;border-top:1px solid var(--bg-alt)}.map-legend--open .map-legend__content{display:block}.map-legend--open .map-legend__btn{border-radius:.4rem .4rem 0 0}.map-legend__item{display:flex;align-items:center;gap:.5rem}.map-legend__dot{width:10px;height:10px;border-radius:50%;display:inline-block;flex-shrink:0}main:has(.hero){max-width:none;padding:0}.hero{min-height:70vh;display:flex;align-items:center;justify-content:center;text-align:center;background:linear-gradient( 135deg,#2B3240 0%,#3A4560 30%,#4E6080 50%,#6B7B9E 70%,#5B8A8A 100% );padding:4rem 2rem;margin:-1rem -1rem 0}.hero__content{max-width:600px}.hero__title{font-family:var(--serif);font-size:3.5rem;color:var(--bg);margin-bottom:.75rem;letter-spacing:.02em}.hero__tagline{font-family:var(--sans);font-size:1.25rem;color:rgba(236,238,241,.85);margin-bottom:2rem}.hero__cta{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.hero__button{display:inline-block;padding:.8rem 1.8rem;border-radius:.4rem;text-decoration:none;font-family:var(--sans);font-weight:600;font-size:1.05rem;transition:background-color .2s,transform .15s}.hero__button:hover{transform:translateY(-2px);text-decoration:none}.hero__button--primary{background:var(--accent);color:var(--bg)}.hero__button--primary:hover{background:var(--accent-dk);color:var(--bg)}.hero__button--secondary{background:rgba(236,238,241,.15);color:var(--bg);border:1px solid rgba(236,238,241,.4)}.hero__button--secondary:hover{background:rgba(236,238,241,.25);color:var(--bg)}.featured{max-width:1100px;margin:0 auto;padding:3rem 1rem}.featured h2{margin-bottom:2rem}@media(max-width:768px){.hero{min-height:60vh;padding:3rem 1.5rem}.hero__title{font-size:2.5rem}.hero__tagline{font-size:1.1rem}}.tietoa-page{max-width:700px;margin:0 auto;padding:2rem 1rem}