:root{--bg:#f7f3eb;--paper:#fffdf8;--ink:#101820;--muted:#66717b;--soft:#ebe1d2;--line:#ded0bc;--line-strong:#c8b394;--accent:#9a6a3d;--navy:#111b27;--shadow:0 24px 80px rgba(33,24,12,.08)}
*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;background:var(--bg);color:var(--ink);font-family:Geist,system-ui,sans-serif}a{color:inherit}main,.nav,.site-footer{width:min(1180px,calc(100% - 40px));margin:auto}.nav{position:sticky;top:0;z-index:10;display:flex;align-items:center;justify-content:space-between;gap:24px;padding:18px 0;background:rgba(247,243,235,.9);backdrop-filter:blur(14px);border-bottom:1px solid rgba(222,208,188,.75)}.brand{display:flex;gap:12px;align-items:center;text-decoration:none}.brand-mark{display:grid;place-items:center;width:38px;height:38px;border:1px solid var(--line-strong);background:var(--navy);color:#fff;font-weight:800}.brand strong{display:block}.brand small{display:block;color:var(--muted);font-size:12px}.nav nav{display:flex;gap:20px;align-items:center}.nav nav a{font-size:13px;font-weight:700;text-decoration:none;color:#3f4850}.nav nav a:hover{color:var(--ink)}section{padding:72px 0}.hero{display:grid;grid-template-columns:minmax(0,1.05fr) 430px;gap:44px;align-items:start;padding-top:86px}.eyebrow{margin:0 0 14px;color:var(--accent);font-size:11px;font-weight:800;letter-spacing:.14em;text-transform:uppercase}.hero h1,.section-head h2,.standards h2,.supplier-page h2,.shortlist-panel h2,.hubs h2{margin:0;font-family:Newsreader,Georgia,serif;font-weight:600;letter-spacing:-.035em}.hero h1{max-width:760px;font-size:clamp(52px,7vw,92px);line-height:.9}.lede{max-width:670px;margin:24px 0 0;color:#4f5a63;font-size:18px;line-height:1.65}.editor-line{margin:18px 0 0;color:#59636c;font-size:13px;font-weight:700}.hero-map,.proof-points,.mini-pipeline,.featured-strip{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.hero-map{margin-top:30px}.hero-map div,.proof-points div,.mini-pipeline span{display:flex;align-items:center;gap:9px;border:1px solid var(--line);background:rgba(255,253,248,.58);padding:10px 12px}.hero-map svg{width:54px;height:12px;stroke:var(--accent);fill:none;stroke-width:1.5}.map-icon{display:grid;place-items:center;width:22px;height:22px;border:1px solid var(--line-strong);color:var(--accent)}.search-panel{border:1px solid var(--line-strong);background:var(--paper);border-radius:22px;padding:26px;box-shadow:var(--shadow)}label span,.filter-bar legend{display:block;margin-bottom:8px;color:#6b5b47;font-size:11px;font-weight:800;letter-spacing:.11em;text-transform:uppercase}input,select{width:100%;height:46px;border:1px solid var(--line);background:#fff;color:var(--ink);border-radius:12px;padding:0 12px;font:inherit}input:focus,select:focus{outline:2px solid rgba(154,106,61,.18);border-color:var(--accent)}.search-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:14px}.proof-points{grid-column:1/-1}.proof-points div{flex:1;min-width:190px;border-radius:18px}.proof-points strong{display:block}.proof-points em{color:var(--muted);font-style:normal}.featured-strip{padding:18px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);color:#39434c}.featured-strip span{color:var(--accent);font-size:11px;font-weight:900;letter-spacing:.14em;text-transform:uppercase}.featured-strip strong{font-size:13px}.shortlist-panel{display:grid;grid-template-columns:.9fr 1.1fr;gap:34px;align-items:center;border-bottom:1px solid var(--line)}.shortlist-panel form{display:grid;grid-template-columns:1fr 1fr;gap:14px;border:1px solid var(--line-strong);background:var(--paper);border-radius:22px;padding:22px;box-shadow:var(--shadow)}.shortlist-panel button{grid-column:span 1}.trust-line{margin:0;align-self:center;color:var(--muted);font-size:13px}.mini-pipeline span{border-radius:999px}.mini-pipeline i{font-style:normal;color:var(--accent);font-weight:900}.section-head{margin-bottom:28px}.section-head.row{display:flex;align-items:end;justify-content:space-between;gap:20px}.section-head h2,.shortlist-panel h2,.standards h2,.hubs h2,.supplier-page h2{font-size:clamp(34px,5vw,60px);line-height:.96}.quiet,.grade-legend{color:var(--muted);line-height:1.55}.grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:22px}.card{display:flex;min-height:330px;flex-direction:column;border:1px solid var(--line);background:var(--paper);border-radius:22px;padding:22px;box-shadow:0 14px 40px rgba(22,15,7,.05)}.card-top{display:flex;align-items:center;gap:10px}.logo-tile{position:relative;display:grid;place-items:center;flex:0 0 auto;width:46px;height:46px;border:1px solid var(--line);border-radius:14px;background:#f2eadf;overflow:hidden;color:#18212a;font-size:11px;font-weight:900}.logo-initials{position:absolute;inset:0;display:grid;place-items:center;letter-spacing:.05em}.logo-tile img{position:relative;z-index:1;width:76%;height:76%;object-fit:contain}.logo-tile.large{width:60px;height:60px}.badge{margin-left:auto;color:var(--accent);font-size:10px;font-weight:900;letter-spacing:.12em;text-transform:uppercase}.grade-badge{display:inline-flex;align-items:center;border:1px solid var(--line-strong);border-radius:999px;padding:6px 9px;background:#fbf4e9;color:#684523;font-size:12px;font-weight:800}.card h3{margin:28px 0 10px;font-family:Newsreader,Georgia,serif;font-size:31px;line-height:1;font-weight:600}.card p{margin:0;color:#515d66;font-size:12px;font-weight:800;line-height:1.4;text-transform:uppercase;letter-spacing:.08em}.card-facts{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin:22px 0 0}.card-facts span{display:flex;align-items:center;gap:7px;min-height:36px;border:1px solid var(--line);border-radius:12px;background:#fbf8f2;padding:8px 9px;color:#4f5a63;font-size:12px;line-height:1.2}.card-facts i{min-width:13px;color:var(--accent);font-style:normal;text-align:center}.actions{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-top:auto;padding-top:24px}.button,button{display:inline-flex;align-items:center;justify-content:center;min-height:44px;border:1px solid var(--navy);border-radius:999px;background:var(--navy);color:#fff;font-weight:800;padding:11px 16px;cursor:pointer;text-decoration:none}.button:hover,button:hover{background:#263445}.ghost{background:transparent;color:var(--ink);border-color:var(--line-strong)}.text-link{color:var(--accent);font-size:12px;font-weight:900;letter-spacing:.08em;text-transform:uppercase;text-decoration:none;border-bottom:1px solid rgba(154,106,61,.35)}.filter-bar{position:sticky;top:75px;z-index:4;display:grid;grid-template-columns:repeat(4,minmax(0,1fr)) minmax(330px,.95fr);gap:12px;margin-bottom:24px;padding:14px;border:1px solid var(--line);border-radius:20px;background:rgba(255,253,248,.92);backdrop-filter:blur(12px)}.segment-filter{align-self:end;display:grid;grid-template-columns:repeat(3,minmax(96px,1fr));gap:8px;margin:0;padding:0;border:0}.segment-filter legend{position:absolute;width:1px;height:1px;overflow:hidden}.segment-filter label{min-width:0}.segment-filter input{position:absolute;opacity:0;pointer-events:none;width:1px;height:1px}.segment-filter span{display:grid;place-items:center;height:46px;border:1px solid var(--line);border-radius:999px;background:#fff;color:#4f5a63;font-size:12px;line-height:1;white-space:nowrap;text-align:center}.segment-filter input:checked+span{background:var(--navy);color:#fff;border-color:var(--navy)}.hubs,.standards{border-top:1px solid var(--line)}.hub-grid,.method-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}.hub-grid article,.method-grid article,.pricing-box{border:1px solid var(--line);background:var(--paper);border-radius:22px;padding:22px}.hub-grid h3,.method-grid strong{margin:0 0 8px;font-family:Newsreader,Georgia,serif;font-size:25px}.hub-grid p,.method-grid small,.pricing-box p{color:var(--muted);line-height:1.55}.hub-grid span{color:var(--accent);font-weight:900}.standards{display:grid;grid-template-columns:.6fr 1.4fr;gap:40px}.method-grid{grid-template-columns:repeat(4,1fr)}.method-grid article>span{display:grid;place-items:center;width:38px;height:38px;margin-bottom:16px;border:1px solid var(--line-strong);border-radius:12px;color:var(--accent)}.grade-ladder ol{display:grid;gap:6px;margin:10px 0 0;padding:0;list-style:none}.grade-ladder li{display:grid;grid-template-columns:42px 1fr;align-items:center;border:1px solid var(--line);border-radius:10px;padding:5px 8px}.empty{text-align:center;color:var(--muted)}dialog{width:min(920px,92vw);border:1px solid var(--line-strong);border-radius:24px;background:var(--paper);color:var(--ink);padding:32px;box-shadow:var(--shadow)}dialog::backdrop{background:rgba(16,24,32,.55);backdrop-filter:blur(8px)}.close{float:right;width:38px;min-height:38px;padding:0;border-color:var(--line);background:#fff;color:var(--ink);font-size:22px}.modal-grid{display:grid;gap:18px}.dossier-head{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:24px}.dossier-title-row{display:flex;align-items:flex-start;gap:16px}.modal-grid h2{margin:6px 0 0;font-family:Newsreader,Georgia,serif;font-size:48px;line-height:.98}.modal-note{padding:18px 0;border-top:1px solid var(--line-strong);border-bottom:1px solid var(--line);color:#3c4750}.dossier-columns{display:grid;grid-template-columns:1fr 1fr 1fr;gap:18px}.dossier-columns section{border-top:1px solid var(--line);padding-top:14px}.dossier-columns ul{margin:0;padding-left:18px;color:var(--muted);line-height:1.5}.dossier-panels{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}.dossier-panels article{min-height:120px;border:1px solid var(--line);border-radius:16px;background:#fbf8f2;padding:16px}.meta{display:flex;gap:10px;flex-wrap:wrap}.pill{border-bottom:1px solid var(--line-strong);color:var(--muted);font-size:12px;padding-bottom:3px}.contact{display:flex;gap:12px;flex-wrap:wrap}.supplier-page{border-top:1px solid var(--line);padding-top:46px}.site-footer{display:flex;justify-content:space-between;gap:24px;padding:34px 0 50px;border-top:1px solid var(--line);color:var(--muted);font-size:13px}.site-footer strong{display:block;color:var(--ink)}.site-footer details{display:inline-block;margin-left:12px}
@media (max-width:920px){main,.nav,.site-footer{width:min(100% - 28px,1180px)}.nav{align-items:flex-start}.nav nav{display:none}.hero,.shortlist-panel,.standards{grid-template-columns:1fr}.grid,.hub-grid,.method-grid,.dossier-columns,.dossier-panels{grid-template-columns:1fr}.filter-bar{position:static;grid-template-columns:1fr}.shortlist-panel form{grid-template-columns:1fr}.site-footer{display:block}.hero h1{font-size:52px}.search-row{grid-template-columns:1fr}}

/* Logo polish: show firm logos when available while keeping initials as the no-broken-mark fallback. */
.logo-tile{position:relative;display:inline-flex;align-items:center;justify-content:center;overflow:hidden;background:linear-gradient(145deg,#fffdf8,#eadcc9)}
.logo-tile .logo-initials{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;width:100%;height:100%;font-family:Georgia,serif;font-weight:700;letter-spacing:.04em;color:var(--accent)}
.logo-tile img{position:relative;z-index:1;display:block;width:78%;height:78%;object-fit:contain;background:#fffdf8;border-radius:8px;opacity:0;transition:opacity .18s ease}
.logo-tile.logo-loaded img{opacity:1}
.logo-tile.logo-loaded .logo-initials{opacity:0}
.logo-tile.logo-failed img{display:none}
.card .logo-tile{width:52px;height:52px;border-radius:16px}
.dossier-title-row .logo-tile.large{width:68px;height:68px;border-radius:18px}
.method-grid article{display:grid;grid-template-columns:auto 1fr;column-gap:12px;row-gap:3px;align-items:start}
.method-grid article span{grid-row:1 / span 2}
.method-grid article strong,.method-grid article small{display:block;line-height:1.2}
.disclosure-links{display:flex;align-items:center;gap:14px;flex-wrap:wrap}

.grade-ladder{display:block!important}
.grade-ladder strong{display:block;margin-bottom:10px}
.grade-ladder ol{display:flex;flex-wrap:wrap;gap:8px;margin:0;padding:0;list-style:none}
.grade-ladder li{display:inline-flex;align-items:center;gap:7px;min-width:92px;padding:8px 10px;border:1px solid var(--line);border-radius:999px;background:#fffdf8;line-height:1}
.grade-ladder b{font-family:Georgia,serif;color:var(--accent)}
.grade-ladder li span{font-size:12px;color:var(--muted);white-space:nowrap}
.hub-card{display:block;color:inherit;text-decoration:none}
.hub-card article{height:100%;transition:transform .16s ease,border-color .16s ease,box-shadow .16s ease}
.hub-card:hover article{transform:translateY(-2px);border-color:var(--line-strong);box-shadow:0 18px 48px rgba(22,15,7,.07)}
.route-page .hero{border-bottom:1px solid var(--line)}
.route-page .search-panel h2{margin:0 0 14px;font-family:Newsreader,Georgia,serif;font-size:42px;line-height:1}
.route-page .search-panel p{color:var(--muted);line-height:1.55}
.route-page .search-panel .button{margin-top:8px}
.advisor-list{display:grid;gap:14px}
.advisor-list article{border:1px solid var(--line);border-radius:18px;background:#fbf8f2;padding:16px}
.advisor-list h3{margin:0 0 6px;font-family:Newsreader,Georgia,serif;font-size:25px;line-height:1}
.advisor-list p{margin:0;color:var(--muted);font-size:14px;line-height:1.45;text-transform:none;letter-spacing:0}
.route-cta{border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.route-cta .shortlist-panel{border-bottom:0;padding:0}
.route-note{margin-top:16px;color:var(--muted);font-size:13px;line-height:1.55}

/* Trust-first SEO additions: extractable answers, FAQs and breadcrumbs keep the editorial style without changing the static architecture. */
.answer-block{margin:0 0 28px;padding:26px;border:1px solid var(--line);border-radius:24px;background:rgba(255,253,248,.62);box-shadow:0 18px 52px rgba(33,24,12,.05)}
.answer-block h2,.faq-section h2{margin:0;font-family:Newsreader,Georgia,serif;font-size:clamp(34px,4vw,54px);line-height:1;letter-spacing:-.03em}
.answer-block p:last-child{max-width:860px;margin:14px 0 0;color:#4f5a63;font-size:17px;line-height:1.65}
.breadcrumbs{width:min(1180px,calc(100% - 40px));margin:22px auto -42px;display:flex;gap:9px;align-items:center;color:var(--muted);font-size:13px;font-weight:700}
.breadcrumbs a{text-decoration:none;color:#3f4850}.breadcrumbs a:hover{color:var(--ink)}
.faq-section{border-top:1px solid var(--line)}
.faq-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin-top:24px}
.faq-grid article{border:1px solid var(--line);border-radius:18px;background:#fbf8f2;padding:18px}
.faq-grid h3{margin:0 0 8px;font-family:Newsreader,Georgia,serif;font-size:24px;line-height:1.05}
.faq-grid p{margin:0;color:var(--muted);font-size:14px;line-height:1.55}
@media (max-width:920px){.breadcrumbs{width:min(100% - 28px,1180px);margin:16px auto -48px}.faq-grid{grid-template-columns:1fr}.answer-block{padding:20px}}


/* May 2026 polish: premium trust panels, clearer selection criteria, richer cards. */
.card{transition:transform .16s ease,border-color .16s ease,box-shadow .16s ease}
.card:hover{transform:translateY(-3px);border-color:var(--line-strong);box-shadow:0 24px 58px rgba(22,15,7,.08)}
.card .card-summary{margin:14px 0 0;color:#4f5a63;font-size:14px;font-weight:500;line-height:1.48;text-transform:none;letter-spacing:0}
.decision-panel{display:grid;grid-template-columns:.78fr 1.22fr;gap:30px;align-items:start;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.decision-panel h2,.selection-summary h2,.owner-questions h2{margin:0;font-family:Newsreader,Georgia,serif;font-size:clamp(34px,5vw,58px);line-height:.96;letter-spacing:-.035em}
.decision-grid,.criteria-grid,.question-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}
.decision-grid article,.criteria-grid article,.question-grid article{border:1px solid var(--line);border-radius:22px;background:linear-gradient(180deg,#fffdf8,#fbf7ef);padding:20px;box-shadow:0 12px 36px rgba(22,15,7,.04)}
.decision-grid span{display:inline-grid;place-items:center;width:34px;height:34px;margin-bottom:22px;border:1px solid var(--line-strong);border-radius:999px;color:var(--accent);font-size:12px;font-weight:900}
.decision-grid strong,.criteria-grid strong,.question-grid strong{display:block;margin-bottom:8px;font-family:Newsreader,Georgia,serif;font-size:24px;line-height:1.02;font-weight:600}
.decision-grid p,.criteria-grid p,.question-grid p{margin:0;color:var(--muted);font-size:14px;line-height:1.55}
.selection-summary,.owner-questions{border-top:1px solid var(--line)}
.owner-questions{padding-top:54px}
@media (max-width:920px){.decision-panel{grid-template-columns:1fr}.decision-grid,.criteria-grid,.question-grid{grid-template-columns:1fr}.proof-points div{min-width:150px}.card .card-summary{font-size:13px}}

/* Advisor-call readiness additions. */
.profile-meta{display:flex;gap:8px;flex-wrap:wrap;margin:12px 0 0;color:var(--muted);font-size:11px;font-weight:800;letter-spacing:.08em;text-transform:uppercase}
.profile-meta span{border:1px solid var(--line);border-radius:999px;background:rgba(255,253,248,.72);padding:7px 9px}
.actions{flex-wrap:wrap}.actions .advisor-correct{flex-basis:100%;margin-top:2px;color:var(--accent);font-weight:800}
.cta-stack{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.example-profile{padding-top:28px}.example-card{border:1px solid var(--line);border-radius:28px;background:linear-gradient(180deg,#fffdf8,#fbf7ef);padding:24px;box-shadow:var(--shadow);margin-bottom:18px}.example-card h2{margin:18px 0 0;font-family:Newsreader,Georgia,serif;font-size:44px;line-height:1}.example-card .logo-tile{width:58px;height:58px;border-radius:18px}
@media (max-width:920px){.example-card h2{font-size:34px}.profile-meta{font-size:10px}}

/* Mobile usability pass: keep the premium editorial look but make the directory easier to use on phones. */
.hero-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:22px}
html,body{max-width:100%;overflow-x:hidden}
img,svg{max-width:100%}

@media (max-width:920px){
  main,.nav,.site-footer,.breadcrumbs{width:min(100% - 28px,1180px)}
  section{padding:48px 0}
  .nav{flex-wrap:wrap;align-items:center;gap:10px;padding:12px 0}
  .brand{min-width:0}
  .brand span:last-child{min-width:0}
  .brand strong,.brand small{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  .nav nav{display:flex;width:100%;gap:8px;overflow-x:auto;padding:2px 0 4px;-webkit-overflow-scrolling:touch;scrollbar-width:none}
  .nav nav::-webkit-scrollbar{display:none}
  .nav nav a{flex:0 0 auto;border:1px solid var(--line);border-radius:999px;background:rgba(255,253,248,.72);padding:8px 10px;font-size:12px;line-height:1}
  .hero{gap:24px;padding-top:42px}
  .hero h1{font-size:clamp(42px,12vw,56px);line-height:.96;overflow-wrap:break-word}
  .lede{margin-top:18px;font-size:16px;line-height:1.55}
  .hero-actions .button{min-height:46px;padding-inline:15px}
  .hero-map{display:grid;grid-template-columns:1fr;align-items:stretch;gap:8px;margin-top:22px}
  .hero-map div{justify-content:flex-start;width:100%;border-radius:14px}
  .hero-map svg{width:28px;height:18px;justify-self:center;transform:rotate(90deg)}
  .search-panel{padding:18px;border-radius:20px;box-shadow:0 14px 42px rgba(33,24,12,.08)}
  label span,.filter-bar legend{font-size:11px;letter-spacing:.09em}
  input,select{min-height:48px;font-size:16px}
  .proof-points{gap:10px}
  .proof-points div{flex:1 1 calc(50% - 10px);min-width:0;border-radius:14px;padding:10px}
  .proof-points strong{font-size:14px}
  .proof-points em{font-size:12px}
  .featured-strip{gap:8px;padding:14px 0}
  .featured-strip span{flex-basis:100%}
  .featured-strip strong{border:1px solid var(--line);border-radius:999px;background:rgba(255,253,248,.6);padding:7px 9px;font-size:12px}
  .section-head.row{display:grid;gap:14px;align-items:start}
  .shortlist-panel{gap:22px}
  .shortlist-panel form{padding:18px;border-radius:20px}
  .shortlist-panel button,.shortlist-panel .trust-line{width:100%}
  .filter-bar{position:static;grid-template-columns:1fr;gap:10px;margin-bottom:18px;padding:12px;border-radius:18px}
  .segment-filter{grid-template-columns:repeat(3,minmax(0,1fr));gap:7px;width:100%}
  .segment-filter span{min-height:44px;height:auto;padding:10px 6px;font-size:12px;white-space:normal}
  .grid{gap:16px}
  .card{min-height:auto;padding:18px;border-radius:20px}
  .card:hover{transform:none}
  .card-top{flex-wrap:wrap;align-items:center}
  .card .logo-tile{width:46px;height:46px;border-radius:14px}
  .badge{margin-left:0}
  .grade-badge{margin-left:auto}
  .card h3{margin:18px 0 8px;font-size:28px;line-height:1.02}
  .card-facts{grid-template-columns:1fr;gap:7px;margin-top:16px}
  .profile-meta span{border-radius:12px;line-height:1.15}
  .actions{gap:10px;padding-top:18px}
  .actions .button{width:100%}
  .actions .text-link{display:inline-flex;align-items:center;min-height:44px}
  .decision-grid article,.criteria-grid article,.question-grid article,.hub-grid article,.method-grid article,.faq-grid article{padding:17px;border-radius:18px}
  .decision-grid strong,.criteria-grid strong,.question-grid strong{font-size:22px}
  .method-grid article{grid-template-columns:auto minmax(0,1fr)}
  .grade-ladder ol{display:grid;grid-template-columns:repeat(2,minmax(0,1fr))}
  .grade-ladder li{min-width:0;justify-content:center}
  dialog{width:calc(100vw - 20px);max-height:90dvh;overflow:auto;padding:20px;border-radius:20px}
  .dossier-head{grid-template-columns:1fr;gap:14px}
  .dossier-title-row{gap:12px}
  .dossier-title-row .logo-tile.large{width:54px;height:54px;border-radius:16px}
  .modal-grid h2{font-size:34px}
  .contact .button,.contact .text-link{width:100%;justify-content:center}
  .site-footer{padding:28px 0 40px}
  .site-footer>div+div{margin-top:14px}
  .site-footer details{display:block;margin:10px 0 0}
  .cta-stack .button{width:100%}
}

@media (max-width:480px){
  main,.nav,.site-footer,.breadcrumbs{width:calc(100% - 24px)}
  section{padding:40px 0}
  .brand-mark{width:34px;height:34px}
  .brand small{display:none}
  .nav nav{flex-wrap:wrap;overflow:visible;gap:7px}
  .nav nav a{font-size:11px;padding:8px 9px}
  .hero{padding-top:30px}
  .hero h1{font-size:clamp(39px,11.5vw,48px)}
  .hero-actions{display:grid;grid-template-columns:1fr;gap:8px}
  .hero-actions .button{width:100%}
  .editor-line{font-size:12px;line-height:1.45}
  .proof-points div{flex-basis:100%}
  .answer-block{padding:18px;border-radius:20px}
  .section-head h2,.shortlist-panel h2,.standards h2,.hubs h2,.supplier-page h2,.decision-panel h2,.selection-summary h2,.owner-questions h2{font-size:clamp(32px,10vw,42px);line-height:1}
  .button,button{width:100%;min-height:46px}
  .text-link{font-size:11px;letter-spacing:.06em}
  .grade-ladder ol{grid-template-columns:1fr}
  .example-card{padding:18px;border-radius:22px}
  .example-card h2{font-size:30px}
}

/* Strong mobile journey pass: shorter browsing, persistent actions, directory-first ordering. */
.result-count{margin:0 0 14px;color:var(--muted);font-size:13px;font-weight:800;letter-spacing:.04em;text-transform:uppercase}
.load-more{display:flex;margin:18px auto 0;min-width:min(100%,280px)}
.mobile-sticky{display:none}

@media (max-width:700px){
  main{display:flex;flex-direction:column}
  .hero{order:1}
  #directory{order:2}
  #shortlist{order:3}
  .featured{order:4}
  .answer-block{order:5}
  .featured-strip{order:6}
  .decision-panel{order:7}
  .selection-summary{order:8}
  #routes{order:9}
  #methodology{order:10}
  #faq{order:11}
  #owner-questions{order:12}
  #suppliers{order:13}

  body{padding-bottom:76px}
  .mobile-sticky{position:fixed;left:10px;right:10px;bottom:10px;z-index:30;display:grid;grid-template-columns:1fr 1fr 1.15fr;gap:6px;padding:7px;border:1px solid rgba(200,179,148,.85);border-radius:20px;background:rgba(255,253,248,.94);box-shadow:0 18px 50px rgba(16,24,32,.18);backdrop-filter:blur(14px)}
  .mobile-sticky a{display:grid;place-items:center;min-height:42px;border-radius:14px;text-decoration:none;font-size:12px;font-weight:900;color:#2f3942;background:#f5eee4;border:1px solid var(--line)}
  .mobile-sticky a:last-child{background:var(--navy);color:#fff;border-color:var(--navy)}

  .hero{padding-bottom:32px}
  #directory{padding-top:36px;border-top:1px solid var(--line)}
  #directory .section-head{margin-bottom:16px}
  #directory .section-head h2{font-size:clamp(36px,11vw,46px)}
  .disclosure-links{gap:8px;font-size:12px}
  .filter-bar{box-shadow:0 12px 34px rgba(22,15,7,.06)}
  .result-count{display:flex;align-items:center;justify-content:space-between;border:1px solid var(--line);border-radius:999px;background:rgba(255,253,248,.72);padding:10px 12px}

  #cards.grid,.featured-grid.grid{gap:12px}
  .featured-grid .card:nth-child(n+4){display:none}
  .card{padding:15px;border-radius:18px;box-shadow:0 10px 28px rgba(22,15,7,.045)}
  .card-top{display:grid;grid-template-columns:auto minmax(0,1fr) auto;gap:9px;align-items:center}
  .card .logo-tile{grid-row:1 / span 2;width:42px;height:42px;border-radius:13px}
  .badge{grid-column:2;min-width:0;margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:9px;letter-spacing:.09em}
  .grade-badge{grid-column:3;grid-row:1 / span 2;align-self:start;padding:5px 8px;font-size:11px}
  .card h3{margin:12px 0 5px;font-size:24px;line-height:1.03}
  .card p:not(.card-summary){font-size:10px;letter-spacing:.07em;line-height:1.25}
  .card .card-summary{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;margin-top:9px;font-size:13px;line-height:1.4}
  .card-facts{display:flex;flex-wrap:wrap;gap:6px;margin-top:12px}
  .card-facts span{min-height:0;flex:1 1 auto;border-radius:999px;padding:7px 9px;font-size:11px;line-height:1.15}
  .card-facts span:nth-child(n+4){display:none}
  .profile-meta{margin-top:10px;gap:6px;font-size:9px;letter-spacing:.06em}
  .profile-meta span{padding:6px 8px}
  .profile-meta span:nth-child(2){display:none}
  .actions{display:grid;grid-template-columns:1fr auto;gap:8px;padding-top:14px;align-items:center}
  .actions .button,.actions button{width:100%;min-height:42px;padding:9px 12px}
  .actions .text-link{justify-content:center;min-height:42px;padding:0 3px;text-align:center}
  .actions .advisor-correct{grid-column:1 / -1;min-height:32px;font-size:10px;text-align:left;justify-content:flex-start}
  .load-more{width:100%;justify-content:center;margin-top:14px}

  .shortlist-panel,.answer-block,.featured,.decision-panel,.selection-summary,.hubs,.standards,.faq-section,.owner-questions,.supplier-page{padding-top:38px;padding-bottom:38px}
  .decision-grid,.criteria-grid,.question-grid,.hub-grid,.method-grid,.faq-grid{gap:10px}
  .decision-grid article,.criteria-grid article,.question-grid article,.hub-grid article,.method-grid article,.faq-grid article{padding:14px}
  .quiet{font-size:14px}
}
/* Mobile-only proof card alignment fix: prevents the stat cards from clipping or drifting on Android/WebView widths without changing laptop layout. */
@media (max-width: 760px){
  .proof-points{
    display:grid;
    grid-template-columns:repeat(2,minmax(0,1fr));
    align-items:stretch;
    gap:10px;
    width:100%;
    max-width:100%;
    overflow:visible;
  }
  .proof-points div{
    display:grid;
    grid-template-columns:auto minmax(0,1fr);
    grid-template-rows:auto auto;
    align-items:center;
    column-gap:8px;
    row-gap:1px;
    width:100%;
    min-width:0;
    min-height:82px;
    padding:12px 13px;
    overflow:hidden;
  }
  .proof-points div > span{
    grid-row:1 / span 2;
    align-self:center;
    min-width:18px;
  }
  .proof-points strong,
  .proof-points em{
    display:block;
    min-width:0;
    max-width:100%;
    line-height:1.12;
    white-space:normal;
    overflow-wrap:anywhere;
    word-break:normal;
  }
  .proof-points strong{
    font-size:clamp(20px,4.8vw,27px);
  }
  .proof-points em{
    font-size:clamp(15px,3.7vw,21px);
  }
}

@media (max-width: 420px){
  .proof-points{
    grid-template-columns:1fr;
  }
  .proof-points div{
    min-height:auto;
  }
}

/* Methodology page + favicon polish: five-card criteria grid and safer editorial wrapping. */
.criteria-grid{grid-template-columns:repeat(auto-fit,minmax(205px,1fr))}
.route-page .section-head h2{max-width:1120px;overflow-wrap:balance;text-wrap:balance}
.route-page .criteria-grid article,.route-page .question-grid article{min-height:174px}
@media (min-width:1100px){
  .route-page .criteria-grid:has(> article:nth-child(5)){grid-template-columns:repeat(5,minmax(0,1fr))}
}
@media (max-width:920px){
  .route-page .criteria-grid article,.route-page .question-grid article{min-height:0}
}
@media (max-width:520px){
  .route-page .section-head h2{font-size:clamp(34px,12vw,46px);line-height:1.02}
}
