:root{font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;line-height:1.5;font-weight:400;color:#101828;background-color:#f8fafc;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}body{margin:0}a{color:#155eef}.app-shell{min-height:100vh}.container{width:min(960px,100% - 2rem);margin-inline:auto}.site-header{background-color:#fff;border-bottom:1px solid #e4e7ec}.header-content{display:flex;justify-content:space-between;align-items:center;min-height:64px;gap:1rem}.brand{font-weight:700;text-decoration:none;color:#101828}.main-nav{display:flex;gap:.5rem}.nav-link{text-decoration:none;color:#475467;padding:.35rem .6rem;border-radius:6px}.nav-link-active{background-color:#eef4ff;color:#155eef}.page-content{padding-block:2rem}.home-hero{min-height:clamp(420px,68vh,680px);border-radius:20px;overflow:hidden;position:relative;display:grid;place-items:center;background-image:linear-gradient(180deg,#0c131f59,#0c131fb8),var(--home-hero-background-url, url(/assets/background.jpg));background-size:cover;background-position:center;box-shadow:0 18px 40px #1018282e}.home-hero-overlay{width:min(680px,100% - 2.5rem);display:grid;gap:.9rem;text-align:center;color:#f8fafc}.home-hero-kicker{margin:0;font-size:.95rem;text-transform:uppercase;letter-spacing:.16em;font-weight:600;color:#fcfdffe6}.home-hero-intro{margin:0;font-size:clamp(1.6rem,4vw,2.6rem);line-height:1.15;font-weight:700;text-wrap:balance}.home-hero-message{margin:0;font-size:clamp(1.15rem,2.7vw,1.4rem);line-height:1.45;color:#f8fafcf2}.home-hero-cta{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;background-color:#fff;color:#0f172a;padding:.75rem 1.25rem;text-decoration:none;font-weight:600;font-size:1rem;transition:transform .18s ease,box-shadow .18s ease}.home-hero-cta:hover,.home-hero-cta:focus-visible{transform:translateY(-1px);box-shadow:0 8px 18px #0f172a42}.routes-header{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap}.search-field{display:grid;gap:.35rem;margin-bottom:1rem}.search-label{font-size:.9rem;color:#475467}.search-field input{width:100%;max-width:28rem;border:1px solid #d0d5dd;border-radius:8px;padding:.6rem .75rem;font:inherit}.view-toggle{display:inline-flex;background:#f2f4f7;border-radius:8px;padding:.2rem}.view-toggle button{border:none;background:transparent;border-radius:6px;padding:.4rem .7rem}.view-toggle .is-active{background:#fff;box-shadow:0 1px 2px #10182814}.routes-toolbar{display:flex;justify-content:space-between;align-items:center;gap:.75rem;flex-wrap:wrap;margin-bottom:.8rem}.results-count{color:#475467;margin:0}.distance-sort{display:inline-flex;align-items:center;gap:.3rem;background:#f2f4f7;border-radius:8px;padding:.2rem}.distance-sort-label{font-size:.8rem;font-weight:600;color:#475467;padding:0 .45rem}.distance-sort button{border:none;background:transparent;border-radius:6px;padding:.35rem .6rem;color:#344054}.distance-sort .is-active{background:#fff;box-shadow:0 1px 2px #10182814}.routes-empty-state{margin:1.2rem 0;padding:1rem;border:1px dashed #d0d5dd;border-radius:10px;color:#475467;background:#fcfcfd}.route-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1rem}.route-card{background-color:#fff;border:1px solid #eaecf0;border-radius:12px;overflow:hidden}.route-list{list-style:none;margin:0;padding:0;display:grid;gap:.75rem}.route-list-item{background-color:#fff;border:1px solid #eaecf0;border-radius:12px;overflow:hidden;min-height:188px}.route-card-link{display:block;text-decoration:none;color:inherit;border-radius:12px}.route-card-link h3,.route-card-link p,.route-card-link ul{margin-left:1rem;margin-right:1rem}.route-card-hero-wrap{width:100%;aspect-ratio:16 / 9;position:relative;overflow:hidden;background:#f2f4f7;border-bottom:1px solid #eaecf0}.route-card-hero{width:100%;height:100%;object-fit:cover}.route-card-hero-placeholder{position:absolute;inset:0;display:none;place-items:center;color:#667085;font-size:.85rem}.route-card-hero-wrap.is-unavailable .route-card-hero-placeholder{display:grid}.route-card-hero.is-hidden{display:none}.route-card:hover,.route-card:focus-within{border-color:#84adff;box-shadow:0 0 0 3px #155eef24}.route-card-link:focus-visible,.route-list-link:focus-visible{outline:2px solid #155eef;outline-offset:2px}.route-list-link{display:grid;grid-template-columns:minmax(180px,28%) minmax(0,1fr) minmax(210px,240px);align-items:stretch;gap:1rem;width:100%;height:100%;overflow:hidden;color:inherit;text-decoration:none;border-radius:8px}.route-list-main{display:grid;align-content:center;gap:.55rem;padding:1rem 0}.route-list-main h3,.route-list-main p{margin:0}.route-list-main h3{line-height:1.25;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.route-list-main p{color:#475467;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.route-list-thumb-wrap{min-height:100%;height:100%;overflow:hidden;background:#f2f4f7;border-right:1px solid #eaecf0;position:relative}.route-list-thumb{width:100%;height:100%;display:block;object-fit:cover}.route-list-thumb-placeholder{position:absolute;inset:0;display:none;background:linear-gradient(145deg,#f2f4f7,#eaecf0)}.route-list-thumb-wrap.is-unavailable .route-list-thumb-placeholder{display:block}.route-list-thumb.is-hidden{display:none}.route-list-meta{margin:0;display:grid;grid-template-rows:repeat(2,minmax(0,1fr));align-self:stretch;min-width:210px;padding:0;border-left:1px solid #eaecf0}.route-list-meta div{margin:0;display:grid;align-content:center;gap:.15rem;padding:.9rem 1rem}.route-list-meta div+div{border-top:1px solid #eaecf0}.route-list-meta dt,.route-list-meta dd{margin:0}.route-list-meta dt{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:#667085}.route-list-meta dd{color:#101828;font-weight:600;line-height:1.3;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.route-list-meta dd span{color:#667085;font-weight:500}.route-list-item:hover,.route-list-item:focus-within{border-color:#84adff;box-shadow:0 0 0 3px #155eef24}.route-detail-page{display:grid;gap:1.5rem}.route-hero{display:grid;gap:.35rem}.route-hero-region{margin:0;font-size:.9rem;font-weight:600;color:#155eef;text-transform:uppercase;letter-spacing:.02em}.route-hero h1{margin:0}.route-hero-summary{margin:0;color:#475467;max-width:65ch}.route-detail-section{display:grid;gap:.8rem}.route-detail-section h2{margin:0;font-size:1.1rem}.route-context{color:#344054;display:grid;gap:.7rem;max-width:72ch}.route-context p{margin:0}.route-context h3{margin:0;font-size:1rem;color:#101828}.strava-embed{width:100%;min-height:400px;aspect-ratio:5 / 4;border:1px solid #eaecf0;border-radius:12px;overflow:hidden;background:#fff}.strava-embed iframe{display:block;width:100%;border:0}.strava-embed .strava-embed-placeholder{width:100%;min-height:inherit}.route-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:.75rem}.route-stat-card{margin:0;padding:.85rem;border-radius:12px;border:1px solid #eaecf0;background:#fff;display:grid;gap:.35rem}.route-stat-card h3{margin:0;font-size:.9rem;color:#475467}.route-stat-card p{margin:0;font-weight:600;color:#101828}.route-actions{display:flex;flex-wrap:wrap;gap:.65rem}.route-action-button{display:inline-flex;align-items:center;justify-content:center;min-height:2.5rem;padding:.5rem .8rem;border-radius:8px;border:1px solid #d0d5dd;background:#fff;color:#344054;font-weight:500;text-decoration:none}.route-action-button.is-disabled{color:#98a2b3;border-color:#eaecf0;background:#f9fafb}.route-meta{color:#475467;font-size:.95rem;margin:0;display:grid;gap:.6rem}.route-meta div{display:grid;grid-template-columns:minmax(120px,180px) 1fr;gap:.75rem;align-items:baseline}.route-meta dt,.route-meta dd{margin:0}.route-meta dt{font-weight:600;color:#344054}.tag-list{list-style:none;padding:0;margin:0;display:flex;flex-wrap:wrap;gap:.4rem}.tag-list li{font-size:.75rem;background:#f2f4f7;color:#344054;border-radius:999px;padding:.15rem .55rem}.route-photo-gallery{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:.75rem;margin:1rem 0 1.25rem}.route-photo-card{margin:0;border-radius:12px;overflow:hidden;background:#fff;border:1px solid #eaecf0}.route-photo-card img{width:100%;aspect-ratio:4 / 3;object-fit:cover;display:block;background:#f2f4f7}.route-photo-trigger{display:block;border:0;margin:0;padding:0;width:100%;background:transparent;cursor:zoom-in}.route-photo-trigger:focus-visible{outline:3px solid #2e90fa;outline-offset:-3px}.route-photo-card figcaption{font-size:.85rem;color:#475467;padding:.55rem .65rem}.route-photo-gallery-preview{min-height:100%;border:1px solid #eaecf0;border-radius:12px;background-color:#344054;background-size:cover;background-position:center;color:#fff;display:flex;flex-direction:column;justify-content:center;align-items:flex-start;text-align:left;gap:.25rem;padding:.85rem;cursor:pointer;min-height:238px;font-weight:600}.route-photo-gallery-preview small{font-size:.85rem;font-weight:500;color:#d0d5dd}.route-photo-gallery-preview:focus-visible{outline:3px solid #2e90fa;outline-offset:2px}.photo-lightbox-backdrop{position:fixed;inset:0;background:#101828c7;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:flex;justify-content:center;align-items:center;padding:1rem;z-index:40}.photo-lightbox{position:relative;width:min(1000px,100%);max-height:100%;background:#101828;border:1px solid rgb(255 255 255 / 16%);border-radius:14px;padding:1rem;color:#f9fafb}.photo-lightbox-close{position:absolute;top:.4rem;right:.4rem;width:2.35rem;height:2.35rem;border-radius:999px;border:1px solid rgb(255 255 255 / 30%);background:#ffffff14;color:inherit;font-size:1.2rem;cursor:pointer}.photo-lightbox-content{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:.45rem}.photo-lightbox-nav{width:2.8rem;height:2.8rem;border-radius:999px;border:1px solid rgb(255 255 255 / 30%);background:#ffffff14;color:inherit;font-size:2rem;line-height:1;cursor:pointer}.photo-lightbox-figure{margin:0;display:grid;justify-items:center;gap:.7rem}.photo-lightbox-figure img{max-width:100%;max-height:min(72vh,760px);object-fit:contain;border-radius:10px}.photo-lightbox-figure figcaption{text-align:center;color:#d0d5dd;font-size:.9rem}.photo-lightbox-close:focus-visible,.photo-lightbox-nav:focus-visible{outline:3px solid #2e90fa;outline-offset:2px}@media(max-width:640px){.strava-embed{min-height:320px}.route-photo-gallery-preview{min-height:200px;padding:1rem}.route-meta div{grid-template-columns:1fr;gap:.15rem}.distance-sort{width:100%;justify-content:center}.route-list-link{grid-template-columns:88px minmax(0,1fr);grid-template-areas:"thumb main" "thumb meta";align-items:start;gap:.35rem .75rem;height:124px;padding:.65rem}.route-list-item{min-height:124px}.route-list-thumb-wrap{grid-area:thumb;border-right:0;border-bottom:0;border-radius:8px;min-height:100%;align-self:stretch}.route-list-main{grid-area:main;padding:.05rem 0 0;gap:.3rem;align-content:start;min-width:0}.route-list-main h3{font-size:.95rem;-webkit-line-clamp:2}.route-list-main p{font-size:.82rem;line-height:1.35;-webkit-line-clamp:1}.route-list-meta{grid-area:meta;display:flex;align-items:center;gap:.7rem;min-width:0;border-left:0;border-top:0;padding-bottom:.1rem}.route-list-meta div{padding:0;min-width:0}.route-list-meta div+div{border-top:0;padding-left:.7rem;border-left:1px solid #d0d5dd}.route-list-meta dt{font-size:.65rem}.route-list-meta dd{font-size:.83rem;white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.photo-lightbox-backdrop{padding:0}.photo-lightbox{width:100%;max-height:100%;min-height:100%;border-radius:0;border:0;padding:3rem .4rem .8rem}.photo-lightbox-content{grid-template-columns:1fr;gap:.75rem}.photo-lightbox-nav{width:100%;height:2.7rem;font-size:1.5rem}.photo-lightbox-figure{order:-1}.photo-lightbox-figure img{max-height:68vh}}
