
:root{
  --bg:#fbfaf8;
  --paper:#ffffff;
  --ink:#0e1728;
  --muted:#5e6a7f;
  --soft:#eef2fb;
  --line:#dfe5ef;
  --blue:#0754d8;
  --purple:#b84dde;
  --violet:#7257e8;
  --green:#18b878;
  --orange:#ff9b33;
  --red:#ef426f;
  --shadow:0 24px 70px rgba(23,31,50,.08);
  --shadow-sm:0 12px 34px rgba(23,31,50,.06);
  --radius:26px;
  --serif: Georgia, "Times New Roman", serif;
  --sans: "DM Sans", Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--sans);
  color:var(--ink);
  background:
    radial-gradient(circle at 8% 18%, rgba(216,180,254,.28), transparent 26rem),
    radial-gradient(circle at 92% 36%, rgba(255,210,151,.26), transparent 26rem),
    radial-gradient(circle at 85% 82%, rgba(145,224,235,.32), transparent 30rem),
    linear-gradient(180deg,#fff 0%,#fbfaf8 100%);
  min-height:100vh;
  -webkit-font-smoothing:antialiased;
}
a{color:inherit}
.container{width:min(1180px,calc(100% - 48px));margin:0 auto}
.site-header{position:sticky;top:0;z-index:80;background:rgba(255,255,255,.76);backdrop-filter:blur(18px);border-bottom:1px solid rgba(223,229,239,.55)}
.nav{height:76px;display:flex;align-items:center;justify-content:space-between;gap:28px}
.brand{display:flex;align-items:center;gap:12px;text-decoration:none;font-weight:700;font-size:24px;letter-spacing:-.02em}
.logo-mark{width:28px;height:28px;display:inline-grid;place-items:center;border:2px solid var(--ink);border-radius:50%;position:relative}
.logo-mark:before,.logo-mark:after{content:"";position:absolute;border:2px solid var(--ink);border-radius:50%;width:20px;height:20px;opacity:.75}
.logo-mark:before{transform:translateX(-4px)}.logo-mark:after{transform:translateX(4px)}
.nav-links{display:flex;align-items:center;gap:26px;font-size:15px;color:#233251}
.nav-links a{text-decoration:none}
.nav-links a:hover,.nav-links a.active{color:var(--blue)}
.nav-actions{display:flex;gap:12px;align-items:center}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border-radius:999px;padding:13px 22px;border:1px solid var(--line);background:#fff;text-decoration:none;font-weight:700;font-size:15px;transition:transform .18s,box-shadow .18s,border-color .18s}
.btn:hover{transform:translateY(-1px);box-shadow:var(--shadow-sm)}
.btn-primary{border:0;color:#fff;background:linear-gradient(100deg,var(--blue),var(--purple));box-shadow:0 14px 28px rgba(91,82,220,.18)}
.btn-dark{background:var(--ink);color:#fff;border-color:var(--ink)}
.btn-ghost{background:rgba(255,255,255,.72)}
.kicker{display:inline-flex;align-items:center;gap:10px;border:1px solid var(--line);background:rgba(255,255,255,.75);border-radius:999px;padding:8px 14px;color:#40506b;font-size:13px;font-weight:600}
.kicker:before{content:"";width:6px;height:6px;background:linear-gradient(90deg,var(--blue),var(--purple));border-radius:50%}
.label{font-size:12px;text-transform:uppercase;letter-spacing:.16em;color:#647391;font-weight:800}
h1,h2,h3{font-family:var(--serif);font-weight:700;letter-spacing:-.045em}
h1{font-size:clamp(48px,7vw,86px);line-height:.98}
h2{font-size:clamp(34px,4.6vw,58px);line-height:1.02}
h3{font-size:24px;line-height:1.15}
.grad{font-style:italic;background:linear-gradient(100deg,var(--blue),var(--purple));-webkit-background-clip:text;background-clip:text;color:transparent}
p{color:var(--muted);line-height:1.75}
.hero{padding:76px 0 70px}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:74px;align-items:center}
.hero-copy h1{margin:24px 0 22px;max-width:670px}
.hero-copy .lead{font-size:18px;max-width:610px}
.cta-row{display:flex;gap:14px;align-items:center;flex-wrap:wrap;margin:30px 0 22px}
.trust-row{display:flex;gap:28px;flex-wrap:wrap;color:#607088;font-size:13px}
.trust-row span:before{content:"✓";color:var(--green);font-weight:800;margin-right:8px}
.check-card,.panel{background:rgba(255,255,255,.82);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:30px}
.check-card h3{font-family:var(--serif);font-size:27px;margin-bottom:6px}
.field-label{display:block;font-size:11px;text-transform:uppercase;letter-spacing:.12em;color:#63718a;font-weight:800;margin:18px 0 8px}
.select-row{display:grid;grid-template-columns:1fr auto 1fr;gap:14px;align-items:end}
.platform-select,.search-input,.form-input,.form-textarea{width:100%;min-height:52px;border:1px solid var(--line);border-radius:14px;background:#fff;padding:0 14px;font-family:var(--sans);font-size:15px;color:var(--ink);outline:0}
.platform-select:focus,.search-input:focus,.form-input:focus,.form-textarea:focus{border-color:#9a81ff;box-shadow:0 0 0 4px rgba(114,87,232,.08)}
.form-textarea{padding:14px;min-height:140px;resize:vertical}
.arrow-pill{width:42px;height:42px;border-radius:50%;background:var(--soft);display:grid;place-items:center;color:var(--blue);margin-bottom:5px}
.main-button{width:100%;margin-top:18px;height:56px;border:0;border-radius:999px;color:#fff;font-weight:800;font-size:15px;cursor:pointer;background:linear-gradient(100deg,var(--blue),var(--purple))}
.stats-mini{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border:1px solid var(--line);border-radius:18px;margin-top:20px;overflow:hidden;background:#fff}
.stats-mini div{padding:16px;text-align:center;border-right:1px solid var(--line);font-size:12px;color:var(--muted)}.stats-mini div:last-child{border-right:0}.stats-mini strong{display:block;font-size:21px;color:var(--ink);margin-bottom:2px}
.preview-box{display:none;margin-top:20px;border:1px solid var(--line);border-radius:22px;background:#fff;padding:20px}
.preview-box.active{display:block}
.preview-head{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:16px}
.preview-route{display:flex;align-items:center;gap:10px;font-weight:800}
.platform-icon{width:28px;height:28px;border-radius:8px;object-fit:contain;border:1px solid var(--line);background:#fff}
.preview-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.preview-tile{background:#fbfcff;border:1px solid var(--line);border-radius:16px;padding:15px}
.preview-tile strong{display:block;margin-bottom:8px}.preview-tile li{list-style:none;color:var(--muted);font-size:13px;line-height:1.6;margin:6px 0}.preview-tile li:before{content:"•";color:var(--blue);font-weight:900;margin-right:8px}
.section{padding:72px 0}.section-center{text-align:center}.section-center p{max-width:720px;margin:14px auto 0}
.feature-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:34px}
.feature-card{display:flex;gap:18px;align-items:flex-start;background:rgba(255,255,255,.72);border:1px solid var(--line);border-radius:22px;padding:24px;min-height:145px;box-shadow:0 10px 30px rgba(23,31,50,.035)}
.ico{width:52px;height:52px;border-radius:18px;display:grid;place-items:center;font-size:22px;flex:0 0 auto}
.ico.green{background:#e4f8ee;color:var(--green)}.ico.blue{background:#e7efff;color:var(--blue)}.ico.pink{background:#ffe9f0;color:var(--red)}.ico.purple{background:#f0eaff;color:var(--violet)}.ico.orange{background:#fff1df;color:var(--orange)}
.feature-card h3{font-family:var(--sans);font-size:17px;letter-spacing:-.01em;margin-bottom:7px}.feature-card p{font-size:14px;line-height:1.6}
.route-promo{display:grid;grid-template-columns:.86fr 1.14fr;gap:52px;align-items:center}
.mock-route{background:rgba(255,255,255,.86);border:1px solid var(--line);border-radius:26px;box-shadow:var(--shadow);padding:24px}
.mock-top{display:flex;align-items:center;justify-content:space-between;gap:20px;border-bottom:1px solid var(--line);padding-bottom:18px;margin-bottom:18px}
.mock-platforms{display:flex;align-items:center;gap:18px;font-weight:800;font-size:20px}
.tabs{display:flex;gap:18px;border-bottom:1px solid var(--line);margin-bottom:18px;overflow:auto}.tabs span{padding:0 0 12px;font-weight:700;font-size:13px;color:#62718a}.tabs span.active{color:var(--blue);border-bottom:2px solid var(--blue)}
.bars{display:grid;gap:12px}.bar-row{display:grid;grid-template-columns:120px 1fr 42px;align-items:center;gap:10px;font-size:13px;color:#52617a}.bar{height:8px;background:#eef2fb;border-radius:99px;overflow:hidden}.bar i{display:block;height:100%;border-radius:99px;background:var(--green)}.bar.orange i{background:var(--orange)}.bar.red i{background:var(--red)}
.pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:38px}.price-card{position:relative;background:#fff;border:1px solid var(--line);border-radius:24px;padding:30px;box-shadow:var(--shadow-sm)}.price-card.popular{border-color:#8d69f2;box-shadow:0 20px 54px rgba(106,77,230,.14)}.badge{display:inline-flex;border-radius:999px;background:#edf7ef;color:#16885a;font-size:12px;font-weight:800;padding:7px 10px}.popular-label{position:absolute;top:-15px;left:50%;transform:translateX(-50%);background:linear-gradient(90deg,var(--blue),var(--purple));color:#fff;border-radius:999px;padding:8px 16px;font-size:12px;font-weight:900;letter-spacing:.08em}.price{font-family:var(--serif);font-size:42px;color:var(--ink);margin:22px 0 6px}.price small{font-family:var(--sans);font-size:13px;color:var(--violet)}.check-list{list-style:none;display:grid;gap:12px;margin:22px 0}.check-list li{color:var(--muted);font-size:14px}.check-list li:before{content:"✓";color:var(--green);font-weight:900;margin-right:10px}
.faq{max-width:920px;margin:34px auto 0;display:grid;gap:10px}.faq-item{background:#fff;border:1px solid var(--line);border-radius:14px;padding:17px 20px;display:flex;justify-content:space-between;font-weight:700;color:#233251}
.footer{padding:54px 0 36px;border-top:1px solid var(--line);text-align:center;margin-top:54px}.footer-tag{font-family:var(--serif);font-style:italic;font-size:22px;margin-bottom:26px}.footer-links{display:flex;justify-content:center;gap:28px;flex-wrap:wrap;color:#617088;font-size:14px;margin-bottom:22px}.footer-links a{text-decoration:none}
.compare-hero{padding:72px 0 28px}.compare-hero-grid{display:grid;grid-template-columns:1fr .9fr;gap:60px;align-items:center}.route-visual{display:flex;align-items:center;justify-content:center;gap:48px}.mini-platform{width:140px;height:140px;border:1px solid var(--line);background:#fff;border-radius:22px;display:grid;place-items:center;text-align:center;box-shadow:var(--shadow-sm)}.mini-platform img{width:42px;height:42px;object-fit:contain;margin-bottom:10px}.route-dot{width:56px;height:56px;border-radius:50%;display:grid;place-items:center;color:#fff;background:linear-gradient(90deg,var(--blue),var(--purple))}
.filter-panel{background:#fff;border:1px solid var(--line);border-radius:24px;box-shadow:var(--shadow);padding:24px;margin:28px 0}.filter-grid{display:grid;grid-template-columns:1fr 1fr 1.3fr .7fr;gap:16px;align-items:end}.chips{display:flex;gap:10px;flex-wrap:wrap;margin-top:18px}.chip{border:1px solid var(--line);border-radius:999px;background:#fff;padding:10px 15px;color:#52617a;font-weight:700;font-size:13px}.chip.active{border-color:#aa7cf4;color:#7f43d6;background:#fbf6ff}
.results-layout{display:grid;grid-template-columns:1fr 270px;gap:24px}.route-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}.route-card{background:#fff;border:1px solid var(--line);border-radius:22px;padding:22px;box-shadow:var(--shadow-sm)}.route-card-icons{display:flex;align-items:center;gap:12px;margin-bottom:16px}.route-card h3{font-size:24px;margin-bottom:10px}.score-line{display:grid;grid-template-columns:90px 1fr 34px;gap:8px;align-items:center;font-size:12px;color:var(--muted);margin:8px 0}.side-card{background:#fff;border:1px solid var(--line);border-radius:22px;padding:22px;box-shadow:var(--shadow-sm);margin-bottom:18px}.side-card h3{font-family:var(--sans);font-size:18px;letter-spacing:0;margin-bottom:14px}.side-card a{display:flex;justify-content:space-between;padding:10px 0;text-decoration:none;border-bottom:1px solid #eef2fb;color:#52617a;font-size:13px}
.route-detail-hero{padding:64px 0}.breadcrumb{display:flex;gap:10px;color:#6d7890;font-size:13px;margin-bottom:26px}.route-detail-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:58px;align-items:center}.route-title h1{font-size:clamp(48px,6vw,74px)}.hero-badges{display:flex;gap:12px;flex-wrap:wrap;margin:22px 0}.summary-card{background:#fff;border:1px solid var(--line);border-radius:26px;box-shadow:var(--shadow);padding:28px}.summary-three{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}.summary-three strong{font-size:32px;display:block;margin:7px 0}.summary-three small{color:var(--muted);line-height:1.5}
.category-tabs{display:grid;grid-template-columns:repeat(6,1fr);background:#fff;border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow-sm);overflow:hidden;margin-bottom:24px}.category-tabs span{padding:18px;text-align:center;font-weight:800;color:#52617a;border-right:1px solid var(--line)}.category-tabs span:last-child{border-right:0}.category-tabs .active{color:var(--blue);box-shadow:inset 0 -3px 0 var(--blue)}
.two-col{display:grid;grid-template-columns:1.35fr .85fr;gap:22px}.data-table{width:100%;border-collapse:collapse}.data-table th,.data-table td{padding:14px;border-bottom:1px solid #edf1f7;text-align:left;color:#52617a;font-size:14px}.data-table th{color:#253554;font-weight:900}.insight-list{display:grid;gap:18px}.insight{display:flex;gap:14px}.insight .ico{width:42px;height:42px;border-radius:50%;font-size:17px}.panel h2{font-size:28px;margin-bottom:18px}.panel h3{font-family:var(--sans);font-size:16px;letter-spacing:0;margin-bottom:5px}.check-panel{display:grid;grid-template-columns:1fr 1fr;gap:22px;margin-top:22px}
.simple-hero{text-align:center;padding:72px 0 44px}.simple-hero h1{max-width:850px;margin:18px auto}.simple-hero p{max-width:650px;margin:0 auto}.comparison-table{background:#fff;border:1px solid var(--line);border-radius:20px;overflow:hidden;box-shadow:var(--shadow-sm);margin-top:34px}.comparison-table table{width:100%;border-collapse:collapse}.comparison-table th,.comparison-table td{padding:17px;border-bottom:1px solid #edf1f7;text-align:center;color:#52617a}.comparison-table th:first-child,.comparison-table td:first-child{text-align:left;color:#253554;font-weight:800}
.about-story{display:grid;grid-template-columns:.7fr 1.3fr;gap:60px;align-items:start}.process-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}.principle-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}.step-num{display:inline-flex;align-items:center;justify-content:center;width:36px;height:28px;border-radius:10px;background:#e8f7ef;color:var(--green);font-weight:900;margin-bottom:28px}
.contact-grid{display:grid;grid-template-columns:1.35fr .85fr;gap:28px}.form-grid{display:grid;gap:16px}.resource{display:flex;align-items:center;gap:14px;padding:16px;border-bottom:1px solid #edf1f7}.resource:last-child{border-bottom:0}.cta-band{background:linear-gradient(100deg,rgba(114,87,232,.10),rgba(255,208,150,.18));border:1px solid var(--line);border-radius:26px;padding:28px;margin-top:34px;display:flex;align-items:center;justify-content:space-between;gap:24px}
@media(max-width:980px){.hero-grid,.compare-hero-grid,.route-promo,.route-detail-grid,.two-col,.results-layout,.contact-grid,.about-story{grid-template-columns:1fr}.feature-grid,.pricing-grid,.route-grid{grid-template-columns:1fr 1fr}.filter-grid{grid-template-columns:1fr 1fr}.category-tabs{grid-template-columns:repeat(3,1fr)}.summary-three{grid-template-columns:1fr}.process-grid,.principle-grid{grid-template-columns:1fr 1fr}}
@media(max-width:640px){.container{width:min(100% - 28px,1180px)}.nav-links{display:none}.hero{padding-top:42px}.feature-grid,.pricing-grid,.route-grid,.preview-grid,.check-panel,.process-grid,.principle-grid,.filter-grid{grid-template-columns:1fr}.select-row{grid-template-columns:1fr}.arrow-pill{display:none}.stats-mini{grid-template-columns:1fr}.stats-mini div{border-right:0;border-bottom:1px solid var(--line)}.category-tabs{grid-template-columns:1fr}.cta-band{flex-direction:column;align-items:flex-start}h1{font-size:44px}.brand{font-size:20px}}


/* v10 fixes */
.nav-links a[href="/compare/"], .nav-links a[href="/pricing/"],
.footer-links a[href="/compare/"], .footer-links a[href="/pricing/"] { display:none !important; }

.search-dd { position:relative; }
.search-dd-button{
  width:100%; min-height:52px; border:1px solid var(--line); border-radius:14px;
  background:#fff; padding:0 14px; font-family:var(--sans); font-size:15px; color:var(--ink);
  display:flex; align-items:center; justify-content:space-between; gap:12px; cursor:pointer;
}
.search-dd-current{display:flex;align-items:center;gap:10px;min-width:0}
.search-dd-current img{width:22px;height:22px;border-radius:6px;object-fit:contain;border:1px solid var(--line)}
.search-dd-current span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.search-dd-panel{
  display:none; position:absolute; top:calc(100% + 8px); left:0; right:0; z-index:60;
  background:#fff; border:1px solid var(--line); border-radius:18px; box-shadow:var(--shadow);
  overflow:hidden;
}
.search-dd.open .search-dd-panel{display:block}
.search-dd-input-wrap{padding:12px;border-bottom:1px solid var(--line)}
.search-dd-input{width:100%;height:42px;border:1px solid var(--line);border-radius:12px;padding:0 12px;font-family:var(--sans);outline:0}
.search-dd-input:focus{border-color:#9a81ff;box-shadow:0 0 0 4px rgba(114,87,232,.08)}
.search-dd-list{max-height:270px;overflow:auto;padding:6px}
.search-dd-item{display:flex;align-items:center;gap:10px;width:100%;border:0;background:transparent;border-radius:12px;padding:10px;cursor:pointer;text-align:left;font-family:var(--sans);font-size:14px;color:var(--ink)}
.search-dd-item:hover,.search-dd-item.active{background:#f5f7fc}
.search-dd-item img{width:22px;height:22px;border-radius:6px;object-fit:contain;border:1px solid var(--line)}
.search-dd-empty{padding:18px;text-align:center;color:var(--muted);font-size:14px}
.full-route-preview{display:none;margin:28px auto 0;width:min(1180px,calc(100% - 48px))}
.full-route-preview.active{display:block}
.full-route-preview .preview-box{display:block;margin:0;padding:28px;border-radius:26px;box-shadow:var(--shadow);background:rgba(255,255,255,.88)}
.full-route-preview h2{font-size:clamp(28px,3.4vw,44px);margin-bottom:12px}
.full-preview-head{display:flex;justify-content:space-between;gap:18px;align-items:flex-start;flex-wrap:wrap;margin-bottom:22px}
.full-preview-route{display:flex;align-items:center;gap:12px;font-size:24px;font-weight:800}
.full-preview-route img{width:34px;height:34px;border-radius:9px;border:1px solid var(--line)}
.full-preview-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:20px}
.full-preview-card{background:#fbfcff;border:1px solid var(--line);border-radius:20px;padding:22px}
.full-preview-card h3{font-family:var(--sans);font-size:17px;letter-spacing:0;margin-bottom:10px}
.full-preview-card ul{list-style:none;display:grid;gap:8px}
.full-preview-card li{color:var(--muted);line-height:1.6;font-size:14px}
.full-preview-card li:before{content:"•";color:var(--blue);font-weight:900;margin-right:8px}
.faq-item{cursor:pointer;align-items:flex-start;gap:18px;flex-wrap:wrap}
.faq-item .faq-answer{display:none;flex:0 0 100%;font-weight:400;color:var(--muted);line-height:1.7;padding-top:10px;border-top:1px solid #edf1f7;margin-top:4px}
.faq-item.open .faq-answer{display:block}
.faq-item.open > span:last-child{transform:rotate(180deg)}
.category-tabs span,.mock-tabs span{cursor:pointer}
.tab-panel{display:none}
.tab-panel.active{display:block}
.mock-tab-panel{display:none}
.mock-tab-panel.active{display:block}
@media(max-width:760px){
  .full-route-preview{width:min(100% - 28px,1180px)}
  .full-preview-grid{grid-template-columns:1fr}
  .full-preview-route{font-size:18px}
}


/* v10.1 remove mock-route tab labels */
.mock-route .tabs{display:none !important;}

/* v10.2 contact/logo/faq tweaks */
.faq,.faq-item,.faq-item .faq-answer{ text-align:left !important; }
.faq-item{ justify-content:space-between; }
.nav-actions{ display:none !important; }

/* v10.3 explicit d logo */
.logo-mark{width:24px !important;height:34px !important;display:inline-block !important;position:relative !important;border:0 !important;border-radius:0 !important;background:none !important;overflow:visible !important}
.logo-mark:before{content:"d" !important;position:absolute !important;left:0 !important;top:2px !important;color:var(--ink) !important;font-family:var(--serif) !important;font-size:42px !important;line-height:1 !important;font-weight:700 !important;border:0 !important;width:auto !important;height:auto !important;opacity:1 !important;transform:none !important}
.logo-mark:after{content:"" !important;position:absolute !important;left:18px !important;top:0 !important;width:8px !important;height:8px !important;border-radius:50% !important;background:var(--blue) !important;border:0 !important;opacity:1 !important;transform:none !important}


/* v11 expanded SEO route content */
.seo-longform{padding:54px 0 78px}
.seo-container{width:min(1180px,calc(100% - 48px));margin:0 auto;display:grid;gap:24px}
.seo-intro h2,.seo-toc h2,.seo-longform .panel h2{font-size:clamp(28px,3.1vw,44px);margin-bottom:16px}
.seo-longform .panel p{margin-bottom:14px}
.seo-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.seo-toc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-top:18px}
.seo-toc-grid a{display:block;text-decoration:none;border:1px solid var(--line);background:#fbfcff;border-radius:16px;padding:14px 16px;color:#233251;font-weight:800;font-size:14px}
.seo-toc-grid a:hover{border-color:#9a81ff;box-shadow:0 8px 24px rgba(114,87,232,.08)}
.seo-list{list-style:none;display:grid;gap:11px;margin:16px 0}
.seo-list li{position:relative;padding-left:26px;color:var(--muted);line-height:1.65}
.seo-list li:before{content:"✓";position:absolute;left:0;top:0;color:var(--green);font-weight:900}
.seo-list.warn li:before{content:"!";color:var(--orange)}
.seo-list.no li:before{content:"×";color:var(--red)}
.seo-table{width:100%;border-collapse:separate;border-spacing:0;border:1px solid var(--line);border-radius:18px;overflow:hidden;margin:18px 0 8px;background:#fff}
.seo-table th,.seo-table td{padding:15px 16px;border-bottom:1px solid #edf1f7;text-align:left;vertical-align:top;color:#52617a;line-height:1.55;font-size:14px}
.seo-table th{background:#fbfcff;color:#253554;font-weight:900}
.seo-table tr:last-child td{border-bottom:0}
.seo-steps{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:18px}
.seo-steps div{border:1px solid var(--line);background:#fbfcff;border-radius:18px;padding:18px}
.seo-steps strong{display:block;color:var(--ink);margin-bottom:8px}
.seo-steps p{font-size:14px;margin:0!important}
.seo-faq-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:18px}
.seo-faq{border:1px solid var(--line);background:#fbfcff;border-radius:18px;padding:18px}
.seo-faq h3{font-family:var(--sans);font-size:16px;letter-spacing:0;margin-bottom:8px}
.seo-faq p{font-size:14px;margin:0!important}
.seo-cta{text-align:center;background:linear-gradient(100deg,rgba(114,87,232,.10),rgba(255,208,150,.18))}
.seo-cta p{max-width:820px;margin-left:auto;margin-right:auto}
@media(max-width:980px){.seo-grid,.seo-faq-grid{grid-template-columns:1fr}.seo-toc-grid{grid-template-columns:1fr 1fr}.seo-steps{grid-template-columns:1fr 1fr}}
@media(max-width:640px){.seo-container{width:min(100% - 28px,1180px)}.seo-toc-grid,.seo-steps{grid-template-columns:1fr}}


/* v11.1 make route guide cover blocks more distinct */
.seo-toc-grid a{
  position:relative;
  min-height:96px;
  display:flex;
  align-items:flex-end;
  padding:18px 18px 18px 72px;
  font-size:15px;
  line-height:1.25;
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease;
  overflow:hidden;
}
.seo-toc-grid a:before{
  position:absolute;
  left:18px;
  top:18px;
  width:40px;
  height:40px;
  border-radius:12px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:18px;
  font-weight:700;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.7);
}
.seo-toc-grid a:after{
  content:"";
  position:absolute;
  inset:auto 0 0 0;
  height:4px;
  opacity:.95;
}
.seo-toc-grid a:hover{
  transform:translateY(-2px);
  box-shadow:0 14px 34px rgba(43,56,95,.10);
}
.seo-toc-grid a:nth-child(1){background:linear-gradient(180deg,#f8fbff 0%,#eef5ff 100%);border-color:#cad8f0}
.seo-toc-grid a:nth-child(1):before{content:"◫";background:#dfeafd;color:#3156c7}
.seo-toc-grid a:nth-child(1):after{background:linear-gradient(90deg,#6fa2ff,#3156c7)}

.seo-toc-grid a:nth-child(2){background:linear-gradient(180deg,#fbfcf7 0%,#f2f7e6 100%);border-color:#dbe5bc}
.seo-toc-grid a:nth-child(2):before{content:"◎";background:#e8f0cb;color:#627b00}
.seo-toc-grid a:nth-child(2):after{background:linear-gradient(90deg,#bedc73,#7ea21d)}

.seo-toc-grid a:nth-child(3){background:linear-gradient(180deg,#fffaf6 0%,#fff0e6 100%);border-color:#f0d4bb}
.seo-toc-grid a:nth-child(3):before{content:"↯";background:#ffe2cb;color:#d06b20}
.seo-toc-grid a:nth-child(3):after{background:linear-gradient(90deg,#ffc48a,#ea7a24)}

.seo-toc-grid a:nth-child(4){background:linear-gradient(180deg,#fcf9ff 0%,#f2ecff 100%);border-color:#d9cdf3}
.seo-toc-grid a:nth-child(4):before{content:"≋";background:#e8ddff;color:#7555d8}
.seo-toc-grid a:nth-child(4):after{background:linear-gradient(90deg,#b9a0ff,#7c5cf0)}

.seo-toc-grid a:nth-child(5){background:linear-gradient(180deg,#f9feff 0%,#eaf8fa 100%);border-color:#c8e6e8}
.seo-toc-grid a:nth-child(5):before{content:"◌";background:#daf1f3;color:#1e8a98}
.seo-toc-grid a:nth-child(5):after{background:linear-gradient(90deg,#74d8df,#1797a4)}

.seo-toc-grid a:nth-child(6){background:linear-gradient(180deg,#fffafb 0%,#ffeef3 100%);border-color:#f0cbd7}
.seo-toc-grid a:nth-child(6):before{content:"⇄";background:#ffdfe8;color:#cf4a75}
.seo-toc-grid a:nth-child(6):after{background:linear-gradient(90deg,#ff9bb8,#dd4f7e)}

.seo-toc-grid a:nth-child(7){background:linear-gradient(180deg,#f9fcff 0%,#edf1fb 100%);border-color:#cfd7ed}
.seo-toc-grid a:nth-child(7):before{content:"→";background:#e0e7f8;color:#4d63b3}
.seo-toc-grid a:nth-child(7):after{background:linear-gradient(90deg,#9eb0e5,#5b6dbb)}

.seo-toc-grid a:nth-child(8){background:linear-gradient(180deg,#fbfbff 0%,#eef1f8 100%);border-color:#d4d9ea}
.seo-toc-grid a:nth-child(8):before{content:"✓";background:#e2e7f2;color:#49607e}
.seo-toc-grid a:nth-child(8):after{background:linear-gradient(90deg,#bac6dc,#647692)}

@media(max-width:640px){
  .seo-toc-grid a{min-height:86px;padding:16px 16px 16px 64px}
  .seo-toc-grid a:before{left:16px;top:16px;width:36px;height:36px}
}


/* v11.2 align TOC cards and mirror icons/colors on target sections */
.seo-toc-grid a{
  min-height:116px;
  display:grid;
  grid-template-columns:72px 1fr;
  align-items:center;
  gap:16px;
  padding:18px 22px;
}
.seo-toc-grid a:before{
  position:relative;
  left:auto;
  top:auto;
  width:56px;
  height:56px;
  border-radius:18px;
  flex-shrink:0;
}
.seo-toc-grid a span,.seo-toc-grid a{align-content:center}
.seo-toc-grid a{font-size:16px;line-height:1.2}
.seo-toc-grid a br{display:none}

/* shared target-block header treatment */
#data-model, #migration-scope, #mapping, #attachments, #cutover{
  position:relative;
  overflow:hidden;
  padding-top:88px !important;
}
#api-limits, #methods, #qa{position:relative}
#api-limits .panel, #methods .panel, #qa .panel{
  position:relative;
  overflow:hidden;
  padding-top:88px !important;
}
#data-model:before, #migration-scope:before, #mapping:before, #attachments:before, #cutover:before,
#api-limits .panel:first-child:before, #methods .panel:first-child:before, #qa .panel:first-child:before{
  position:absolute;
  left:22px;
  top:22px;
  width:52px;
  height:52px;
  border-radius:16px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:22px;
  font-weight:700;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.65);
}
#data-model:after, #migration-scope:after, #mapping:after, #attachments:after, #cutover:after,
#api-limits .panel:first-child:after, #methods .panel:first-child:after, #qa .panel:first-child:after{
  content:"";
  position:absolute;
  left:0; right:0; top:0;
  height:5px;
}
#data-model h2, #migration-scope h2, #mapping h2, #attachments h2, #cutover h2,
#api-limits .panel:first-child h2, #methods .panel:first-child h2, #qa .panel:first-child h2{
  max-width:calc(100% - 84px);
}

/* data model */
#data-model{background:linear-gradient(180deg,#f8fbff 0%,#eef5ff 100%);border-color:#cad8f0}
#data-model:before{content:"◫";background:#dfeafd;color:#3156c7}
#data-model:after{background:linear-gradient(90deg,#6fa2ff,#3156c7)}

/* migration scope */
#migration-scope{background:linear-gradient(180deg,#fbfcf7 0%,#f2f7e6 100%);border-color:#dbe5bc}
#migration-scope:before{content:"◎";background:#e8f0cb;color:#627b00}
#migration-scope:after{background:linear-gradient(90deg,#bedc73,#7ea21d)}

/* mapping */
#mapping{background:linear-gradient(180deg,#fcf9ff 0%,#f2ecff 100%);border-color:#d9cdf3}
#mapping:before{content:"≋";background:#e8ddff;color:#7555d8}
#mapping:after{background:linear-gradient(90deg,#b9a0ff,#7c5cf0)}

/* api limits */
#api-limits .panel:first-child{background:linear-gradient(180deg,#fffaf6 0%,#fff0e6 100%);border-color:#f0d4bb}
#api-limits .panel:first-child:before{content:"↯";background:#ffe2cb;color:#d06b20}
#api-limits .panel:first-child:after{background:linear-gradient(90deg,#ffc48a,#ea7a24)}
#api-limits .panel:last-child{background:#fffdf9;border-color:#f0dfcf}

/* attachments */
#attachments{background:linear-gradient(180deg,#f9feff 0%,#eaf8fa 100%);border-color:#c8e6e8}
#attachments:before{content:"◌";background:#daf1f3;color:#1e8a98}
#attachments:after{background:linear-gradient(90deg,#74d8df,#1797a4)}

/* methods */
#methods .panel:first-child{background:linear-gradient(180deg,#fffafb 0%,#ffeef3 100%);border-color:#f0cbd7}
#methods .panel:first-child:before{content:"⇄";background:#ffdfe8;color:#cf4a75}
#methods .panel:first-child:after{background:linear-gradient(90deg,#ff9bb8,#dd4f7e)}
#methods .panel:last-child{background:#fff9fb;border-color:#efd8e2}

/* cutover */
#cutover{background:linear-gradient(180deg,#f9fcff 0%,#edf1fb 100%);border-color:#cfd7ed}
#cutover:before{content:"→";background:#e0e7f8;color:#4d63b3}
#cutover:after{background:linear-gradient(90deg,#9eb0e5,#5b6dbb)}

/* qa */
#qa .panel:first-child{background:linear-gradient(180deg,#fbfbff 0%,#eef1f8 100%);border-color:#d4d9ea}
#qa .panel:first-child:before{content:"✓";background:#e2e7f2;color:#49607e}
#qa .panel:first-child:after{background:linear-gradient(90deg,#bac6dc,#647692)}
#qa .panel:last-child{background:#fafcff;border-color:#d9e1ee}

/* ensure old mapping table fits new padded header */
#mapping .data-table, #mapping table{margin-top:8px}

@media(max-width:980px){
  .seo-toc-grid a{grid-template-columns:64px 1fr;min-height:104px}
}
@media(max-width:640px){
  .seo-toc-grid a{grid-template-columns:56px 1fr;gap:14px;min-height:96px;padding:16px 18px}
  .seo-toc-grid a:before{width:44px;height:44px;border-radius:14px;font-size:18px}
  #data-model, #migration-scope, #mapping, #attachments, #cutover,
  #api-limits .panel, #methods .panel, #qa .panel{padding-top:80px !important}
}


/* v11.5 dot logo and favicon */
.brand{display:flex;align-items:center;gap:12px;text-decoration:none;font-weight:700;font-size:24px;letter-spacing:-.02em}
.logo-mark{width:16px;height:16px;display:inline-block;border:0 !important;border-radius:0 !important;position:relative;flex:0 0 auto;background:url('/assets/img/logo-dot.png') center/contain no-repeat !important}
.logo-mark:before,.logo-mark:after{display:none !important;content:none !important}


/* v11.6 restore lowercase d logo with blue dot */
.logo-mark{
  width:30px !important;
  height:36px !important;
  display:inline-block !important;
  position:relative !important;
  flex:0 0 30px !important;
  border:0 !important;
  border-radius:0 !important;
  background:none !important;
  overflow:visible !important;
}
.logo-mark:before{
  content:"d" !important;
  display:block !important;
  position:absolute !important;
  left:0 !important;
  top:1px !important;
  width:auto !important;
  height:auto !important;
  border:0 !important;
  border-radius:0 !important;
  background:none !important;
  color:var(--ink) !important;
  font-family:var(--serif) !important;
  font-size:42px !important;
  line-height:1 !important;
  font-weight:700 !important;
  opacity:1 !important;
  transform:none !important;
}
.logo-mark:after{
  content:"" !important;
  display:block !important;
  position:absolute !important;
  left:20px !important;
  top:0 !important;
  width:9px !important;
  height:9px !important;
  border:0 !important;
  border-radius:999px !important;
  background:#0754d8 !important;
  opacity:1 !important;
  transform:none !important;
}


/* v11.7 exact uploaded logo */
.logo-mark{
  width:32px !important;
  height:32px !important;
  display:inline-block !important;
  flex:0 0 32px !important;
  border:0 !important;
  border-radius:0 !important;
  background:url('/assets/img/site-logo.png') center/contain no-repeat !important;
  overflow:visible !important;
}
.logo-mark:before,
.logo-mark:after{
  content:none !important;
  display:none !important;
}


/* v11.8 exact uploaded logo, no upscale */
.logo-mark{
  width:10px !important;
  height:10px !important;
  display:inline-block !important;
  flex:0 0 10px !important;
  border:0 !important;
  border-radius:0 !important;
  background:url('/assets/img/site-logo.png') center/contain no-repeat !important;
  image-rendering:auto !important;
  overflow:visible !important;
}
.logo-mark:before,
.logo-mark:after{
  content:none !important;
  display:none !important;
}
.brand{ gap:18px !important; }


/* v11.9 logo from latest uploaded image */
.logo-mark{
  width:10px !important;
  height:10px !important;
  display:inline-block !important;
  flex:0 0 10px !important;
  border:0 !important;
  border-radius:0 !important;
  background:url('/assets/img/site-logo.png') center/contain no-repeat !important;
  overflow:visible !important;
}
.logo-mark:before,.logo-mark:after{
  content:none !important;
  display:none !important;
}
.brand{gap:18px !important;}


/* v12 Ahrefs fixes */
.route-directory-section{padding-top:44px}
.route-directory-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:28px;max-height:760px;overflow:auto;padding:6px 4px 10px}
.route-directory-grid a{display:block;text-decoration:none;border:1px solid var(--line);background:rgba(255,255,255,.74);border-radius:14px;padding:12px 14px;color:#233251;font-weight:700;font-size:13px;line-height:1.35}
.route-directory-grid a:hover{border-color:#9a81ff;box-shadow:0 8px 22px rgba(114,87,232,.08)}
.ai-editor-note{border:1px solid #d9cdf3;background:linear-gradient(180deg,#fcf9ff 0%,#f7f2ff 100%);border-radius:20px;padding:20px;margin-top:16px}
.ai-editor-note strong{display:block;color:var(--ink);margin-bottom:8px}
.ai-editor-note p{margin:0!important}
@media(max-width:980px){.route-directory-grid{grid-template-columns:1fr 1fr}}
@media(max-width:640px){.route-directory-grid{grid-template-columns:1fr;max-height:none}}


/* v12.1 collapsed crawlable route directory */
.route-directory-details{
  width:min(1180px,calc(100% - 48px));
  margin:0 auto;
}
.route-directory-details > summary{
  list-style:none;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  background:rgba(255,255,255,.82);
  border:1px solid var(--line);
  border-radius:22px;
  box-shadow:var(--shadow-sm);
  padding:22px 26px;
  color:var(--ink);
  font-weight:800;
}
.route-directory-details > summary::-webkit-details-marker{display:none}
.route-directory-details > summary span{
  font-family:var(--serif);
  font-size:clamp(26px,3.2vw,42px);
  letter-spacing:-.035em;
}
.route-directory-details > summary small{
  font-family:var(--sans);
  font-size:13px;
  color:var(--muted);
  border:1px solid var(--line);
  border-radius:999px;
  padding:8px 12px;
  background:#fff;
}
.route-directory-details[open] > summary{
  margin-bottom:22px;
}
.route-directory-details[open] > summary small:after{
  content:"";
}
.route-directory-details .label,
.route-directory-details h2{
  display:none;
}
.route-directory-details .route-directory-grid,
.route-directory-details .routes-grid,
.route-directory-details .directory-grid{
  margin-top:0;
}
@media(max-width:640px){
  .route-directory-details{width:min(100% - 28px,1180px)}
  .route-directory-details > summary{align-items:flex-start;flex-direction:column}
}


/* v12.2 fixed collapsed route directory */
.route-directory-details:not([open]) .route-directory-inner{
  display:none !important;
}
.route-directory-details[open] .route-directory-inner{
  display:block !important;
}
.route-directory-details > summary{
  user-select:none;
}
.route-directory-details > summary small::before{
  content:"";
}
.route-directory-details[open] > summary small{
  font-size:0;
}
.route-directory-details[open] > summary small::after{
  content:"Close directory";
  font-size:13px;
}
.route-directory-details:not([open]) > summary small{
  font-size:0;
}
.route-directory-details:not([open]) > summary small::after{
  content:"Open directory";
  font-size:13px;
}


/* v12.3 route directory toggle fixed */
.route-directory-section{
  padding:34px 0 68px;
}
.route-directory-toggle{
  width:100%;
  appearance:none;
  border:1px solid var(--line);
  background:rgba(255,255,255,.88);
  border-radius:22px;
  box-shadow:var(--shadow-sm);
  padding:22px 26px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  cursor:pointer;
  color:var(--ink);
  text-align:left;
}
.route-directory-toggle span{
  font-family:var(--serif);
  font-size:clamp(30px,4vw,48px);
  line-height:1;
  letter-spacing:-.04em;
  font-weight:700;
}
.route-directory-toggle small{
  font-family:var(--sans);
  font-size:13px;
  color:var(--muted);
  border:1px solid var(--line);
  border-radius:999px;
  padding:8px 13px;
  background:#fff;
  white-space:nowrap;
}
.route-directory-toggle:hover{
  border-color:#cfd8ee;
  box-shadow:0 14px 36px rgba(23,31,50,.08);
}
.route-directory-list[hidden]{
  display:none !important;
}
.route-directory-list{
  margin-top:24px;
}
.route-directory-list .route-directory-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:10px;
  max-height:760px;
  overflow:auto;
  padding:6px 4px 10px;
}
.route-directory-list .route-directory-grid a{
  display:block;
  text-decoration:none;
  border:1px solid var(--line);
  background:rgba(255,255,255,.74);
  border-radius:14px;
  padding:12px 14px;
  color:#233251;
  font-weight:700;
  font-size:13px;
  line-height:1.35;
}
.route-directory-list .route-directory-grid a:hover{
  border-color:#9a81ff;
  box-shadow:0 8px 22px rgba(114,87,232,.08);
}
@media(max-width:980px){
  .route-directory-list .route-directory-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:640px){
  .route-directory-section{padding:24px 0 48px}
  .route-directory-toggle{flex-direction:column;align-items:flex-start}
  .route-directory-list .route-directory-grid{grid-template-columns:1fr;max-height:560px}
}


/* v12.4 native details route directory - no JS dependency */
.route-directory-section{
  padding:34px 0 68px;
}
.route-directory-native{
  width:100%;
}
.route-directory-native > summary{
  list-style:none;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  background:rgba(255,255,255,.88);
  border:1px solid var(--line);
  border-radius:22px;
  box-shadow:var(--shadow-sm);
  padding:22px 26px;
  color:var(--ink);
  user-select:none;
}
.route-directory-native > summary::-webkit-details-marker{
  display:none;
}
.route-directory-native > summary span{
  font-family:var(--serif);
  font-size:clamp(30px,4vw,48px);
  line-height:1;
  letter-spacing:-.04em;
  font-weight:700;
}
.route-directory-native > summary small{
  font-family:var(--sans);
  font-size:13px;
  color:var(--muted);
  border:1px solid var(--line);
  border-radius:999px;
  padding:8px 13px;
  background:#fff;
  white-space:nowrap;
}
.route-directory-native .close-label{
  display:none;
}
.route-directory-native[open] .open-label{
  display:none;
}
.route-directory-native[open] .close-label{
  display:inline-block;
}
.route-directory-native .route-directory-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:10px;
  max-height:760px;
  overflow:auto;
  padding:24px 4px 10px;
}
.route-directory-native:not([open]) .route-directory-grid{
  display:none !important;
}
.route-directory-native .route-directory-grid a{
  display:block;
  text-decoration:none;
  border:1px solid var(--line);
  background:rgba(255,255,255,.74);
  border-radius:14px;
  padding:12px 14px;
  color:#233251;
  font-weight:700;
  font-size:13px;
  line-height:1.35;
}
.route-directory-native .route-directory-grid a:hover{
  border-color:#9a81ff;
  box-shadow:0 8px 22px rgba(114,87,232,.08);
}
@media(max-width:980px){
  .route-directory-native .route-directory-grid{
    grid-template-columns:1fr 1fr;
  }
}
@media(max-width:640px){
  .route-directory-section{
    padding:24px 0 48px;
  }
  .route-directory-native > summary{
    flex-direction:column;
    align-items:flex-start;
  }
  .route-directory-native .route-directory-grid{
    grid-template-columns:1fr;
    max-height:560px;
  }
}


/* v12.5 CSS-only route directory toggle */
.route-directory-section{
  padding:34px 0 68px;
}
.route-directory-css{
  position:relative;
}
.route-directory-checkbox{
  position:absolute !important;
  width:1px !important;
  height:1px !important;
  overflow:hidden !important;
  clip:rect(0 0 0 0) !important;
  white-space:nowrap !important;
  border:0 !important;
  padding:0 !important;
  margin:-1px !important;
}
.route-directory-button{
  width:100%;
  border:1px solid var(--line);
  background:rgba(255,255,255,.88);
  border-radius:22px;
  box-shadow:var(--shadow-sm);
  padding:22px 26px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  cursor:pointer;
  color:var(--ink);
  text-align:left;
}
.route-directory-button span{
  font-family:var(--serif);
  font-size:clamp(30px,4vw,48px);
  line-height:1;
  letter-spacing:-.04em;
  font-weight:700;
}
.route-directory-button small{
  font-family:var(--sans);
  font-size:13px;
  color:var(--muted);
  border:1px solid var(--line);
  border-radius:999px;
  padding:8px 13px;
  background:#fff;
  white-space:nowrap;
}
.route-directory-css .close-label{
  display:none;
}
.route-directory-css .route-directory-list{
  display:none !important;
  margin-top:24px;
}
.route-directory-checkbox:checked ~ .route-directory-list{
  display:block !important;
}
.route-directory-checkbox:checked ~ .route-directory-button .open-label{
  display:none;
}
.route-directory-checkbox:checked ~ .route-directory-button .close-label{
  display:inline-block;
}
.route-directory-list .route-directory-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:10px;
  max-height:760px;
  overflow:auto;
  padding:6px 4px 10px;
}
.route-directory-list .route-directory-grid a{
  display:block;
  text-decoration:none;
  border:1px solid var(--line);
  background:rgba(255,255,255,.74);
  border-radius:14px;
  padding:12px 14px;
  color:#233251;
  font-weight:700;
  font-size:13px;
  line-height:1.35;
}
.route-directory-list .route-directory-grid a:hover{
  border-color:#9a81ff;
  box-shadow:0 8px 22px rgba(114,87,232,.08);
}
@media(max-width:980px){
  .route-directory-list .route-directory-grid{
    grid-template-columns:1fr 1fr;
  }
}
@media(max-width:640px){
  .route-directory-section{
    padding:24px 0 48px;
  }
  .route-directory-button{
    flex-direction:column;
    align-items:flex-start;
  }
  .route-directory-list .route-directory-grid{
    grid-template-columns:1fr;
    max-height:560px;
  }
}


/* v12.7 keep route links crawlable without visible directory text */
.route-directory-crawler-only{
  position:absolute !important;
  left:-10000px !important;
  top:auto !important;
  width:1px !important;
  height:1px !important;
  overflow:hidden !important;
}
.route-directory-crawler-only a{
  display:block;
}


/* v12.9 route directory links include platform logos */
.route-directory-crawler-only .crawler-route-link{
  display:flex;
  align-items:center;
  gap:8px;
}
.route-directory-crawler-only .crawler-route-link img{
  width:16px;
  height:16px;
  border-radius:4px;
  object-fit:contain;
  background:#fff;
}
.route-directory-crawler-only .route-arrow{
  color:#6b7890;
  font-weight:800;
}


/* v13 visible All migration routes with platform logos */
.route-directory-crawler-only{
  display:none !important;
}
.route-directory-section{
  padding:34px 0 68px;
}
.route-directory-visible{
  width:100%;
}
.route-directory-visible > summary{
  list-style:none;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  background:rgba(255,255,255,.88);
  border:1px solid var(--line);
  border-radius:22px;
  box-shadow:var(--shadow-sm);
  padding:22px 26px;
  color:var(--ink);
  user-select:none;
}
.route-directory-visible > summary::-webkit-details-marker{
  display:none;
}
.route-directory-visible > summary span{
  font-family:var(--serif);
  font-size:clamp(30px,4vw,48px);
  line-height:1;
  letter-spacing:-.04em;
  font-weight:700;
}
.route-directory-visible > summary small{
  font-family:var(--sans);
  font-size:13px;
  color:var(--muted);
  border:1px solid var(--line);
  border-radius:999px;
  padding:8px 13px;
  background:#fff;
  white-space:nowrap;
}
.route-directory-visible .close-label{
  display:none;
}
.route-directory-visible[open] .open-label{
  display:none;
}
.route-directory-visible[open] .close-label{
  display:inline-block;
}
.route-directory-visible .route-directory-grid{
  display:none;
}
.route-directory-visible[open] .route-directory-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:10px;
  max-height:760px;
  overflow:auto;
  padding:24px 4px 10px;
}
.route-directory-visible .route-dir-link{
  display:flex;
  align-items:center;
  gap:8px;
  text-decoration:none;
  border:1px solid var(--line);
  background:rgba(255,255,255,.74);
  border-radius:14px;
  padding:12px 14px;
  color:#233251;
  font-weight:700;
  font-size:13px;
  line-height:1.35;
  min-width:0;
}
.route-directory-visible .route-dir-link:hover{
  border-color:#9a81ff;
  box-shadow:0 8px 22px rgba(114,87,232,.08);
}
.route-directory-visible .route-dir-link img{
  width:18px;
  height:18px;
  border-radius:5px;
  object-fit:contain;
  background:#fff;
  flex:0 0 auto;
}
.route-directory-visible .route-dir-name{
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
  min-width:0;
}
.route-directory-visible .route-arrow{
  color:#6b7890;
  font-weight:900;
  flex:0 0 auto;
}
@media(max-width:980px){
  .route-directory-visible[open] .route-directory-grid{
    grid-template-columns:1fr 1fr;
  }
}
@media(max-width:640px){
  .route-directory-section{
    padding:24px 0 48px;
  }
  .route-directory-visible > summary{
    flex-direction:column;
    align-items:flex-start;
  }
  .route-directory-visible[open] .route-directory-grid{
    grid-template-columns:1fr;
    max-height:560px;
  }
}


/* v13.1 full-width layout + quick review contact form */
.container,
.seo-container{
  width:calc(100% - 64px) !important;
  max-width:none !important;
}
.full-route-preview{
  width:calc(100% - 64px) !important;
  max-width:none !important;
}
.hero-grid,
.route-promo,
.route-detail-grid,
.results-layout,
.contact-grid,
.about-story{
  gap:64px;
}
.feature-grid{
  grid-template-columns:repeat(3,minmax(0,1fr));
}
.route-directory-section{
  padding-top:24px;
}
.route-directory-visible[open] .route-directory-grid{
  grid-template-columns:repeat(4,minmax(0,1fr)) !important;
}
.quick-review-note{
  margin:18px 0 0;
  padding:18px 20px;
  border:1px solid #d9cdf3;
  background:linear-gradient(100deg,rgba(114,87,232,.08),rgba(255,208,150,.14));
  border-radius:18px;
  color:#35445f;
}
.quick-review-form{
  margin-top:22px;
  border:1px solid var(--line);
  background:#fff;
  border-radius:22px;
  padding:24px;
  box-shadow:0 12px 32px rgba(23,31,50,.055);
}
.quick-review-form-head{
  margin-bottom:18px;
}
.quick-review-form-head h3{
  font-family:var(--serif);
  font-size:28px;
  margin-bottom:6px;
}
.quick-review-form-head p{
  margin:0;
  max-width:820px;
}
.quick-review-form-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:14px;
}
.quick-review-form label{
  display:block;
}
.quick-review-form label span{
  display:block;
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:.12em;
  color:#63718a;
  font-weight:800;
  margin-bottom:8px;
}
.quick-review-form input,
.quick-review-form textarea{
  width:100%;
  border:1px solid var(--line);
  border-radius:14px;
  background:#fff;
  padding:13px 14px;
  font-family:var(--sans);
  font-size:14px;
  color:var(--ink);
  outline:0;
}
.quick-review-form input:focus,
.quick-review-form textarea:focus{
  border-color:#9a81ff;
  box-shadow:0 0 0 4px rgba(114,87,232,.08);
}
.quick-review-form input[readonly]{
  background:#f7f9fc;
  color:#52617a;
}
.quick-review-message{
  margin-top:14px;
}
.quick-review-form textarea{
  min-height:110px;
  resize:vertical;
}
.quick-review-form .btn{
  margin-top:16px;
  border:0;
}
@media(max-width:1180px){
  .route-directory-visible[open] .route-directory-grid{
    grid-template-columns:repeat(3,minmax(0,1fr)) !important;
  }
  .quick-review-form-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
}
@media(max-width:760px){
  .container,
  .seo-container,
  .full-route-preview{
    width:calc(100% - 28px) !important;
  }
  .route-directory-visible[open] .route-directory-grid,
  .quick-review-form-grid{
    grid-template-columns:1fr !important;
  }
}


/* v13.3 modern full-width polish */
body{
  background:
    radial-gradient(circle at 4% 10%, rgba(216,180,254,.28), transparent 32rem),
    radial-gradient(circle at 92% 18%, rgba(145,224,235,.28), transparent 30rem),
    radial-gradient(circle at 75% 86%, rgba(255,210,151,.24), transparent 34rem),
    linear-gradient(180deg,#ffffff 0%,#fbfaf8 100%);
}
.container,
.seo-container{
  width:min(1480px, calc(100% - 72px)) !important;
  max-width:1480px !important;
}
.homepage-hero{
  padding:82px 0 54px;
  position:relative;
  overflow:hidden;
}
.homepage-hero:before{
  content:"";
  position:absolute;
  inset:26px 36px auto 36px;
  height:calc(100% - 58px);
  min-height:620px;
  border:1px solid rgba(223,229,239,.8);
  border-radius:38px;
  background:
    linear-gradient(120deg,rgba(255,255,255,.62),rgba(255,255,255,.22)),
    radial-gradient(circle at 15% 18%, rgba(114,87,232,.10), transparent 28rem),
    radial-gradient(circle at 84% 32%, rgba(7,84,216,.08), transparent 26rem);
  box-shadow:0 28px 90px rgba(23,31,50,.055);
  z-index:-1;
}
.homepage-hero-grid{
  grid-template-columns:minmax(0,1.08fr) minmax(430px,.92fr);
  gap:clamp(48px,5vw,86px);
  align-items:center;
}
.hero-copy h1{
  max-width:850px;
  font-size:clamp(54px,6.8vw,106px);
  letter-spacing:-.06em;
}
.hero-copy .lead{
  max-width:720px;
  font-size:20px;
  line-height:1.75;
  color:#46566f;
}
.kicker{
  background:rgba(255,255,255,.82);
  box-shadow:0 8px 28px rgba(23,31,50,.045);
}
.hero-proof-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:12px;
  max-width:760px;
  margin-top:30px;
}
.hero-proof-grid div{
  border:1px solid var(--line);
  background:rgba(255,255,255,.74);
  border-radius:18px;
  padding:16px 18px;
  box-shadow:0 10px 30px rgba(23,31,50,.035);
}
.hero-proof-grid strong{
  display:block;
  font-family:var(--serif);
  font-size:30px;
  line-height:1;
  letter-spacing:-.04em;
  color:var(--ink);
}
.hero-proof-grid span{
  display:block;
  margin-top:5px;
  color:#66748a;
  font-size:13px;
  font-weight:700;
}
.check-card{
  padding:32px;
  border-radius:32px;
  background:rgba(255,255,255,.9);
  box-shadow:0 28px 80px rgba(23,31,50,.10);
}
.check-card h3{
  font-size:34px;
}
.search-dd-button,
.platform-select,
.search-input,
.form-input,
.form-textarea{
  min-height:58px;
  border-radius:18px;
  background:#fbfcff;
}
.main-button{
  height:60px;
  border-radius:18px;
  box-shadow:0 14px 34px rgba(91,82,220,.18);
}
.stats-mini{
  border-radius:22px;
}
.stats-mini div{
  padding:18px;
}
.full-route-preview{
  width:min(1480px, calc(100% - 72px)) !important;
  max-width:1480px !important;
}
.full-route-preview .preview-box{
  border-radius:34px;
  padding:34px;
}
.full-preview-grid{
  grid-template-columns:repeat(3,minmax(0,1fr));
}
.full-preview-card{
  min-height:220px;
  padding:26px;
  border-radius:24px;
  background:
    linear-gradient(180deg,rgba(255,255,255,.9),rgba(249,251,255,.86));
  box-shadow:0 14px 34px rgba(23,31,50,.04);
}
.full-preview-card h3{
  font-size:19px;
}
.quick-review-form{
  border-radius:28px;
  padding:28px;
}
.quick-review-form-grid{
  grid-template-columns:repeat(4,minmax(0,1fr));
}
.section{
  padding:82px 0;
}
.section-center{
  max-width:1120px;
  margin:0 auto;
}
.feature-grid{
  max-width:1480px;
  margin-left:auto;
  margin-right:auto;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:22px;
}
.feature-card{
  border-radius:28px;
  padding:28px;
  min-height:178px;
  background:rgba(255,255,255,.78);
  box-shadow:0 18px 50px rgba(23,31,50,.045);
}
.feature-card:nth-child(1), .feature-card:nth-child(4){
  background:linear-gradient(180deg,#ffffff,#f4f8ff);
}
.feature-card:nth-child(2), .feature-card:nth-child(5){
  background:linear-gradient(180deg,#ffffff,#fff7ee);
}
.feature-card:nth-child(3), .feature-card:nth-child(6){
  background:linear-gradient(180deg,#ffffff,#f3fbf7);
}
.ico{
  width:58px;
  height:58px;
  border-radius:20px;
}
.route-promo{
  grid-template-columns:minmax(0,.82fr) minmax(520px,1.18fr);
  gap:72px;
}
.mock-route{
  border-radius:34px;
  padding:30px;
}
.route-directory-section{
  padding:16px 0 78px;
}
.route-directory-visible > summary{
  border-radius:30px;
  padding:28px 34px;
  background:
    linear-gradient(120deg,rgba(255,255,255,.95),rgba(250,252,255,.88));
  box-shadow:0 20px 60px rgba(23,31,50,.07);
}
.route-directory-visible > summary span{
  font-size:clamp(34px,4.8vw,64px);
}
.route-directory-visible > summary small{
  padding:10px 16px;
}
.route-directory-visible[open] .route-directory-grid{
  grid-template-columns:repeat(4,minmax(0,1fr)) !important;
  gap:12px;
  max-height:680px;
  padding-top:26px;
}
.route-directory-visible .route-dir-link{
  border-radius:18px;
  padding:15px 16px;
  background:rgba(255,255,255,.82);
}
.route-directory-visible .route-dir-link img{
  width:22px;
  height:22px;
}
.pricing-grid,
.process-grid,
.principle-grid,
.seo-grid,
.seo-steps,
.seo-faq-grid{
  max-width:1480px;
  margin-left:auto;
  margin-right:auto;
}
.panel{
  border-radius:30px;
}
.footer{
  margin-top:0;
}
@media(max-width:1240px){
  .homepage-hero-grid,
  .route-promo{
    grid-template-columns:1fr;
  }
  .check-card{
    max-width:760px;
  }
  .route-directory-visible[open] .route-directory-grid{
    grid-template-columns:repeat(3,minmax(0,1fr)) !important;
  }
  .quick-review-form-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
}
@media(max-width:900px){
  .container,
  .seo-container,
  .full-route-preview{
    width:min(100% - 34px, 1480px) !important;
  }
  .homepage-hero:before{
    inset:14px 12px auto 12px;
    min-height:720px;
  }
  .hero-proof-grid,
  .feature-grid,
  .full-preview-grid,
  .quick-review-form-grid{
    grid-template-columns:1fr;
  }
  .route-directory-visible[open] .route-directory-grid{
    grid-template-columns:1fr 1fr !important;
  }
}
@media(max-width:640px){
  .homepage-hero{
    padding-top:48px;
  }
  .hero-copy h1{
    font-size:44px;
  }
  .hero-copy .lead{
    font-size:17px;
  }
  .check-card{
    padding:22px;
    border-radius:26px;
  }
  .route-directory-visible[open] .route-directory-grid{
    grid-template-columns:1fr !important;
  }
}


/* v13.4 smaller hero headline */
.homepage-hero-grid{
  grid-template-columns:minmax(0,.95fr) minmax(430px,1.05fr);
  gap:clamp(42px,4vw,72px);
}
.hero-copy h1{
  font-size:clamp(42px,4.8vw,78px) !important;
  line-height:1.02 !important;
  letter-spacing:-.045em !important;
  max-width:760px !important;
}
.hero-copy .lead{
  max-width:660px;
  font-size:18px;
  line-height:1.7;
}
@media(max-width:900px){
  .hero-copy h1{
    font-size:clamp(40px,9vw,62px) !important;
  }
}
@media(max-width:640px){
  .hero-copy h1{
    font-size:40px !important;
    line-height:1.04 !important;
  }
}


/* v13.5 compact hero and auto-preview polish */
.homepage-hero{
  padding:38px 0 24px !important;
}
.homepage-hero:before{
  inset:14px 28px auto 28px !important;
  min-height:500px !important;
  height:calc(100% - 28px) !important;
  border-radius:32px !important;
}
.homepage-hero-grid{
  grid-template-columns:minmax(0,.95fr) minmax(390px,.86fr) !important;
  gap:clamp(34px,3.6vw,58px) !important;
  align-items:center !important;
}
.hero-copy h1{
  font-size:clamp(40px,4.1vw,66px) !important;
  line-height:1.02 !important;
  max-width:680px !important;
  margin:18px 0 16px !important;
}
.hero-copy .lead{
  max-width:620px !important;
  font-size:17px !important;
  line-height:1.62 !important;
}
.kicker{
  padding:7px 13px !important;
  font-size:12px !important;
}
.hero-proof-grid{
  display:none !important;
}
.check-card{
  padding:24px !important;
  border-radius:28px !important;
}
.check-card h3{
  font-size:28px !important;
}
.check-card p{
  font-size:14px !important;
  line-height:1.55 !important;
}
.field-label{
  margin:13px 0 7px !important;
}
.search-dd-button,
.platform-select,
.search-input,
.form-input,
.form-textarea{
  min-height:50px !important;
  border-radius:15px !important;
}
.main-button{
  height:52px !important;
  margin-top:15px !important;
}
.stats-mini{
  margin-top:15px !important;
}
.stats-mini div{
  padding:12px !important;
  font-size:11px !important;
}
.stats-mini strong{
  font-size:18px !important;
}
.route-directory-section{
  padding:10px 0 44px !important;
}
.route-directory-visible > summary{
  padding:18px 24px !important;
  border-radius:24px !important;
}
.route-directory-visible > summary span{
  font-size:clamp(28px,3.4vw,44px) !important;
}
.route-directory-visible > summary small{
  padding:7px 12px !important;
  font-size:12px !important;
}
@media(max-width:1240px){
  .homepage-hero:before{
    min-height:650px !important;
  }
  .homepage-hero-grid{
    grid-template-columns:1fr !important;
  }
  .check-card{
    max-width:720px !important;
  }
}
@media(max-width:760px){
  .homepage-hero{
    padding-top:30px !important;
  }
  .homepage-hero:before{
    inset:10px 10px auto 10px !important;
    min-height:700px !important;
  }
  .hero-copy h1{
    font-size:38px !important;
  }
}


/* v13.6 compact one-screen Instant migration preview */
.full-route-preview{
  scroll-margin-top:88px;
}
.full-route-preview.active{
  margin-top:18px !important;
}
.full-route-preview .preview-box{
  padding:22px 24px !important;
  border-radius:28px !important;
  max-height:calc(100vh - 110px);
  overflow:auto;
}
.full-preview-head{
  margin-bottom:14px !important;
}
.full-preview-head h2{
  font-size:clamp(26px,3.2vw,42px) !important;
  margin-bottom:8px !important;
}
.full-preview-route{
  font-size:clamp(17px,1.8vw,24px) !important;
}
.full-preview-route img{
  width:28px !important;
  height:28px !important;
}
.preview-short-copy{
  max-width:920px;
  margin:0 0 16px !important;
  font-size:15px;
  line-height:1.55;
}
.compact-preview-grid,
.full-preview-grid.compact-preview-grid{
  grid-template-columns:repeat(3,minmax(0,1fr)) !important;
  gap:14px !important;
  margin-top:0 !important;
}
.compact-preview-grid .full-preview-card{
  min-height:0 !important;
  padding:20px 20px 18px !important;
  border-radius:22px !important;
  position:relative;
  overflow:hidden;
}
.compact-preview-grid .full-preview-card:after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  bottom:0;
  height:5px;
}
.compact-preview-grid .preview-card-icon{
  width:42px;
  height:42px;
  border-radius:15px;
  display:grid;
  place-items:center;
  font-weight:900;
  margin-bottom:12px;
}
.compact-preview-grid .full-preview-card h3{
  font-size:17px !important;
  margin-bottom:8px !important;
}
.compact-preview-grid .full-preview-card ul{
  gap:5px !important;
}
.compact-preview-grid .full-preview-card li{
  font-size:13px !important;
  line-height:1.45 !important;
}
.clean-card{
  background:linear-gradient(180deg,#ffffff,#f0fbf5) !important;
  border-color:#ccebd9 !important;
}
.clean-card .preview-card-icon{
  background:#dff7ea;
  color:#15965d;
}
.clean-card:after{
  background:linear-gradient(90deg,#42d98b,#18b878);
}
.mapping-card{
  background:linear-gradient(180deg,#ffffff,#f5f1ff) !important;
  border-color:#d9cdf3 !important;
}
.mapping-card .preview-card-icon{
  background:#e9ddff;
  color:#7555d8;
}
.mapping-card:after{
  background:linear-gradient(90deg,#b9a0ff,#7c5cf0);
}
.risk-card{
  background:linear-gradient(180deg,#ffffff,#fff3ea) !important;
  border-color:#efd2b8 !important;
}
.risk-card .preview-card-icon{
  background:#ffe3cc;
  color:#d06b20;
}
.risk-card:after{
  background:linear-gradient(90deg,#ffc48a,#ea7a24);
}
.quick-review-compact{
  margin-top:14px;
  padding:16px;
  border:1px solid #d9cdf3;
  background:linear-gradient(100deg,rgba(114,87,232,.08),rgba(255,208,150,.14));
  border-radius:20px;
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(320px,.82fr);
  gap:16px;
  align-items:center;
}
.quick-review-compact strong{
  display:block;
  color:var(--ink);
  font-size:16px;
  margin-bottom:3px;
}
.quick-review-compact span{
  display:block;
  color:#52617a;
  font-size:14px;
  line-height:1.45;
}
.quick-review-mini-form{
  display:flex;
  gap:10px;
}
.quick-review-mini-form input{
  flex:1;
  min-width:0;
  border:1px solid var(--line);
  border-radius:14px;
  padding:12px 13px;
  font-family:var(--sans);
  font-size:14px;
}
.quick-review-mini-form button{
  border:0;
  border-radius:14px;
  padding:12px 16px;
  white-space:nowrap;
  color:#fff;
  font-weight:800;
  background:linear-gradient(100deg,var(--blue),var(--purple));
  cursor:pointer;
}
.quick-review-form{
  display:none !important;
}
@media(max-width:980px){
  .full-route-preview .preview-box{
    max-height:none;
  }
  .compact-preview-grid,
  .full-preview-grid.compact-preview-grid{
    grid-template-columns:1fr !important;
  }
  .quick-review-compact{
    grid-template-columns:1fr;
  }
}
@media(max-width:640px){
  .full-route-preview .preview-box{
    padding:18px !important;
  }
  .quick-review-mini-form{
    flex-direction:column;
  }
}


/* v13.7 preview reset + name field */
.preview-actions{
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
  justify-content:flex-end;
}
.preview-reset-btn{
  border:1px solid var(--line);
  background:#fff;
  color:#52617a;
  border-radius:999px;
  padding:8px 12px;
  font-family:var(--sans);
  font-size:12px;
  font-weight:800;
  cursor:pointer;
  box-shadow:0 8px 20px rgba(23,31,50,.045);
}
.preview-reset-btn:hover{
  border-color:#9a81ff;
  color:#1f2e4a;
  box-shadow:0 10px 24px rgba(114,87,232,.10);
}
.quick-review-mini-form{
  grid-template-columns:minmax(120px,.7fr) minmax(180px,1fr) auto;
}
.quick-review-mini-form input[name="name"]{
  flex:.72;
}
@media(max-width:760px){
  .full-preview-head{
    align-items:flex-start;
  }
  .preview-actions{
    justify-content:flex-start;
  }
  .quick-review-mini-form{
    display:grid;
    grid-template-columns:1fr;
  }
}


/* v13.10 mobile layout audit + fixes */
html, body{
  max-width:100%;
  overflow-x:hidden;
}
img, svg, video{
  max-width:100%;
  height:auto;
}

/* Prevent any wide tables/cards from forcing horizontal scrolling */
table{
  max-width:100%;
}
.seo-table,
.data-table,
.comparison-table table{
  display:block;
  width:100%;
  overflow-x:auto;
  -webkit-overflow-scrolling:touch;
}
.seo-table thead,
.seo-table tbody,
.seo-table tr,
.data-table thead,
.data-table tbody,
.data-table tr{
  min-width:680px;
}

/* Tablet */
@media(max-width:980px){
  .container,
  .seo-container,
  .full-route-preview{
    width:calc(100% - 32px) !important;
    max-width:none !important;
  }
  .nav{
    height:66px;
  }
  .nav-links{
    display:none !important;
  }
  .brand{
    font-size:20px !important;
    gap:10px !important;
  }
  .homepage-hero{
    padding:30px 0 20px !important;
  }
  .homepage-hero:before{
    inset:8px 8px auto 8px !important;
    height:calc(100% - 18px) !important;
    min-height:0 !important;
    border-radius:26px !important;
  }
  .homepage-hero-grid{
    grid-template-columns:1fr !important;
    gap:26px !important;
  }
  .hero-copy h1{
    font-size:clamp(36px,8vw,56px) !important;
    line-height:1.04 !important;
    max-width:680px !important;
    margin:14px 0 12px !important;
  }
  .hero-copy .lead{
    font-size:16px !important;
    line-height:1.6 !important;
    max-width:680px !important;
  }
  .check-card{
    max-width:none !important;
    padding:22px !important;
    border-radius:24px !important;
  }
  .check-card h3{
    font-size:25px !important;
  }
  .stats-mini{
    grid-template-columns:repeat(3,1fr) !important;
  }
  .full-preview-head{
    align-items:flex-start !important;
  }
  .full-preview-grid,
  .compact-preview-grid,
  .feature-grid,
  .pricing-grid,
  .process-grid,
  .principle-grid,
  .seo-grid,
  .seo-faq-grid,
  .route-grid,
  .results-layout,
  .route-promo,
  .route-detail-grid,
  .two-col,
  .contact-grid,
  .about-story{
    grid-template-columns:1fr !important;
  }
  .route-directory-visible[open] .route-directory-grid{
    grid-template-columns:1fr 1fr !important;
  }
  .quick-review-form-grid,
  .quick-review-mini-form,
  .quick-review-compact{
    grid-template-columns:1fr !important;
  }
}

/* Phone */
@media(max-width:640px){
  .container,
  .seo-container,
  .full-route-preview{
    width:calc(100% - 24px) !important;
  }
  .site-header{
    position:sticky;
  }
  .nav{
    height:58px !important;
  }
  .brand{
    font-size:18px !important;
  }
  .logo-mark{
    transform:scale(.9);
    transform-origin:left center;
  }
  .homepage-hero{
    padding:22px 0 16px !important;
  }
  .homepage-hero:before{
    content:none !important;
  }
  .hero-copy h1{
    font-size:34px !important;
    line-height:1.06 !important;
    letter-spacing:-.035em !important;
    margin:12px 0 10px !important;
  }
  .hero-copy .lead{
    font-size:15px !important;
    line-height:1.55 !important;
  }
  .kicker{
    font-size:11px !important;
    padding:7px 10px !important;
    white-space:normal !important;
  }
  .check-card{
    padding:18px !important;
    border-radius:22px !important;
  }
  .check-card h3{
    font-size:22px !important;
    margin-bottom:5px !important;
  }
  .check-card p{
    font-size:13px !important;
  }
  .field-label{
    font-size:10px !important;
    margin:11px 0 6px !important;
  }
  .search-dd-button,
  .platform-select,
  .search-input,
  .form-input,
  .form-textarea{
    min-height:46px !important;
    border-radius:13px !important;
    font-size:14px !important;
  }
  .search-dd-panel{
    position:fixed !important;
    left:12px !important;
    right:12px !important;
    top:70px !important;
    max-height:calc(100vh - 88px) !important;
    z-index:999 !important;
  }
  .search-dd-list{
    max-height:calc(100vh - 160px) !important;
  }
  .main-button{
    height:48px !important;
    border-radius:14px !important;
    font-size:14px !important;
  }
  .stats-mini{
    grid-template-columns:1fr 1fr 1fr !important;
  }
  .stats-mini div{
    padding:10px 6px !important;
    font-size:10px !important;
  }
  .stats-mini strong{
    font-size:16px !important;
  }
  .preview-box{
    padding:16px !important;
    border-radius:20px !important;
  }
  .full-route-preview{
    scroll-margin-top:68px !important;
  }
  .full-route-preview.active{
    margin-top:12px !important;
  }
  .full-route-preview .preview-box{
    padding:16px !important;
    border-radius:22px !important;
    max-height:none !important;
  }
  .full-preview-head{
    display:grid !important;
    grid-template-columns:1fr !important;
    gap:10px !important;
  }
  .full-preview-head h2{
    font-size:26px !important;
  }
  .full-preview-route{
    font-size:15px !important;
    gap:8px !important;
    flex-wrap:wrap !important;
  }
  .full-preview-route img{
    width:22px !important;
    height:22px !important;
  }
  .preview-actions{
    justify-content:flex-start !important;
  }
  .compact-preview-grid .full-preview-card{
    padding:16px !important;
    border-radius:18px !important;
  }
  .quick-review-compact{
    padding:14px !important;
    border-radius:18px !important;
  }
  .quick-review-mini-form{
    display:grid !important;
    grid-template-columns:1fr !important;
  }
  .quick-review-mini-form button{
    width:100%;
  }
  .route-directory-section{
    padding:10px 0 36px !important;
  }
  .route-directory-visible > summary{
    padding:16px 18px !important;
    border-radius:20px !important;
    align-items:flex-start !important;
  }
  .route-directory-visible > summary span{
    font-size:28px !important;
  }
  .route-directory-visible[open] .route-directory-grid{
    grid-template-columns:1fr !important;
    max-height:520px !important;
    padding-top:14px !important;
  }
  .route-directory-visible .route-dir-link{
    padding:12px !important;
    border-radius:14px !important;
  }
  .section{
    padding:46px 0 !important;
  }
  .section-center h2{
    font-size:32px !important;
  }
  .feature-card,
  .panel,
  .mock-route,
  .summary-card,
  .price-card{
    padding:18px !important;
    border-radius:22px !important;
  }
  .feature-card{
    min-height:0 !important;
  }
  .footer{
    padding:36px 0 28px !important;
  }
  .footer-tag{
    font-size:19px !important;
  }
}


/* v13.11 hard mobile overflow fixes */
@media(max-width:760px){
  body{
    overflow-x:hidden !important;
  }

  /* Stop wide sections from pushing the viewport */
  .route-promo,
  .mock-route,
  .route-detail-grid,
  .results-layout,
  .route-card,
  .panel,
  .preview-box,
  .full-route-preview,
  .check-card,
  .feature-card,
  .container,
  .seo-container{
    max-width:100% !important;
    min-width:0 !important;
    box-sizing:border-box !important;
  }

  /* Fix the overflowing Route Explorer headline */
  .route-promo h2,
  .section-center h2,
  .hero-copy h1,
  h1, h2{
    max-width:100% !important;
    overflow-wrap:anywhere !important;
    word-break:normal !important;
    hyphens:auto !important;
  }

  .route-promo h2{
    font-size:34px !important;
    line-height:1.08 !important;
    letter-spacing:-.035em !important;
  }

  .route-promo p{
    max-width:100% !important;
    font-size:16px !important;
    line-height:1.6 !important;
  }

  .route-promo ul{
    max-width:100% !important;
    padding-left:0 !important;
  }

  .route-promo li{
    max-width:100% !important;
    font-size:15px !important;
    line-height:1.45 !important;
  }

  .route-promo .btn,
  .route-promo a.btn{
    width:100% !important;
    max-width:100% !important;
    justify-content:center !important;
    text-align:center !important;
    white-space:normal !important;
    padding-left:18px !important;
    padding-right:18px !important;
  }

  /* Make the mock compatibility card fit the phone viewport */
  .mock-route{
    width:100% !important;
    padding:18px !important;
    border-radius:24px !important;
    overflow:hidden !important;
  }

  .mock-head{
    display:grid !important;
    grid-template-columns:1fr !important;
    gap:12px !important;
    align-items:start !important;
  }

  .mock-head > div:first-child,
  .mock-route-title,
  .preview-route,
  .full-preview-route{
    display:flex !important;
    flex-wrap:wrap !important;
    align-items:center !important;
    gap:8px !important;
    min-width:0 !important;
    max-width:100% !important;
  }

  .mock-head img,
  .mock-route-title img,
  .platform-icon{
    width:28px !important;
    height:28px !important;
    flex:0 0 28px !important;
  }

  .mock-head strong,
  .mock-route-title strong,
  .preview-route,
  .full-preview-route{
    font-size:20px !important;
    line-height:1.2 !important;
  }

  .mock-head .badge,
  .badge{
    justify-self:start !important;
    max-width:100% !important;
    white-space:normal !important;
    text-align:left !important;
    font-size:12px !important;
    padding:8px 11px !important;
  }

  .score-row{
    grid-template-columns:92px minmax(0,1fr) 36px !important;
    gap:8px !important;
    max-width:100% !important;
  }

  .score-row span:first-child{
    font-size:14px !important;
  }

  .score-row strong{
    font-size:13px !important;
    text-align:right !important;
  }

  .score-bar{
    min-width:0 !important;
    max-width:100% !important;
  }

  /* Avoid any absolute/flex child extending the viewport */
  .mock-route *,
  .route-promo *,
  .full-route-preview *{
    min-width:0 !important;
    box-sizing:border-box !important;
  }
}

@media(max-width:430px){
  .route-promo h2{
    font-size:31px !important;
  }
  .mock-head strong,
  .mock-route-title strong{
    font-size:18px !important;
  }
  .score-row{
    grid-template-columns:86px minmax(0,1fr) 32px !important;
  }
}


/* v13.12 mobile compatibility badge overlap fix */
@media(max-width:760px){
  .mock-head{
    display:flex !important;
    flex-direction:column !important;
    align-items:stretch !important;
    gap:14px !important;
  }

  .mock-head > div:first-child{
    width:100% !important;
    max-width:100% !important;
    display:grid !important;
    grid-template-columns:28px minmax(0,1fr) 22px 28px minmax(0,1fr) !important;
    gap:8px !important;
    align-items:center !important;
    overflow:hidden !important;
  }

  .mock-head > div:first-child img{
    width:28px !important;
    height:28px !important;
    flex:0 0 28px !important;
  }

  .mock-head > div:first-child strong,
  .mock-head > div:first-child span:not(.route-arrow){
    min-width:0 !important;
    overflow:hidden !important;
    text-overflow:ellipsis !important;
    white-space:nowrap !important;
    font-size:20px !important;
    line-height:1.1 !important;
  }

  .mock-head .route-arrow,
  .mock-head > div:first-child span{
    text-align:center !important;
  }

  .mock-head .badge,
  .mock-head > .badge{
    position:static !important;
    justify-self:start !important;
    align-self:flex-start !important;
    display:inline-flex !important;
    max-width:100% !important;
    width:auto !important;
    white-space:normal !important;
    text-align:left !important;
    font-size:12px !important;
    line-height:1.2 !important;
    padding:8px 11px !important;
    margin:0 !important;
  }
}

@media(max-width:430px){
  .mock-head > div:first-child{
    grid-template-columns:26px minmax(0,1fr) 18px 26px minmax(0,1fr) !important;
    gap:7px !important;
  }

  .mock-head > div:first-child img{
    width:26px !important;
    height:26px !important;
  }

  .mock-head > div:first-child strong,
  .mock-head > div:first-child span:not(.route-arrow){
    font-size:18px !important;
  }
}


/* v13.13 prevent word hyphenation in headings */
h1, h2, h3,
.hero-copy h1,
.section-center h2,
.route-promo h2,
.seo-longform .panel h2{
  hyphens:none !important;
  -webkit-hyphens:none !important;
  -ms-hyphens:none !important;
  word-break:normal !important;
  overflow-wrap:normal !important;
}
.section-center h2 .grad,
.hero-copy h1 .grad,
.route-promo h2 .grad{
  white-space:nowrap !important;
}
@media(max-width:760px){
  .section-center h2{
    font-size:clamp(30px,8.4vw,42px) !important;
    line-height:1.08 !important;
    letter-spacing:-.035em !important;
  }
  .section-center h2 .grad{
    display:inline-block;
    white-space:nowrap !important;
  }
}
@media(max-width:430px){
  .section-center h2{
    font-size:32px !important;
  }
  .section-center p{
    font-size:17px !important;
    line-height:1.55 !important;
  }
}


/* v13.14 uploaded logo package */
.logo-mark{
  width:34px !important;
  height:34px !important;
  display:inline-block !important;
  flex:0 0 34px !important;
  border:0 !important;
  border-radius:0 !important;
  background:url('/assets/img/site-logo.png') center/contain no-repeat !important;
  overflow:visible !important;
  transform:none !important;
}
.logo-mark:before,
.logo-mark:after{
  content:none !important;
  display:none !important;
}
@media(max-width:640px){
  .logo-mark{
    width:30px !important;
    height:30px !important;
    flex-basis:30px !important;
    transform:none !important;
  }
}


/* v13.16 native Netlify form template */
.netlify-form-template{
  position:absolute !important;
  left:-10000px !important;
  top:auto !important;
  width:1px !important;
  height:1px !important;
  overflow:hidden !important;
}
.netlify-form-template .hidden{
  display:none !important;
}
