mirror of
				https://github.com/XRPLF/xrpl-dev-portal.git
				synced 2025-11-04 11:55:50 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			156 lines
		
	
	
		
			3.7 KiB
		
	
	
	
		
			SCSS
		
	
	
	
	
	
			
		
		
	
	
			156 lines
		
	
	
		
			3.7 KiB
		
	
	
	
		
			SCSS
		
	
	
	
	
	
.web-banner {
 | 
						|
  text-decoration: none;
 | 
						|
  display: flex;
 | 
						|
  justify-content: space-between;
 | 
						|
  height: $banner-height;
 | 
						|
  background: #32E685 !important;
 | 
						|
  padding: 7px 35px;
 | 
						|
  font-family: "Space Grotesk";
 | 
						|
  z-index: 10;
 | 
						|
  cursor: pointer;
 | 
						|
  
 | 
						|
  &:hover {
 | 
						|
    text-decoration: none;
 | 
						|
    color: $white;
 | 
						|
    .button-icon{
 | 
						|
      animation: iconJitter 0.7s cubic-bezier(0.16, 1, 0.3, 1) forwards;
 | 
						|
      transition: transform 0.7s cubic-bezier(0.16, 1, 0.3, 1);
 | 
						|
    }
 | 
						|
  }
 | 
						|
  color: $black !important;
 | 
						|
  text-align: center;
 | 
						|
  font-family: "Space Grotesk";
 | 
						|
  font-size: 26px; // Further scaled down from 28px
 | 
						|
  font-style: normal;
 | 
						|
  font-weight: 600;
 | 
						|
  letter-spacing: -0.32px;
 | 
						|
  // Pseudo-element for the fill animation
 | 
						|
  &::after {
 | 
						|
    content: "";
 | 
						|
    position: absolute;
 | 
						|
    top: 0;
 | 
						|
    left: 0;
 | 
						|
    width: 100%; // Full width so that we can scale it
 | 
						|
    height: 100%;
 | 
						|
    background-color: #E0E500;
 | 
						|
    z-index: 0;
 | 
						|
    transform: scaleX(0);       // Start scaled down to 0
 | 
						|
    transform-origin: left;     // Scale from the left edge
 | 
						|
    transition: transform 0.7s cubic-bezier(0.7, 0, 0.84, 0);
 | 
						|
    will-change: transform;     // Hint for smoother animations
 | 
						|
  }
 | 
						|
 | 
						|
  // On hover, scale to full width
 | 
						|
  &:hover::after {
 | 
						|
    transform: scaleX(1);
 | 
						|
    transition: transform 0.7s cubic-bezier(0.16, 1, 0.3, 1);
 | 
						|
  }
 | 
						|
  // Ensure direct children are above the pseudo-element
 | 
						|
  > * {
 | 
						|
    position: relative;
 | 
						|
    z-index: 1;
 | 
						|
  }
 | 
						|
  @media (max-width: 768px) {
 | 
						|
    font-size: 18px;
 | 
						|
    padding: 11px 35px;
 | 
						|
    .banner-button{
 | 
						|
      gap: 11px !important;
 | 
						|
    }
 | 
						|
    .button-text{
 | 
						|
      margin-bottom: 4px;
 | 
						|
    }
 | 
						|
  }
 | 
						|
  @media (max-width: 564px) {
 | 
						|
    font-size: 15px;
 | 
						|
    padding: 9px 40px;
 | 
						|
    .button-text{
 | 
						|
      margin-bottom: 0px;
 | 
						|
    }
 | 
						|
    .banner-event-details{
 | 
						|
      gap: 0px !important;
 | 
						|
      flex-direction: column;
 | 
						|
      text-align: left;
 | 
						|
      line-height: 21px;
 | 
						|
      .event-date{
 | 
						|
        position: relative;
 | 
						|
        top: -5px;
 | 
						|
      }
 | 
						|
    }
 | 
						|
    .banner-button{
 | 
						|
      align-self: baseline;
 | 
						|
      gap: 8px !important;
 | 
						|
      margin-top: -2px !important;
 | 
						|
      padding-top: 0px !important;
 | 
						|
    }
 | 
						|
  }
 | 
						|
  .banner-button{
 | 
						|
    display: flex;
 | 
						|
    align-items: center;
 | 
						|
    gap: 14.5px;
 | 
						|
    padding-top: 1px;
 | 
						|
    img{
 | 
						|
      width: 24.5px; 
 | 
						|
      height: 33.7px;
 | 
						|
      @media (max-width: 768px) {
 | 
						|
        width: 15.5px;
 | 
						|
        height: 17px;
 | 
						|
        margin-top: 4px;
 | 
						|
      }
 | 
						|
      @media (max-width: 564px) {
 | 
						|
        width: 14.5px;
 | 
						|
        height: 13.85px;
 | 
						|
      }
 | 
						|
    }
 | 
						|
  }
 | 
						|
 | 
						|
  .banner-event-details {
 | 
						|
    display: flex;
 | 
						|
    gap: 32px;
 | 
						|
  }
 | 
						|
 | 
						|
 | 
						|
  .button-icon {
 | 
						|
    transform-style: preserve-3d;
 | 
						|
    aspect-ratio: 0.71;
 | 
						|
    object-fit: contain;
 | 
						|
    animation: none;
 | 
						|
    transform: rotateZ(0deg);
 | 
						|
    transition: transform 0.7s cubic-bezier(0.16, 1, 0.3, 1); // Adjust duration as needed
 | 
						|
    align-self: stretch;
 | 
						|
    margin: auto 0;
 | 
						|
    transform-style: preserve-3d;
 | 
						|
  }
 | 
						|
 | 
						|
  @keyframes iconJitter {
 | 
						|
    from {
 | 
						|
      transform: translate3d(0, 0, 0) scale3d(1, 1, 1) rotateZ(0deg) skew(0deg, 0deg);
 | 
						|
    }
 | 
						|
    to {
 | 
						|
      transform: translate3d(0, 0, 0) scale3d(1, 1, 1) rotateZ(45deg) skew(0deg, 0deg);
 | 
						|
    }
 | 
						|
  }
 | 
						|
 | 
						|
}
 | 
						|
 | 
						|
.web-banner a {
 | 
						|
  text-decoration: none;
 | 
						|
}
 | 
						|
 | 
						|
.button-icon {
 | 
						|
  animation: iconJitter 0.7s ease-in-out;
 | 
						|
  animation-iteration-count: 1;
 | 
						|
  transition: transform 0.7s cubic-bezier(0.16, 1, 0.3, 1);
 | 
						|
}
 | 
						|
@keyframes iconReturn {
 | 
						|
  from {
 | 
						|
    transform: translate3d(0, 0, 0) scale3d(1, 1, 1) rotateZ(45deg) skew(0deg, 0deg);
 | 
						|
  }
 | 
						|
  to {
 | 
						|
    transform: translate3d(0, 0, 0) scale3d(1, 1, 1) rotateZ(0deg) skew(0deg, 0deg);
 | 
						|
  }
 | 
						|
}
 | 
						|
/* After the banner has been hovered once, on unhover run the reverse animation */
 | 
						|
.web-banner.has-hover:not(:hover) .button-icon {
 | 
						|
  animation: iconReturn 0.7s ease-in-out forwards;
 | 
						|
  transition: transform 0.7s cubic-bezier(0.16, 1, 0.3, 1);
 | 
						|
} |