
/* Hub V403 — Site Organization Upgrade */

/* Cleaner global navigation */
header.nav .navlinks{
  gap:14px !important;
}
header.nav .navlinks a{
  padding:10px 12px !important;
  border-radius:999px !important;
  color:#334155 !important;
  background:rgba(248,250,252,.55);
  border:1px solid transparent;
}
header.nav .navlinks a:hover{
  background:#eff6ff !important;
  border-color:#bfdbfe !important;
  color:#0369a1 !important;
}

/* Organized homepage router */
.hub403-section{
  max-width:1180px;
  margin:0 auto 28px;
  padding:0 18px;
}
.hub403-priority-router{
  margin-top:-4px;
}
.hub403-router-head{
  display:flex;
  flex-direction:column;
  gap:6px;
  margin-bottom:16px;
  padding:22px;
  border-radius:28px;
  border:1px solid rgba(191,219,254,.9);
  background:linear-gradient(135deg,#ffffff,#f7fbff 58%,#eff6ff);
  box-shadow:0 18px 42px rgba(15,23,42,.06);
}
.hub403-kicker{
  display:inline-flex;
  width:max-content;
  align-items:center;
  gap:8px;
  padding:7px 10px;
  border-radius:999px;
  background:#e0f2fe;
  color:#075985;
  font-weight:900;
  font-size:.78rem;
  letter-spacing:.12em;
  text-transform:uppercase;
}
.hub403-router-head h2{
  margin:0;
  color:#0f172a;
  font-size:clamp(1.7rem,3.2vw,2.8rem);
  line-height:.98;
  letter-spacing:-.055em;
}
.hub403-router-head p{
  margin:0;
  max-width:780px;
  color:#475569;
  line-height:1.58;
}
.hub403-router-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:16px;
}
.hub403-route{
  display:flex;
  flex-direction:column;
  min-height:100%;
  padding:14px;
  border-radius:30px;
  text-decoration:none;
  background:linear-gradient(180deg,#ffffff,#f8fbff);
  border:1px solid rgba(191,219,254,.95);
  box-shadow:0 18px 42px rgba(15,23,42,.08);
  overflow:hidden;
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.hub403-route:hover{
  transform:translateY(-2px);
  border-color:#7dd3fc;
  box-shadow:0 26px 58px rgba(14,165,233,.14);
}
.hub403-route img{
  width:100%;
  height:144px;
  object-fit:contain;
  object-position:center;
  border-radius:22px;
  background:linear-gradient(180deg,#f8fbff,#eef6ff);
  border:1px solid rgba(219,234,254,.95);
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.88);
  margin-bottom:12px;
}
.hub403-route span{
  display:inline-flex;
  width:max-content;
  padding:6px 9px;
  border-radius:999px;
  background:#eff6ff;
  color:#075985;
  font-size:.72rem;
  font-weight:950;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.hub403-route h3{
  margin:11px 0 6px;
  color:#0f172a;
  font-size:1.1rem;
  letter-spacing:-.03em;
}
.hub403-route p{
  margin:0 0 14px;
  color:#475569;
  line-height:1.48;
  font-size:.92rem;
}
.hub403-route b{
  margin-top:auto;
  color:#0369a1;
}
.hub403-route.primary{
  background:linear-gradient(180deg,#f0f9ff,#ffffff);
  border-color:#7dd3fc;
}

/* Fast map */
.hub403-fast-map{
  margin-top:-10px;
}
.hub403-map-row{
  display:grid;
  grid-template-columns:repeat(6,minmax(0,1fr));
  gap:10px;
}
.hub403-map-row a{
  display:block;
  padding:16px;
  border-radius:20px;
  text-decoration:none;
  background:rgba(255,255,255,.94);
  border:1px solid rgba(191,219,254,.85);
  box-shadow:0 12px 26px rgba(15,23,42,.06);
}
.hub403-map-row b{
  display:block;
  color:#0f172a;
  font-size:.98rem;
  margin-bottom:4px;
}
.hub403-map-row span{
  display:block;
  color:#64748b;
  font-size:.82rem;
  line-height:1.35;
}

/* Start Here page */
.hub403-page{
  max-width:1180px;
  margin:0 auto;
  padding:20px 18px 44px;
}
.hub403-page-hero{
  border-radius:34px;
  padding:clamp(28px,5vw,54px);
  background:
    radial-gradient(circle at 78% 12%,rgba(56,189,248,.20),transparent 34%),
    linear-gradient(135deg,#ffffff,#f8fbff 52%,#eef6ff);
  border:1px solid rgba(191,219,254,.95);
  box-shadow:0 24px 72px rgba(15,23,42,.10);
  margin-bottom:22px;
}
.hub403-page-hero h1{
  margin:12px 0 10px;
  color:#0f172a;
  font-size:clamp(2.3rem,5vw,4.8rem);
  line-height:.92;
  letter-spacing:-.07em;
  max-width:820px;
}
.hub403-page-hero p{
  max-width:760px;
  color:#475569;
  font-size:1.08rem;
  line-height:1.6;
  margin:0 0 22px;
}
.hub403-hero-actions{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}
.hub403-page-section{
  margin:22px 0;
}
.hub403-steps{
  display:grid;
  grid-template-columns:repeat(5,minmax(0,1fr));
  gap:12px;
}
.hub403-steps a,
.hub403-collection-grid a{
  display:block;
  padding:18px;
  text-decoration:none;
  background:#ffffff;
  border:1px solid rgba(191,219,254,.9);
  border-radius:24px;
  box-shadow:0 14px 34px rgba(15,23,42,.06);
}
.hub403-steps b{
  display:inline-flex;
  padding:7px 9px;
  border-radius:999px;
  background:#e0f2fe;
  color:#075985;
  font-weight:950;
}
.hub403-steps h3{
  color:#0f172a;
  margin:12px 0 6px;
}
.hub403-steps p{
  color:#475569;
  margin:0;
  line-height:1.45;
  font-size:.9rem;
}
.hub403-collection-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:12px;
}
.hub403-collection-grid b{
  display:block;
  color:#0f172a;
  margin-bottom:6px;
  font-size:1.04rem;
}
.hub403-collection-grid span{
  display:block;
  color:#475569;
  line-height:1.45;
  font-size:.92rem;
}

/* Keep older heavy sections visually below the new organizer */
.hub393-home .hub393-section{
  scroll-margin-top:110px;
}

@media(max-width:1040px){
  .hub403-router-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .hub403-map-row{grid-template-columns:repeat(3,minmax(0,1fr))}
  .hub403-steps{grid-template-columns:repeat(3,minmax(0,1fr))}
}
@media(max-width:760px){
  .hub403-section{padding:0 10px;margin-bottom:18px}
  .hub403-router-grid,
  .hub403-map-row,
  .hub403-steps,
  .hub403-collection-grid{
    grid-template-columns:1fr;
  }
  .hub403-router-head{
    padding:18px;
    border-radius:22px;
  }
  .hub403-route{
    border-radius:24px;
  }
  .hub403-route img{
    height:128px;
  }
  .hub403-page{
    padding:10px 10px 34px;
  }
  .hub403-page-hero{
    border-radius:26px;
    padding:24px 18px;
  }
  .hub403-page-hero h1{
    font-size:2.35rem;
  }
}
