Multi-Cloud Identity Pro: AWS & Azure
<section class="identity-flow-v3">
<div class="flow-container">
<!-- Azure Entra ID -->
<div class="flow-icon azure-icon">
<img src="/uploads/header_icon1_5ba29d5b59.png" alt="Azure Entra ID" draggable="false" />
</div>
<!-- Connection Line with small User Icon in the middle -->
<div class="flow-connection">
<div class="connection-line"></div>
<div class="flow-icon user-sync-icon">
<img src="/uploads/header_icon3_bfd9f2c9ff.png" alt="User Sync" draggable="false" />
</div>
</div>
<!-- AWS Identity Center -->
<div class="flow-icon aws-icon">
<img src="/uploads/header_icon2_1fc177ce35.png" alt="AWS IAM Identity Center" draggable="false" />
</div>
</div>
</section>
<style>
.identity-flow-v3 {
display: flex;
justify-content: center;
align-items: center;
padding: clamp(24px, 4vw, 40px) 0;
max-width: 100%;
margin: 0 auto;
width: 100%;
user-select: none;
-webkit-user-select: none;
-moz-user-select: none;
-ms-user-select: none;
}
.flow-container {
display: flex;
align-items: center;
justify-content: center;
gap: 0;
position: relative;
width: 100%;
max-width: min(90%, 700px);
margin: 0 auto;
}
.flow-icon {
position: relative;
background: linear-gradient(135deg, rgba(59, 130, 246, 0.12), rgba(99, 102, 241, 0.06));
border: 2.5px solid rgba(59, 130, 246, 0.35);
border-radius: 20px;
padding: clamp(16px, 3vw, 24px);
transition: all 0.35s cubic-bezier(0.4, 0, 0.2, 1);
cursor: pointer;
box-shadow: 0 6px 20px rgba(0, 0, 0, 0.15);
backdrop-filter: blur(8px);
z-index: 2;
}
.flow-icon img {
display: block;
width: clamp(64px, 10vw, 100px);
height: clamp(64px, 10vw, 100px);
object-fit: contain;
pointer-events: none;
user-select: none;
-webkit-user-drag: none;
filter: drop-shadow(0 2px 8px rgba(0, 0, 0, 0.2));
}
.flow-icon:hover {
border-color: rgba(59, 130, 246, 0.9);
background: linear-gradient(135deg, rgba(59, 130, 246, 0.25), rgba(99, 102, 241, 0.12));
box-shadow: 0 0 0 4px rgba(59, 130, 246, 0.25), 0 12px 32px rgba(59, 130, 246, 0.3);
transform: translateY(-4px) scale(1.08);
}
.azure-icon {
background: linear-gradient(135deg, rgba(0, 120, 212, 0.15), rgba(59, 130, 246, 0.08));
border-color: rgba(0, 120, 212, 0.4);
}
.azure-icon:hover {
border-color: rgba(0, 120, 212, 0.9);
background: linear-gradient(135deg, rgba(0, 120, 212, 0.28), rgba(59, 130, 246, 0.15));
box-shadow: 0 0 0 4px rgba(0, 120, 212, 0.25), 0 12px 32px rgba(0, 120, 212, 0.35);
}
.aws-icon {
background: linear-gradient(135deg, rgba(255, 153, 0, 0.12), rgba(232, 119, 34, 0.06));
border-color: rgba(255, 153, 0, 0.4);
}
.aws-icon:hover {
border-color: rgba(255, 153, 0, 0.9);
background: linear-gradient(135deg, rgba(255, 153, 0, 0.22), rgba(232, 119, 34, 0.12));
box-shadow: 0 0 0 4px rgba(255, 153, 0, 0.25), 0 12px 32px rgba(255, 153, 0, 0.35);
}
.flow-connection {
position: relative;
flex: 1;
display: flex;
align-items: center;
justify-content: center;
height: auto;
margin: 0 clamp(-16px, -2vw, -12px);
z-index: 1;
}
.connection-line {
position: absolute;
width: 100%;
height: 3px;
background: linear-gradient(90deg,
rgba(0, 120, 212, 0.6) 0%,
rgba(96, 165, 250, 0.8) 25%,
rgba(167, 139, 250, 0.8) 50%,
rgba(96, 165, 250, 0.8) 75%,
rgba(255, 153, 0, 0.6) 100%
);
box-shadow: 0 0 12px rgba(96, 165, 250, 0.5);
transition: all 0.35s cubic-bezier(0.4, 0, 0.2, 1);
z-index: 1;
}
.connection-line::after {
content: '';
position: absolute;
right: -8px;
top: 50%;
transform: translateY(-50%);
width: 0;
height: 0;
border-left: 12px solid rgba(255, 153, 0, 0.7);
border-top: 8px solid transparent;
border-bottom: 8px solid transparent;
filter: drop-shadow(0 0 6px rgba(255, 153, 0, 0.6));
}
.flow-connection:hover .connection-line {
height: 4px;
box-shadow: 0 0 20px rgba(96, 165, 250, 0.8), 0 0 40px rgba(167, 139, 250, 0.4);
background: linear-gradient(90deg,
rgba(0, 120, 212, 0.8) 0%,
rgba(96, 165, 250, 1) 25%,
rgba(167, 139, 250, 1) 50%,
rgba(96, 165, 250, 1) 75%,
rgba(255, 153, 0, 0.8) 100%
);
}
.user-sync-icon {
position: relative;
z-index: 10;
background: linear-gradient(135deg, rgba(167, 139, 250, 0.25), rgba(139, 92, 246, 0.15));
border-color: rgba(167, 139, 250, 0.6);
padding: clamp(10px, 2vw, 14px);
border-radius: 14px;
animation: pulse-glow 2.5s ease-in-out infinite;
}
.user-sync-icon img {
width: clamp(32px, 5vw, 48px);
height: clamp(32px, 5vw, 48px);
}
.user-sync-icon:hover {
border-color: rgba(167, 139, 250, 1);
background: linear-gradient(135deg, rgba(167, 139, 250, 0.4), rgba(139, 92, 246, 0.25));
box-shadow: 0 0 0 4px rgba(167, 139, 250, 0.35), 0 8px 24px rgba(167, 139, 250, 0.45);
animation-play-state: paused;
transform: translateY(-3px) scale(1.15);
}
@keyframes pulse-glow {
0%, 100% {
box-shadow: 0 0 0 0 rgba(167, 139, 250, 0.4), 0 6px 18px rgba(0, 0, 0, 0.15);
}
50% {
box-shadow: 0 0 0 8px rgba(167, 139, 250, 0.1), 0 6px 24px rgba(167, 139, 250, 0.3);
}
}
/* Responsive adjustments */
@media (max-width: 768px) {
.flow-container {
max-width: 95%;
}
.flow-icon {
padding: clamp(12px, 2.5vw, 18px);
border-radius: 16px;
}
.flow-icon img {
width: clamp(52px, 9vw, 72px);
height: clamp(52px, 9vw, 72px);
}
.user-sync-icon {
padding: clamp(8px, 1.5vw, 12px);
}
.user-sync-icon img {
width: clamp(28px, 4.5vw, 40px);
height: clamp(28px, 4.5vw, 40px);
}
}
@media (max-width: 480px) {
.identity-flow-v3 {
padding: clamp(20px, 3vw, 32px) 0;
}
.flow-container {
max-width: 98%;
}
.flow-icon {
padding: clamp(10px, 2vw, 14px);
border-radius: 14px;
}
.flow-icon img {
width: clamp(44px, 8vw, 56px);
height: clamp(44px, 8vw, 56px);
}
.user-sync-icon {
padding: clamp(6px, 1.2vw, 10px);
border-radius: 12px;
}
.user-sync-icon img {
width: clamp(24px, 4vw, 32px);
height: clamp(24px, 4vw, 32px);
}
.connection-line {
height: 2px;
}
.connection-line::after {
border-left-width: 10px;
border-top-width: 6px;
border-bottom-width: 6px;
right: -6px;
}
.flow-connection {
margin: 0 clamp(-12px, -1.5vw, -8px);
}
}
/* Accessibility */
.flow-icon:focus-visible {
outline: 3px solid rgba(59, 130, 246, 0.7);
outline-offset: 3px;
}
/* Prevent text selection */
.identity-flow-v3 * {
user-select: none;
-webkit-user-select: none;
-moz-user-select: none;
-ms-user-select: none;
}
</style>
$24.99