:root{
  --bg:#f7f8fb;
  --surface:#fff;
  --text:#172033;
  --muted:#5d6678;
  --line:#dfe4ec;
  --brand:#136f63;
  --brand-dark:#0d5148;
  --accent:#f5b94e;
  --danger:#b42318;
  --shadow:0 12px 34px rgba(23,32,51,.08);
}
*{box-sizing:border-box}
html{font-family:Arial,Helvetica,sans-serif;color:var(--text);background:var(--bg);line-height:1.55}
body{margin:0}
a{color:var(--brand);text-decoration:none}
a:hover{text-decoration:underline}
.site-header{position:sticky;top:0;z-index:2000;background:rgba(255,255,255,.96);border-bottom:1px solid var(--line);backdrop-filter:blur(10px)}
.header-inner{width:min(1160px,calc(100% - 32px));margin:0 auto;display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:18px;padding:10px 0}
.brand{display:inline-flex;align-items:center;justify-self:start;width:max-content;column-gap:10px;font-weight:800;color:var(--text);font-size:22px;line-height:1.1;letter-spacing:-.01em;flex-shrink:0;white-space:nowrap}
.brand:before{content:"";display:inline-block;width:30px;height:30px;background:url('/assets/img/favicon.svg') center/contain no-repeat;flex:0 0 auto}
.brand .brand-line-1{white-space:nowrap}
.brand .brand-line-2{white-space:nowrap;color:var(--brand-dark);font-weight:800;margin-left:4px}
.main-nav{display:flex;flex-wrap:wrap;gap:2px 4px;justify-content:flex-end;align-items:center;min-width:0;row-gap:2px}
.main-nav a{color:var(--muted);font-weight:700;font-size:16px;padding:7px 10px;border-radius:6px;white-space:nowrap;line-height:1.2}
.main-nav a[aria-current="page"],.main-nav a:hover{background:#eaf4f2;color:var(--brand-dark);text-decoration:none}
.wrap,.container{width:min(1160px,calc(100% - 32px));margin:0 auto}
.hero{padding:70px 0 46px;background:linear-gradient(180deg,#eaf4f2 0%,#f7f8fb 100%)}
.hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:32px;align-items:center}
.eyebrow{color:var(--brand-dark);font-weight:800;text-transform:uppercase;font-size:13px;letter-spacing:.08em}
h1{font-size:clamp(36px,6vw,58px);line-height:1.04;margin:10px 0 14px;letter-spacing:0}
h2{font-size:clamp(24px,3.5vw,32px);line-height:1.18;margin:0 0 14px}
h3{font-size:20px;margin:24px 0 8px}
p,li{font-size:17px}
p{margin:0 0 14px}
.lead{font-size:20px;color:var(--muted);max-width:720px}
.actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:24px}
.btn{display:inline-flex;align-items:center;justify-content:center;min-height:44px;padding:11px 18px;border-radius:6px;font-weight:800;border:1px solid var(--brand);background:var(--brand);color:#fff}
.btn:hover{text-decoration:none;background:var(--brand-dark)}
.btn.secondary{background:#fff;color:var(--brand-dark);margin-bottom: 10px}
.map-preview{min-height:330px;border:1px solid var(--line);border-radius:8px;background:#e4f0ec;box-shadow:var(--shadow);overflow:hidden;display:flex;align-items:stretch}
.map-preview:before,.map-preview:after{display:none}
.map-preview svg{width:100%;height:100%;display:block;flex:1;min-height:330px}
.section{padding:38px 0}
.tool-header{max-width:860px;margin-bottom:12px}
.tool-header p:not(.lead){color:var(--muted)}
.tool-content{display:grid;grid-template-columns:minmax(0,1fr);gap:22px}
.tool-card{background:var(--surface);border:1px solid var(--line);border-radius:8px;padding:18px;box-shadow:var(--shadow);margin:0 0 4px}
.tool-card.compact,.route-form-card{max-width:none}
.tool-card h2,.content-card h2{margin-top:0}
.content-card{background:var(--surface);border:1px solid var(--line);border-radius:8px;padding:24px;box-shadow:0 6px 22px rgba(23,32,51,.05)}
.feature-list{margin:10px 0 0;padding-left:22px;color:var(--muted)}
.feature-list li{margin-bottom:6px}
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.card{background:var(--surface);border:1px solid var(--line);border-radius:8px;padding:22px;box-shadow:0 4px 18px rgba(23,32,51,.04)}
.card h3{margin-top:0}
.tool-shell{background:var(--surface);border:1px solid var(--line);border-radius:8px;padding:18px;box-shadow:var(--shadow);margin:24px 0}
.tool-form{display:grid;grid-template-columns:minmax(180px,1fr) minmax(180px,1fr) 150px auto;gap:12px;align-items:end}
.tool-form label,.field label{display:block;font-weight:800;font-size:13px;color:var(--muted);margin-bottom:5px}
input,select,button{font:inherit}
input,select{width:100%;border:1px solid #cbd3df;border-radius:6px;padding:11px 12px;background:#fff;color:var(--text)}
button{cursor:pointer}
.btn:disabled{opacity:.72;cursor:wait}
.map-frame{position:relative;width:100%;border:1px solid var(--line);border-radius:8px;overflow:hidden;background:transparent;padding:0;margin:0;line-height:normal}
.tool-map-wrap .map-frame{margin-top:14px}
.map-frame .map{border:0;border-radius:0;display:block;width:100%}
.map{height:450px;min-height:340px;border-radius:8px;border:1px solid var(--line);overflow:hidden;background:#e7ecef}
.map.map-large,.map.map-route{height:450px}
.map-fullscreen-toggle{position:absolute;top:12px;right:12px;z-index:800;border:1px solid rgba(13,81,72,.18);border-radius:999px;background:#fff;color:var(--brand-dark);box-shadow:0 6px 18px rgba(23,32,51,.15);font-size:13px;font-weight:800;line-height:1.2;min-height:0;height:auto;width:auto;white-space:nowrap;padding:8px 12px}
.map-fullscreen-toggle:hover{background:#eaf4f2}
.fullscreen-map{position:fixed!important;top:0!important;right:0!important;bottom:0!important;left:0!important;width:100vw!important;height:100vh!important;max-width:none!important;max-height:none!important;margin:0!important;padding:0!important;border:0!important;border-radius:0!important;z-index:9999;box-shadow:none!important;background:#e7ecef;overflow:hidden!important}
.fullscreen-map .map,.fullscreen-map .leaflet-container{position:absolute!important;top:0!important;right:0!important;bottom:0!important;left:0!important;width:100vw!important;height:100vh!important;min-height:0!important;margin:0!important;padding:0!important;border:0!important;border-radius:0!important}
.fullscreen-map .leaflet-control-container{position:relative;z-index:1000}
.has-fullscreen-map{overflow:hidden}
.map-frame .leaflet-top.leaflet-right{top:52px}
.map-layer-card.leaflet-control{border:0;border-radius:8px;box-shadow:0 8px 24px rgba(23,32,51,.16);overflow:hidden;background:#fff}
.map-layer-card .map-layer-title{display:block;width:100%;border:0;border-bottom:1px solid var(--line);background:#fff;text-align:left;font-weight:800;color:var(--text);padding:9px 12px 7px;font-size:13px}
.map-layer-card .map-layer-title:after{content:"−";float:right;color:var(--brand-dark);font-weight:900}
.map-layer-card.is-collapsed.leaflet-control{border-radius:999px;box-shadow:0 4px 12px rgba(23,32,51,.12);border:1px solid rgba(13,81,72,.18)}
.map-layer-card.is-collapsed .map-layer-title{border-bottom:0;border-radius:999px;padding:5px 10px;line-height:1.15}
.map-layer-card.is-collapsed .map-layer-title:after{content:"+";float:none;margin-left:5px}
.map-layer-card.is-collapsed .leaflet-control-layers-list{display:none}
.map-layer-card .leaflet-control-layers-list{padding:7px 10px 9px}
.map-layer-card label{display:flex;align-items:center;gap:7px;margin:5px 0;color:var(--muted);font-weight:700;font-size:13px}
.map-layer-card input{width:auto;accent-color:var(--brand)}
.status{padding:10px 12px;border-radius:6px;background:#eef6ff;color:#184a78;margin:10px 0}
.status.error{background:#fff0ee;color:var(--danger)}
.route-results[hidden],.route-details[hidden]{display:none}
.result-grid{display:grid;grid-template-columns:1fr;gap:18px;align-items:start}
.route-results-panel,.route-map-panel{min-width:0}
.route-map-panel{margin-bottom:18px}
.route-actions{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin:2px 0 16px}
.route-summary-wrap{margin-bottom:18px}
.steps{padding:0;margin:12px 0 0;list-style:none}
.steps li{display:grid;grid-template-columns:32px 1fr auto;gap:10px;align-items:start;margin:0;padding:12px 14px;border:1px solid var(--line);border-radius:8px;background:#fff}
.steps li+li{margin-top:8px}
.steps li:hover{background:#f6fbfa;border-color:#cfe4dd}
.steps small{color:var(--muted);font-weight:800;white-space:nowrap}
.steps .sr-more-row{display:block;border:none;background:none;padding:8px 0 4px}
.steps .sr-more-row:hover{background:none}
.route-freshness{display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin:6px 0 12px;padding:8px 12px;background:#f8faf9;border:1px solid #d4e6df;border-radius:6px;font-size:13px}
.route-freshness-date{color:var(--muted)}
.rigenera-btn{display:inline-flex;align-items:center;gap:5px;padding:5px 12px;border-radius:5px;border:1px solid #136f63;color:#136f63;font-size:13px;font-weight:700;text-decoration:none;transition:background .12s,color .12s}
.rigenera-btn:hover{background:#136f63;color:#fff;text-decoration:none}
.meta-list{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}
.route-summary-wrap .meta-list{grid-template-columns:repeat(3,1fr)}
.meta-box{background:#f3f6f8;border:1px solid var(--line);border-radius:6px;padding:12px}
.metric-box strong{display:block;color:var(--muted);font-size:13px;margin-bottom:4px}
.metric-value{display:block;font-size:22px;font-weight:800;color:var(--text)}
.metric-value span{display:block;font-size:15px;color:var(--muted);font-weight:800;margin-top:2px}
.route-print-header,.route-print-fixed-footer,.route-print-source,.route-print-map,.route-print-continuation{display:none}
.coordinate-panel{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-bottom:12px}
.coordinate-value{display:block;font-size:22px;font-weight:800;margin-top:4px;word-break:break-word}
.hint{color:var(--muted);font-size:15px;margin:4px 0 14px}
.status-label{display:block;font-size:13px;font-weight:800;color:#31587b;margin-bottom:4px}
.measure-value{display:block;font-size:26px;font-weight:800;line-height:1.1;color:#123f69}
.measure-sub{display:block;font-size:17px;font-weight:700;color:#42617f;margin-top:3px}
.unit-toggle{display:inline-flex;gap:4px;align-items:center;background:#f3f6f8;border:1px solid var(--line);border-radius:999px;padding:4px;margin:0 0 12px}
.unit-toggle button{border:0;border-radius:999px;background:transparent;color:var(--muted);font-weight:800;padding:7px 12px}
.unit-toggle button[aria-pressed="true"]{background:#fff;color:var(--brand-dark);box-shadow:0 2px 8px rgba(23,32,51,.08)}
.ad-slot{display:block;width:100%;min-width:300px;max-width:100%;min-height:90px;margin:18px 0;text-align:center;overflow:hidden;contain:layout}
.ad-slot ins.adsbygoogle{display:block!important;width:100%!important;min-width:300px;min-height:90px}
.ad-slot-placeholder{background:#f4f6f8;border:1px dashed #cbd3df;border-radius:8px;color:var(--muted);font-size:13px}
.ad-slot-placeholder span{opacity:.75}
.related{display:flex;gap:10px;flex-wrap:wrap;margin-top:10px}
.related a{background:#eef6f3;border:1px solid #cfe4dd;border-radius:999px;padding:9px 14px;font-weight:800;color:var(--brand-dark)}
.related a:hover{background:#dcefe9;text-decoration:none}
.faq details{background:#fff;border:1px solid var(--line);border-radius:8px;padding:14px 16px;margin-bottom:10px}
.faq summary{font-weight:800;cursor:pointer}
.link-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.link-grid a{background:#fff;border:1px solid var(--line);border-radius:6px;padding:12px;font-weight:700}
.site-footer{padding:32px 0;background:#172033;color:#dbe4ef;margin-top:36px}
.footer-inner{width:min(1240px,calc(100% - 32px));margin:0 auto}
.site-footer nav{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:14px}
.site-footer .legal-nav{padding:14px 0 0;border-top:1px solid rgba(255,255,255,.14);margin-top:12px;background:transparent;border-left:none;border-right:none;border-bottom:none;border-radius:0;gap:8px 10px}
.site-footer .legal-nav a{font-size:13.5px;color:#f1f5fb;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.18);padding:6px 12px;border-radius:6px;font-weight:500;line-height:1.2}
.site-footer .legal-nav a:hover{background:rgba(255,255,255,.18);border-color:rgba(255,255,255,.32);color:#fff;text-decoration:none}
.site-footer a{color:#fff}
.site-footer p{max-width:980px;color:#c5cfdc}
.site-footer small{color:#c5cfdc}

/* Footer "Explore Canada by province and territory" SEO block */
.footer-regions{margin:22px 0 18px;padding:18px 0;border-top:1px solid rgba(255,255,255,.14);border-bottom:1px solid rgba(255,255,255,.14)}
.footer-regions-title{margin:0 0 14px;font-size:15px;font-weight:800;color:#fff;letter-spacing:.02em;text-transform:none}
.footer-regions-list{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:6px 18px}
.footer-region-item{display:flex;align-items:baseline;gap:8px;flex-wrap:wrap;font-size:14px;line-height:1.45}
.footer-region-link{color:#fff;font-weight:700}
.footer-region-link:hover{text-decoration:underline}
.footer-region-capital{color:#9aa9bd;font-size:12.5px;font-weight:500}
.footer-region-capital a{color:#cfdbeb;font-weight:600}
.footer-region-capital a:hover{color:#fff;text-decoration:underline}
@media (max-width:560px){
  .footer-regions{margin:18px 0 14px;padding:16px 0}
  .footer-regions-list{grid-template-columns:1fr 1fr;gap:6px 12px}
  .footer-region-item{flex-direction:column;align-items:flex-start;gap:0;font-size:13.5px}
  .footer-region-capital{font-size:12px}
}
@media (max-width:380px){
  .footer-regions-list{grid-template-columns:1fr}
}
.leaflet-control-attribution{font-size:11px}
/* Site search */
.site-search-wrap{position:relative}
.site-search-wrap form{display:flex;align-items:center;border:1px solid var(--line);border-radius:6px;background:#fff;overflow:hidden}
.site-search-wrap input[type=search]{border:0;outline:0;padding:7px 10px;font-size:13px;width:170px;background:transparent;color:var(--text)}
.site-search-wrap input[type=search]::placeholder{color:var(--muted)}
.site-search-wrap button{border:0;background:transparent;color:var(--brand-dark);font-size:17px;padding:6px 9px;cursor:pointer;line-height:1;flex:0 0 auto}
.site-search-wrap button:hover{background:#eaf4f2}
#site-search-results{position:absolute;top:calc(100% + 6px);right:0;left:0;z-index:3000;background:#fff;border:1px solid var(--line);border-radius:8px;box-shadow:0 12px 32px rgba(23,32,51,.14);list-style:none;margin:0;padding:6px 0;min-width:260px;max-height:360px;overflow-y:auto}
#site-search-results[hidden]{display:none}
#site-search-results li{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;cursor:pointer;gap:10px;font-size:14px;line-height:1.3;transition:background .1s}
#site-search-results li:hover,#site-search-results li[aria-selected=true]{background:#eef8f6}
#site-search-results .sr-city{font-weight:600;color:var(--text)}
#site-search-results .sr-region{color:var(--muted);font-size:12px;white-space:nowrap;flex-shrink:0}
#site-search-results .sr-foreign{color:#6b7a99;font-size:11px;font-style:italic}
/* Foreign result — stacked layout with inline action buttons */
#site-search-results li:has(.sr-foreign-wrap){display:block;padding:8px 12px}
#site-search-results .sr-foreign-wrap{display:flex;flex-direction:column;gap:6px;width:100%}
#site-search-results .sr-top-row{display:flex;justify-content:space-between;align-items:center;gap:8px;min-width:0}
#site-search-results .sr-top-row .sr-city{flex:0 1 auto;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:14px}
#site-search-results .sr-top-row .sr-foreign{flex:0 0 auto;font-size:11px;white-space:nowrap;max-width:140px;overflow:hidden;text-overflow:ellipsis;padding:1px 6px;background:#f0f4f8;border-radius:4px}
#site-search-results .sr-actions{display:flex;gap:5px;flex-wrap:nowrap}
#site-search-results .sr-act{font-size:12px;padding:4px 10px;border-radius:12px;background:#f0f4f8;color:var(--brand-dark);text-decoration:none;white-space:nowrap;border:1px solid var(--line);line-height:1.5;flex:1 1 0;text-align:center;min-width:0;overflow:hidden;text-overflow:ellipsis;transition:background .12s,color .12s}
#site-search-results .sr-act:hover,#site-search-results .sr-act:focus{background:var(--brand);color:#fff;border-color:var(--brand);text-decoration:none;outline:none}
#site-search-results mark{background:rgba(19,111,99,.18);color:inherit;font-weight:600;border-radius:2px;padding:0 2px}
@media(max-width:480px){
  #site-search-results{left:-8px;right:-8px;border-radius:6px}
  #site-search-results .sr-act{font-size:11px;padding:4px 6px}
}
/* Header: two-row layout for anything narrower than a wide desktop.
   The 9-item nav needs its own row to breathe; 1440px is the
   threshold below which one-row layout starts looking cramped.
   Row 1 = brand (left) + search (right). Row 2 = nav, full-width. */
@media (max-width:1440px){
  .header-inner{grid-template-columns:1fr auto;grid-template-rows:auto auto;gap:8px 16px;padding:10px 0}
  .brand{grid-column:1;grid-row:1}
  .site-search-wrap{grid-column:2;grid-row:1;align-self:center}
  .main-nav{grid-column:1 / -1;grid-row:2;flex-wrap:wrap;justify-content:flex-start;gap:2px 4px;border-top:1px solid var(--line);padding-top:8px;margin-top:0}
  .main-nav a{padding:7px 12px;font-size:16px}
  .site-search-wrap input[type=search]{width:180px}
}
/* Brand wraps to two visual lines on small tablets / phones so
   "Canada Driving / Directions" stays readable above a long nav. */
@media (max-width:640px){
  .brand{font-size:17px;line-height:1.12}
  .main-nav{justify-content:flex-start}
  .main-nav a{padding:6px 10px;font-size:14px}
}
@media (max-width:900px){
  .site-header{position:static}
  .hero-grid,.grid,.result-grid{grid-template-columns:1fr}
  .tool-form{grid-template-columns:1fr}
  .tool-card.compact{max-width:none}
  .link-grid{grid-template-columns:repeat(2,1fr)}
  .map,.map.map-large,.map.map-route{height:430px}
  .route-summary-wrap .meta-list{grid-template-columns:1fr}
}
@media (max-width:560px){
  .hero{padding-top:38px}
  .lead{font-size:18px}
  .link-grid,.meta-list,.coordinate-panel{grid-template-columns:1fr}
  .header-inner{gap:8px 12px;padding:10px 0}
  .brand{font-size:16px}
  .main-nav a{padding:6px 8px;font-size:13px}
  .site-search-wrap input[type=search]{width:120px}
  .tool-card,.content-card{padding:16px}
  .map,.map.map-large,.map.map-route{height:360px;min-height:300px}
  .map-frame .leaflet-top.leaflet-right{top:42px}
  .map-layer-card.leaflet-control{width:142px;max-width:142px}
  .map-layer-card.is-collapsed.leaflet-control{width:auto;max-width:none;border-radius:999px;box-shadow:0 4px 12px rgba(23,32,51,.12);border:1px solid rgba(13,81,72,.18)}
  .map-layer-card .map-layer-title{padding:6px 9px;font-size:11.5px;white-space:nowrap}
  .map-layer-card.is-collapsed .map-layer-title{padding:4px 8px;background:#fff;border-radius:999px;line-height:1.15}
  .map-layer-card.is-collapsed .map-layer-title{font-size:0}
  .map-layer-card.is-collapsed .map-layer-title:before{content:"Layers";font-size:11px}
  .map-layer-card .leaflet-control-layers-list{padding:4px 7px 6px}
  .map-layer-card label{font-size:11.5px;margin:2px 0;gap:5px;line-height:1.25;white-space:nowrap}
  .map-layer-card input{transform:scale(.88)}
  .steps li{grid-template-columns:1fr}
  .steps small{white-space:normal}
  .fullscreen-map{inset:0!important}
  .map-fullscreen-toggle{font-size:12px;padding:7px 10px}
}

/* ── Breadcrumbs ─────────────────────────────────────────────────────────────*/
.breadcrumb{margin:0 0 14px}
.breadcrumb ol{list-style:none;padding:0;margin:0;display:flex;flex-wrap:wrap;align-items:center;font-size:13px;color:var(--muted)}
.breadcrumb li{display:flex;align-items:center}
.breadcrumb li+li:before{content:'›';margin:0 6px;color:var(--muted);opacity:.6;font-size:12px}
.breadcrumb li a{color:var(--brand)}
.breadcrumb li a:hover{text-decoration:underline}
.breadcrumb li[aria-current="page"]{color:var(--text);font-weight:700}
@media print{.breadcrumb{display:none!important}}
/* ── Percorso page additions ─────────────────────────────────────────────── */
/* Warning / caveat box on route pages */
.percorso-caveat{background:#fff8ed;border:1px solid #f5d98b;border-radius:6px;padding:12px 14px;font-size:14px;color:#6b4a00}

/* Google Maps embed shell on city pages */
.gmaps-embed-shell{
  position:relative;width:100%;height:420px;
  border-radius:8px;overflow:hidden;background:#e8f0f8
}
.gmaps-embed-frame{width:100%;height:100%;border:0;display:block}
.gmaps-embed-placeholder{
  position:absolute;inset:0;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  background:linear-gradient(135deg,#eaf4f2 0%,#f0f9f0 55%,#e3f2fd 100%);
  gap:6px;padding:24px
}
@media(max-width:600px){.gmaps-embed-shell{height:300px}}

@media print{
  @page{margin:10mm 10mm 16mm}
  *{box-shadow:none!important}
  html,body{background:#fff;color:#000}
  body{font-size:11pt;-webkit-print-color-adjust:exact;print-color-adjust:exact}
  .site-header,.site-footer,.tool-header,.route-form-card,.content-card,.route-actions,.status,.ad-slot,.map-fullscreen-toggle,.leaflet-control,.leaflet-control-container{display:none!important}
  main,.section,.wrap{display:block;width:100%;max-width:none;padding:0;margin:0}
  .tool-content{display:block}
  .tool-card{box-shadow:none;border:0;padding:0;margin:0}
  .route-results{display:block!important;width:100%;max-width:190mm;margin:0 auto!important;padding:0 3mm 16mm!important}
  .route-print-fixed-footer{position:fixed;bottom:0;left:8mm;right:8mm;height:10mm;display:flex;align-items:center;justify-content:space-between;border-top:1px solid #bbb;background:#fff;color:#000;font-size:9pt;z-index:9999}
  .print-page-number:after{content:"Print version"}
  .print-brand,.print-brand-block .print-brand{display:inline-flex;align-items:center;gap:7px;font-weight:800;color:#000}
  .print-brand:before{content:"";display:inline-block;width:16px;height:16px;background:url('/assets/img/favicon.svg') center/contain no-repeat}
  .print-continuation{font-weight:700;color:#444}
  .route-print-header{display:block;margin:0 0 12px;padding:0 0 10px;border-bottom:2px solid #136f63;break-after:avoid}
  .print-brand-block{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:7px}
  .print-page-label{font-size:10pt;font-weight:800;color:#136f63;text-transform:uppercase}
  .route-print-header h2{font-size:22pt;line-height:1.1;margin:0 0 6px;color:#000}
  .route-print-header p{font-size:10.5pt;color:#222;margin:0 0 4px}
  .route-print-map{display:block!important;width:100%;min-height:64mm;margin:0 0 10px;break-inside:avoid;page-break-inside:avoid;background:#e8eef2;border:1px solid #999}
  .route-print-map:empty{display:block!important}
  .route-print-map svg{display:block!important;width:100%!important;height:auto!important;max-height:70mm;border:0;background:#eaf4f2}
  .route-map-panel{display:none!important}
  .map-frame{display:block!important;position:relative;width:100%;height:auto;border:1px solid #999;border-radius:0;overflow:hidden;background:#eef3f5;margin:0}
  .map-frame .map,.map,.map.map-large,.map.map-route{display:block!important;width:100%!important;height:92mm!important;min-height:92mm!important;border:0!important;border-radius:0!important;overflow:hidden;background:#eef3f5!important}
  .leaflet-container{background:#eef3f5!important;overflow:hidden!important}
  .leaflet-container img{max-width:none!important}
  .leaflet-container svg{max-width:none!important}
  .leaflet-pane,.leaflet-map-pane,.leaflet-tile-pane,.leaflet-overlay-pane,.leaflet-marker-pane,.leaflet-shadow-pane{display:block!important}
  .leaflet-tile,.leaflet-marker-icon,.leaflet-marker-shadow{display:block!important;visibility:visible!important}
  .route-details,.route-details[hidden]{display:block!important}
  .route-summary-wrap{margin:0 0 12px;break-inside:avoid;page-break-inside:avoid}
  .route-summary-wrap .meta-list{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
  .meta-box{background:#fff;border:1px solid #999;border-radius:0;padding:8px;break-inside:avoid;page-break-inside:avoid}
  .metric-box strong{font-size:8.5pt;color:#333;margin-bottom:2px}
  .metric-value{font-size:13pt;color:#000}
  .metric-value span{font-size:9pt;color:#333}
  .route-details h2{font-size:16pt;margin:12px 0 8px;break-after:avoid}
  .route-print-continuation{display:flex;align-items:center;justify-content:space-between;gap:12px;margin:12px 0 8px;padding:8px 0;border-top:1px solid #bbb;border-bottom:1px solid #bbb;font-size:9pt;color:#333;break-after:avoid;page-break-after:avoid}
  .route-print-continuation span:last-child{text-align:right;font-weight:800}
  .steps{margin:0;padding-left:18px;list-style:decimal;orphans:3;widows:3}
  .steps li{display:list-item;margin:0 0 3px;padding:4px 7px;border:1px solid #bbb;border-radius:0;background:#fff;break-inside:avoid!important;page-break-inside:avoid!important;overflow:visible}
  .steps li:nth-child(8){break-before:page;page-break-before:always;margin-top:0}
  .steps li:nth-child(8n+1){break-before:auto;page-break-before:auto}
  .steps li span{display:inline}
  .steps li:hover{background:#fff}
  .steps small{display:block;color:#333;font-weight:800;white-space:normal;margin-top:2px}
  .route-print-source{display:block;margin-top:14px;padding-top:10px;border-top:1px solid #bbb;break-inside:avoid;page-break-inside:avoid}
  .route-print-source h2{font-size:14pt;margin:0 0 6px}
  .route-print-source p{font-size:10pt;margin:0 0 5px}
  a{color:#000;text-decoration:none}
  .steps li{grid-template-columns:22px 1fr auto}
  .step-icon{width:22px;min-width:22px;height:22px;font-size:10px;background:none;color:#000;border:1px solid #bbb}
  .steps:not(.steps-expanded) .step-overflow{display:list-item!important}
  .cost-tabs,.steps-toggle,.cost-tab-btn{display:none!important}
  #route-cost-calc,.cost-panel[hidden]{display:none!important}
}
/* ── Maneuver icons ──────────────────────────────────────────────────────────*/
.step-icon{display:inline-flex;align-items:center;justify-content:center;width:32px;min-width:32px;height:32px;border-radius:50%;background:var(--brand,#136f63);color:#fff;font-size:14px;font-weight:800;flex-shrink:0;line-height:1}
/* ── Step collapse ───────────────────────────────────────────────────────────*/
.steps:not(.steps-expanded) .step-overflow{display:none}
.steps-toggle{display:block;margin-top:10px}
/* ── Cost calculator ─────────────────────────────────────────────────────────*/
/* ── Sticky route CTA bar ────────────────────────────────────────────────────*/
body.has-sticky-cta{padding-bottom:72px}
#route-sticky-cta{position:fixed;bottom:0;left:0;right:0;z-index:2000;background:linear-gradient(135deg,#0a4f46 0%,#136f63 100%);color:#fff;padding:10px 16px;display:flex;align-items:center;gap:10px;box-shadow:0 -4px 20px rgba(0,0,0,.3);transition:transform .25s ease}
#route-sticky-cta.hidden{transform:translateY(100%)}
#route-sticky-cta .sc-label{font-size:13px;font-weight:700;flex:1 1 auto;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}
#route-sticky-cta .sc-btn{display:inline-block;padding:8px 18px;border-radius:6px;font-size:14px;font-weight:700;text-decoration:none;white-space:nowrap;flex-shrink:0;transition:background .12s,color .12s,border-color .12s}
#route-sticky-cta .sc-btn-primary{background:#fff;color:#0a4f46}
#route-sticky-cta .sc-btn-primary:hover{background:#e8f7f4;text-decoration:none}
#route-sticky-cta .sc-btn-secondary{background:transparent;color:#fff;border:2px solid rgba(255,255,255,.55)}
#route-sticky-cta .sc-btn-secondary:hover{background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.8);text-decoration:none}
#route-sticky-cta .sc-close{background:none;border:none;color:rgba(255,255,255,.65);font-size:17px;line-height:1;cursor:pointer;padding:4px 6px;border-radius:4px;flex-shrink:0;transition:color .1s,background .1s}
#route-sticky-cta .sc-close:hover{color:#fff;background:rgba(255,255,255,.15)}
@media(max-width:600px){
  #route-sticky-cta{flex-wrap:wrap;padding:10px 12px;gap:8px}
  #route-sticky-cta .sc-label{width:calc(100% - 36px);order:1}
  #route-sticky-cta .sc-close{order:2;margin-left:auto}
  #route-sticky-cta .sc-btn{flex:1 1 calc(50% - 4px);text-align:center;order:3;padding:9px 8px}
}
@media print{#route-sticky-cta{display:none}}
.cost-tabs{display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap}
.cost-tab-btn{padding:8px 18px;border:1px solid var(--line);border-radius:6px;background:#fff;cursor:pointer;font-weight:800;font-size:14px;color:var(--muted)}
.cost-tab-btn.active{background:var(--brand);color:#fff;border-color:var(--brand)}
.cost-inputs{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:16px}
.cost-inputs label{display:flex;flex-direction:column;gap:5px;font-weight:800;font-size:13px;color:var(--muted)}
.cost-inputs input{padding:8px 10px;border:1px solid var(--line);border-radius:6px;font-size:15px;width:100%;box-sizing:border-box}
.cost-results{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
@media(max-width:700px){.cost-inputs{grid-template-columns:1fr}.cost-results{grid-template-columns:1fr}}
/* ── Route form v2 (expanded planner) ───────────────────────────────────────*/
.route-main-row{display:grid;grid-template-columns:1fr 1fr 170px auto;gap:12px;align-items:end}
.route-field-wrap{position:relative;min-width:0}
.route-field-wrap label{display:block;font-weight:800;font-size:13px;color:var(--muted);margin-bottom:5px}
.place-wrap{position:relative}
.route-options-row{display:flex;align-items:center;gap:20px;flex-wrap:wrap;margin-top:12px;padding-top:12px;border-top:1px solid var(--line)}
.route-avoid-group{border:0;padding:0;margin:0;display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.route-avoid-group legend{font-weight:800;font-size:13px;color:var(--muted);margin-right:6px;float:left}
.route-avoid-group label{display:flex;align-items:center;gap:5px;font-size:14px;font-weight:700;color:var(--text);cursor:pointer}
.route-avoid-group input[type="checkbox"]{width:auto;accent-color:var(--brand)}
.route-traffic-wrap{display:flex;align-items:center;gap:8px;margin-left:auto}
.route-traffic-wrap label{font-size:13px;font-weight:800;color:var(--muted);white-space:nowrap}
.route-traffic-wrap select{width:auto;padding:6px 10px;font-size:13px;border:1px solid var(--line);border-radius:6px}
/* Autocomplete dropdown */
.place-results{position:absolute;top:calc(100% + 2px);left:0;right:0;z-index:3000;background:#fff;border:1px solid var(--line);border-radius:6px;box-shadow:0 8px 24px rgba(23,32,51,.14);list-style:none;margin:0;padding:4px 0;max-height:260px;overflow-y:auto}
.place-results[hidden]{display:none}
.place-result-item{display:flex;align-items:baseline;justify-content:space-between;padding:9px 14px;cursor:pointer;gap:8px;font-size:14px}
.place-result-item:hover,.place-result-item.pr-active{background:#eaf4f2}
.pr-name{font-weight:700;color:var(--text)}
.pr-sub{color:var(--muted);font-size:12px;white-space:nowrap}
@media(max-width:900px){.route-main-row{grid-template-columns:1fr 1fr}.route-main-row .btn{grid-column:1/-1}}
@media(max-width:560px){.route-main-row{grid-template-columns:1fr}.route-traffic-wrap{margin-left:0}}
@media print{.route-avoid-group,.route-traffic-wrap,.route-options-row{display:none!important}}
/* ── Province MD content tables (Phase 8L-1) ────────────────────────────────*/
.table-responsive{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;margin:14px 0;border:1px solid var(--line);border-radius:8px;background:#fff}
.table-responsive .content-table{width:100%;border-collapse:collapse;font-size:14.5px;color:var(--text);min-width:520px}
.table-responsive .content-table caption{caption-side:top;text-align:left;font-weight:800;font-size:14px;padding:10px 14px;color:var(--muted);background:#f8f9fa;border-bottom:1px solid var(--line)}
.table-responsive .content-table th,.table-responsive .content-table td{padding:10px 14px;border-bottom:1px solid var(--line);text-align:left;vertical-align:top;line-height:1.5}
.table-responsive .content-table thead th{background:#f3f5f7;font-weight:800;color:var(--muted);text-transform:none;letter-spacing:0;border-bottom:2px solid var(--line)}
.table-responsive .content-table tbody tr:last-child td{border-bottom:0}
.table-responsive .content-table tbody tr:nth-child(even){background:#fafbfc}
.table-responsive .content-table th:first-child,.table-responsive .content-table td:first-child{font-weight:700;color:var(--text);width:34%}
@media(max-width:560px){.table-responsive .content-table{font-size:14px}.table-responsive .content-table th,.table-responsive .content-table td{padding:8px 10px}}
/* ── Did You Know teasers (Phase 8L-1) ──────────────────────────────────────*/
.dyk-box{margin:18px 0;padding:16px 18px;border-radius:10px;border:1px solid var(--line);background:#fff}
.dyk-box.dyk-card{background:linear-gradient(180deg,#f7faf9 0%,#fff 100%);box-shadow:0 1px 2px rgba(23,32,51,.04)}
.dyk-box.dyk-teaser{padding:12px 14px;border-left:3px solid var(--brand);background:#f7faf9;border-radius:6px}
.dyk-box.dyk-inline{padding:10px 14px;background:transparent;border:0;border-left:3px solid var(--brand);border-radius:0}
.dyk-heading{margin:0 0 8px 0;font-size:14px;font-weight:800;color:var(--brand);letter-spacing:.02em;text-transform:uppercase}
.dyk-list{list-style:none;margin:0;padding:0}
.dyk-item + .dyk-item{margin-top:12px;padding-top:12px;border-top:1px dashed var(--line)}
.dyk-q{margin:0 0 4px 0;font-weight:700;color:var(--text);font-size:15.5px;line-height:1.45}
.dyk-a{margin:0;color:var(--muted);font-size:14.5px;line-height:1.55}
@media(max-width:560px){.dyk-q{font-size:15px}.dyk-a{font-size:14px}}
/* ── /provinces hub grid (Phase 8L-2D) ──────────────────────────────────────*/
.provinces-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:8px}
@media(max-width:980px){.provinces-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.provinces-grid{grid-template-columns:1fr}}
.province-card{background:#fff;border:1px solid var(--line);border-radius:10px;padding:16px 18px;display:flex;flex-direction:column;gap:6px}
.province-card-title{font-size:18px;margin:0;font-weight:800;line-height:1.25}
.province-card-title a{color:var(--text);text-decoration:none}
.province-card-title a:hover{color:var(--brand);text-decoration:underline}
.province-card-capital{margin:0;font-size:13.5px;color:var(--muted)}
.province-card-capital a{color:var(--brand)}
.province-card-blurb{margin:4px 0 8px;font-size:14px;line-height:1.5;color:var(--text)}
.province-card-links{list-style:none;margin:auto 0 0;padding:0;display:flex;gap:14px;flex-wrap:wrap;font-size:13.5px;font-weight:700}
.province-card-links a{color:var(--brand);text-decoration:none}
.province-card-links a:hover{text-decoration:underline}
/* ── /guides hub grid (Phase 8M-1) ──────────────────────────────────────────*/
.guides-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;list-style:none;margin:0;padding:0}
.guide-card{background:#fff;border:1px solid var(--line);border-radius:10px;padding:18px 20px;display:flex;flex-direction:column;gap:8px}
.guide-card-title{margin:0;font-size:17px;font-weight:800;line-height:1.4;letter-spacing:0}
.guide-card-title a{color:var(--text);text-decoration:none;background:transparent;border:0;padding:0;border-radius:0;font-weight:800}
.guide-card-title a:hover{color:var(--brand);text-decoration:underline}
.guide-card-excerpt{margin:0;font-size:14px;line-height:1.55;color:var(--muted)}
@media(max-width:560px){.guides-grid{grid-template-columns:1fr;gap:12px}.guide-card{padding:16px}.guide-card-title{font-size:16px}}
/* ── Province hub reference map — compact, click-to-enlarge ─────────────────*/
.province-media{margin:0 0 24px;max-width:560px;border:1px solid var(--line);border-radius:8px;overflow:hidden;background:#fff}
.province-media a{display:block;line-height:0;background:#eef2f6}
.province-media img{width:100%;height:auto;display:block;transition:transform .25s ease,opacity .15s ease}
.province-media a:hover img{transform:scale(1.02);opacity:.95}
.province-media figcaption{font-size:13px;color:var(--muted);padding:8px 12px;background:#f7f9fc;line-height:1.45}
@media(max-width:700px){.province-media{max-width:100%}}
/* ── 404 page ───────────────────────────────────────────────────────────────*/
.not-found{padding:32px 0 48px}
.not-found-hero{text-align:center;max-width:760px;margin:0 auto 36px}
.nf-code{font-size:96px;line-height:1;margin:0 0 4px;color:var(--brand);font-weight:800;letter-spacing:-.02em}
.nf-title{margin:0 0 12px;font-size:28px}
.nf-lead{margin:0 0 18px;font-size:18px;color:var(--text)}
.nf-requested{display:inline-flex;flex-direction:column;align-items:center;gap:6px;margin:0 auto 18px;padding:12px 18px;background:#fff7ed;border:1px solid #fdba74;border-left:4px solid #ea580c;border-radius:8px;max-width:100%}
.nf-requested-label{font-size:13px;font-weight:600;color:#9a3412;letter-spacing:.01em}
.nf-requested-url{font-family:ui-monospace,Menlo,Consolas,monospace;background:#fff;border:1px solid #fdba74;color:#7c2d12;padding:5px 10px;border-radius:5px;font-size:14px;word-break:break-all;max-width:100%}
.nf-note{margin:0 auto 22px;max-width:620px;font-size:15px;line-height:1.6;color:var(--muted)}
.nf-actions{justify-content:center;display:flex;gap:10px;flex-wrap:wrap}
.nf-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:18px;margin-top:8px;align-items:start}
.nf-card{background:#fff;border:1px solid var(--line);border-radius:10px;padding:18px 20px;transition:box-shadow .15s ease,transform .15s ease}
.nf-card:hover{box-shadow:0 4px 14px rgba(15,23,42,.06);transform:translateY(-1px)}
.nf-card h3{margin:0 0 14px;font-size:16px;color:var(--brand-dark);border-bottom:1px solid var(--line);padding-bottom:10px;display:flex;align-items:center;gap:8px;line-height:1.2}
.nf-icon{width:20px;height:20px;flex:0 0 20px;stroke:var(--brand);stroke-width:1.8;fill:none;stroke-linecap:round;stroke-linejoin:round}
.nf-card ul{list-style:none;padding:0;margin:0}
.nf-card li{margin:0;padding:5px 0;border-bottom:1px dashed transparent}
.nf-card li+li{border-top:1px solid #f1f4f8}
.nf-card a{color:var(--text);text-decoration:none;font-size:14px;line-height:1.4;display:block;padding:3px 0}
.nf-card a:hover{color:var(--brand);text-decoration:underline}
.nf-provinces{display:grid;grid-template-columns:1fr 1fr;gap:0 16px}
.nf-provinces li{font-size:13.5px}
.nf-provinces a{padding:4px 0;line-height:1.35}
.nf-card-provinces ul.nf-provinces li+li{border-top:none}
.nf-card-provinces ul.nf-provinces li{border-top:1px solid #f1f4f8}
.nf-card-provinces ul.nf-provinces li:nth-child(1),
.nf-card-provinces ul.nf-provinces li:nth-child(2){border-top:none}
@media(max-width:560px){.nf-code{font-size:72px}.nf-title{font-size:22px}.nf-lead{font-size:16px}.nf-provinces{grid-template-columns:1fr}.nf-card-provinces ul.nf-provinces li:nth-child(2){border-top:1px solid #f1f4f8}}
/* ── Legal / policy pages ───────────────────────────────────────────────────*/
.legal-page{max-width:none}
.legal-page .legal-body{margin-left:auto;margin-right:auto}
.legal-header{margin-bottom:18px}
.legal-header h1{margin:0 0 8px;font-size:30px;letter-spacing:-.01em}
.legal-header .lead{margin:0;font-size:15px;color:var(--muted);line-height:1.55;max-width:760px}
.legal-body{padding:28px 32px;font-size:15px;line-height:1.7;color:var(--text)}
.legal-body h2{margin:30px 0 10px;font-size:19px;color:var(--brand-dark);padding-top:14px;border-top:1px solid var(--line)}
.legal-body h2:first-of-type{padding-top:0;border-top:none;margin-top:6px}
.legal-body h3{margin:22px 0 8px;font-size:16px;color:var(--text)}
.legal-body p{margin:0 0 14px}
.legal-body ul,.legal-body ol{margin:0 0 16px;padding-left:22px}
.legal-body li{margin:0 0 6px}
.legal-body a{color:var(--brand);text-decoration:none}
.legal-body a:hover{text-decoration:underline}
.legal-body strong{color:var(--text)}
.legal-body em{color:var(--muted)}
.legal-body hr{border:none;border-top:1px solid var(--line);margin:24px 0}
.legal-nav{display:flex;flex-wrap:wrap;gap:6px 8px;padding:14px 16px;margin:0 0 22px;background:#f7f9fc;border:1px solid var(--line);border-radius:8px;font-size:13.5px}
.legal-nav a{display:inline-block;padding:5px 10px;border-radius:5px;background:#fff;border:1px solid var(--line);color:var(--text);text-decoration:none;line-height:1.2;transition:background .12s ease,color .12s ease,border-color .12s ease}
.legal-nav a:hover{background:var(--brand);color:#fff;border-color:var(--brand);text-decoration:none}
@media(max-width:640px){.legal-body{padding:20px 18px;font-size:14.5px}.legal-header h1{font-size:24px}.legal-body h2{font-size:17px}}
