/**
 * Elementor Widgets PDA - Frontend Styles
 *
 * @package Elementor_Widgets_PDA
 * @version 1.0.0
 */

/* ==========================================================================
   Base Styles
   ========================================================================== */

.ewpda-widget {
    position: relative;
}

/* ==========================================================================
   Utility Classes
   ========================================================================== */

.ewpda-flex {
    display: flex;
}

.ewpda-flex-wrap {
    flex-wrap: wrap;
}

.ewpda-items-center {
    align-items: center;
}

.ewpda-justify-center {
    justify-content: center;
}

.ewpda-justify-between {
    justify-content: space-between;
}

.ewpda-text-center {
    text-align: center;
}

.ewpda-hidden {
    display: none;
}

/* ==========================================================================
   Animation Classes
   ========================================================================== */

.ewpda-fade-in {
    animation: ewpdaFadeIn 0.3s ease-in-out;
}

.ewpda-slide-up {
    animation: ewpdaSlideUp 0.3s ease-in-out;
}

@keyframes ewpdaFadeIn {
    from {
        opacity: 0;
    }
    to {
        opacity: 1;
    }
}

@keyframes ewpdaSlideUp {
    from {
        opacity: 0;
        transform: translateY(20px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* ==========================================================================
   Loading States
   ========================================================================== */

.ewpda-loading {
    position: relative;
    pointer-events: none;
}

.ewpda-loading::after {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    width: 30px;
    height: 30px;
    margin: -15px 0 0 -15px;
    border: 3px solid #f3f3f3;
    border-top: 3px solid #3498db;
    border-radius: 50%;
    animation: ewpdaSpin 1s linear infinite;
}

@keyframes ewpdaSpin {
    0% {
        transform: rotate(0deg);
    }
    100% {
        transform: rotate(360deg);
    }
}

/* ==========================================================================
   Responsive Utilities
   ========================================================================== */

@media (max-width: 1024px) {
    .ewpda-hide-tablet {
        display: none !important;
    }
}

@media (max-width: 767px) {
    .ewpda-hide-mobile {
        display: none !important;
    }
}

/* ==========================================================================
   Add your custom widget styles below
   ========================================================================== */
/* ==========================================================================
   EWPDA Image Card Widget
   ========================================================================== */

.ewpda-ic-card {
    display: block;
    position: relative;
    text-decoration: none;
    transition: all 0.3s ease;
    overflow: hidden;
    cursor: pointer;
}

.ewpda-ic-card__image {
    position: absolute;
    top: 0;
    left: 0;
    width: 100% !important;
    height: 100% !important;
    object-fit: cover;
    object-position: center center;
    transition: transform 0.4s ease;
    z-index: 1;
    pointer-events: none;
}

.ewpda-ic-card__text {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    display: block;
    transition: background-color 0.3s ease;
    z-index: 2;
    pointer-events: none;
}

/* Link styles */
a.ewpda-ic-card {
    color: inherit;
    text-decoration: none;
    display: block;
}

a.ewpda-ic-card:hover {
    text-decoration: none;
}

a.ewpda-ic-card:focus {
    outline: none;
}

/* ==========================================================================
   EWPDA Timeline Widget
   ========================================================================== */

.ewpda-tl {
    position: relative;
    width: 100%;
}

/* Linha Central */
.ewpda-tl__line {
    position: absolute;
    left: 50%;
    top: 0;
    bottom: 0;
    width: 3px;
    background-color: #1B4F72;
    transform: translateX(-50%);
    z-index: 1;
}

/* Item da Timeline */
.ewpda-tl__item {
    position: relative;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 40px;
    margin-bottom: 60px;
    align-items: center;
}

.ewpda-tl__item:last-child {
    margin-bottom: 0;
}

/* Marcador/Dot */
.ewpda-tl__dot {
    position: absolute;
    left: 50%;
    top: 20px;
    width: 16px;
    height: 16px;
    background-color: #1B4F72;
    border: 3px solid #FFFFFF;
    border-radius: 50%;
    transform: translateX(-50%);
    z-index: 2;
    box-shadow: 0 0 0 4px rgba(27, 79, 114, 0.2);
}

/* Conteúdo */
.ewpda-tl__content {
    position: relative;
}

.ewpda-tl__date {
    font-size: 14px;
    font-weight: 500;
    color: #1B4F72;
    margin-bottom: 5px;
    letter-spacing: 0.5px;
}

.ewpda-tl__title {
    font-size: 24px;
    font-weight: 700;
    color: #1B4F72;
    margin: 0 0 15px 0;
    line-height: 1.3;
}

.ewpda-tl__description {
    font-size: 15px;
    line-height: 1.7;
    color: #333333;
}

/* Imagem */
.ewpda-tl__image {
    position: relative;
}

.ewpda-tl__image img {
    width: 100%;
    height: auto;
    display: block;
    border-radius: 10px;
}

/* Layout - Item à Esquerda (conteúdo esquerda, imagem direita) */
.ewpda-tl__item--left .ewpda-tl__content {
    grid-column: 1;
    text-align: right;
    padding-right: 30px;
}

.ewpda-tl__item--left .ewpda-tl__image {
    grid-column: 2;
    padding-left: 30px;
}

/* Layout - Item à Direita (imagem esquerda, conteúdo direita) */
.ewpda-tl__item--right {
    direction: rtl;
}

.ewpda-tl__item--right > * {
    direction: ltr;
}

.ewpda-tl__item--right .ewpda-tl__content {
    grid-column: 1;
    text-align: left;
    padding-left: 30px;
}

.ewpda-tl__item--right .ewpda-tl__image {
    grid-column: 2;
    padding-right: 30px;
}

/* Layout Fixo Esquerda */
.ewpda-tl--left .ewpda-tl__line {
    left: 30px;
}

.ewpda-tl--left .ewpda-tl__item {
    grid-template-columns: 60px 1fr 1fr;
}

.ewpda-tl--left .ewpda-tl__dot {
    left: 30px;
}

/* Layout Fixo Direita */
.ewpda-tl--right .ewpda-tl__line {
    left: auto;
    right: 30px;
}

.ewpda-tl--right .ewpda-tl__item {
    grid-template-columns: 1fr 1fr 60px;
}

.ewpda-tl--right .ewpda-tl__dot {
    left: auto;
    right: 30px;
    transform: translateX(50%);
}

/* ==========================================================================
   Timeline Animações
   ========================================================================== */

/* Estado inicial - escondido */
.ewpda-tl__item--hidden {
    opacity: 0;
}

.ewpda-tl__item--hidden .ewpda-tl__content,
.ewpda-tl__item--hidden .ewpda-tl__image {
    opacity: 0;
}

/* Fade */
.ewpda-tl--animated[data-animation="fade"] .ewpda-tl__item--hidden .ewpda-tl__content,
.ewpda-tl--animated[data-animation="fade"] .ewpda-tl__item--hidden .ewpda-tl__image {
    opacity: 0;
}

/* Fade + Slide */
.ewpda-tl--animated[data-animation="fade-slide"] .ewpda-tl__item--left.ewpda-tl__item--hidden .ewpda-tl__content {
    transform: translateX(-50px);
}

.ewpda-tl--animated[data-animation="fade-slide"] .ewpda-tl__item--left.ewpda-tl__item--hidden .ewpda-tl__image {
    transform: translateX(50px);
}

.ewpda-tl--animated[data-animation="fade-slide"] .ewpda-tl__item--right.ewpda-tl__item--hidden .ewpda-tl__content {
    transform: translateX(50px);
}

.ewpda-tl--animated[data-animation="fade-slide"] .ewpda-tl__item--right.ewpda-tl__item--hidden .ewpda-tl__image {
    transform: translateX(-50px);
}

/* Fade + Scale */
.ewpda-tl--animated[data-animation="fade-scale"] .ewpda-tl__item--hidden .ewpda-tl__content,
.ewpda-tl--animated[data-animation="fade-scale"] .ewpda-tl__item--hidden .ewpda-tl__image {
    transform: scale(0.8);
}

/* Slide Only */
.ewpda-tl--animated[data-animation="slide-only"] .ewpda-tl__item--left.ewpda-tl__item--hidden .ewpda-tl__content {
    transform: translateX(-80px);
    opacity: 1;
}

.ewpda-tl--animated[data-animation="slide-only"] .ewpda-tl__item--left.ewpda-tl__item--hidden .ewpda-tl__image {
    transform: translateX(80px);
    opacity: 1;
}

.ewpda-tl--animated[data-animation="slide-only"] .ewpda-tl__item--right.ewpda-tl__item--hidden .ewpda-tl__content {
    transform: translateX(80px);
    opacity: 1;
}

.ewpda-tl--animated[data-animation="slide-only"] .ewpda-tl__item--right.ewpda-tl__item--hidden .ewpda-tl__image {
    transform: translateX(-80px);
    opacity: 1;
}

/* Blur In */
.ewpda-tl--animated[data-animation="blur-in"] .ewpda-tl__item--hidden .ewpda-tl__content,
.ewpda-tl--animated[data-animation="blur-in"] .ewpda-tl__item--hidden .ewpda-tl__image {
    filter: blur(10px);
    transform: scale(1.05);
}

/* Rotate In */
.ewpda-tl--animated[data-animation="rotate-in"] .ewpda-tl__item--left.ewpda-tl__item--hidden .ewpda-tl__content {
    transform: translateX(-30px) rotate(-5deg);
}

.ewpda-tl--animated[data-animation="rotate-in"] .ewpda-tl__item--left.ewpda-tl__item--hidden .ewpda-tl__image {
    transform: translateX(30px) rotate(5deg);
}

.ewpda-tl--animated[data-animation="rotate-in"] .ewpda-tl__item--right.ewpda-tl__item--hidden .ewpda-tl__content {
    transform: translateX(30px) rotate(5deg);
}

.ewpda-tl--animated[data-animation="rotate-in"] .ewpda-tl__item--right.ewpda-tl__item--hidden .ewpda-tl__image {
    transform: translateX(-30px) rotate(-5deg);
}

/* Estado Visível - Animado */
.ewpda-tl__item--visible {
    opacity: 1;
}

.ewpda-tl__item--visible .ewpda-tl__content,
.ewpda-tl__item--visible .ewpda-tl__image {
    opacity: 1;
    transform: translateX(0) scale(1) rotate(0);
    filter: blur(0);
}

/* ==========================================================================
   Timeline Responsivo
   ========================================================================== */

@media (max-width: 1024px) {
    .ewpda-tl__item {
        gap: 30px;
    }
    
    .ewpda-tl__item--left .ewpda-tl__content {
        padding-right: 20px;
    }
    
    .ewpda-tl__item--left .ewpda-tl__image {
        padding-left: 20px;
    }
    
    .ewpda-tl__item--right .ewpda-tl__content {
        padding-left: 20px;
    }
    
    .ewpda-tl__item--right .ewpda-tl__image {
        padding-right: 20px;
    }
}

@media (max-width: 767px) {
    /* Linha à esquerda no mobile */
    .ewpda-tl__line {
        left: 15px !important;
        transform: none;
    }
    
    /* Marcador à esquerda */
    .ewpda-tl__dot {
        left: 15px !important;
        top: 5px;
        transform: translateX(-50%);
        width: 12px;
        height: 12px;
    }
    
    /* Layout coluna única */
    .ewpda-tl__item {
        display: block !important;
        grid-template-columns: none !important;
        padding-left: 40px;
        margin-bottom: 40px;
    }
    
    .ewpda-tl__item--left,
    .ewpda-tl__item--right {
        direction: ltr;
    }
    
    /* Conteúdo alinhado à esquerda */
    .ewpda-tl__item--left .ewpda-tl__content,
    .ewpda-tl__item--right .ewpda-tl__content {
        text-align: left;
        padding: 0 0 15px 0;
    }
    
    /* Imagem abaixo do conteúdo */
    .ewpda-tl__item--left .ewpda-tl__image,
    .ewpda-tl__item--right .ewpda-tl__image {
        padding: 0;
    }
    
    .ewpda-tl__image img {
        max-width: 100%;
    }
    
    /* Tipografia mobile */
    .ewpda-tl__date {
        font-size: 12px;
    }
    
    .ewpda-tl__title {
        font-size: 18px;
        margin-bottom: 10px;
    }
    
    .ewpda-tl__description {
        font-size: 14px;
        line-height: 1.6;
    }
    
    /* Fix para layouts fixos */
    .ewpda-tl--left .ewpda-tl__line,
    .ewpda-tl--right .ewpda-tl__line {
        left: 15px !important;
        right: auto !important;
    }
    
    .ewpda-tl--left .ewpda-tl__dot,
    .ewpda-tl--right .ewpda-tl__dot {
        left: 15px !important;
        right: auto !important;
        transform: translateX(-50%);
    }
    
    .ewpda-tl--left .ewpda-tl__item,
    .ewpda-tl--right .ewpda-tl__item {
        padding-left: 40px;
    }
}

/* ==========================================================================
   EWPDA Container Hover Animations
   ========================================================================== */

/* Base para animações */
.ewpda-hover-animated {
    --ewpda-hover-duration: 0.3s;
    --ewpda-hover-delay: 0s;
    display: inline-block;
    vertical-align: middle;
    transform: perspective(1px) translateZ(0);
    box-shadow: 0 0 1px rgba(0, 0, 0, 0);
    transition-duration: var(--ewpda-hover-duration);
    transition-delay: var(--ewpda-hover-delay);
    transition-property: transform, box-shadow, background-color;
    transition-timing-function: ease-out;
}

/* ==========================================================================
   2D Transitions
   ========================================================================== */

/* Grow */
.ewpda-hover-grow:hover,
.ewpda-hover-grow:focus,
.ewpda-hover-grow:active {
    transform: scale(1.1);
}

/* Shrink */
.ewpda-hover-shrink:hover,
.ewpda-hover-shrink:focus,
.ewpda-hover-shrink:active {
    transform: scale(0.9);
}

/* Pulse */
@keyframes ewpda-pulse {
    25% { transform: scale(1.1); }
    75% { transform: scale(0.9); }
}
.ewpda-hover-pulse:hover,
.ewpda-hover-pulse:focus,
.ewpda-hover-pulse:active {
    animation: ewpda-pulse 1s linear infinite;
}

/* Pulse Grow */
@keyframes ewpda-pulse-grow {
    to { transform: scale(1.1); }
}
.ewpda-hover-pulse-grow:hover,
.ewpda-hover-pulse-grow:focus,
.ewpda-hover-pulse-grow:active {
    animation: ewpda-pulse-grow 0.3s linear infinite alternate;
}

/* Pulse Shrink */
@keyframes ewpda-pulse-shrink {
    to { transform: scale(0.9); }
}
.ewpda-hover-pulse-shrink:hover,
.ewpda-hover-pulse-shrink:focus,
.ewpda-hover-pulse-shrink:active {
    animation: ewpda-pulse-shrink 0.3s linear infinite alternate;
}

/* Push */
@keyframes ewpda-push {
    50% { transform: scale(0.8); }
    100% { transform: scale(1); }
}
.ewpda-hover-push:hover,
.ewpda-hover-push:focus,
.ewpda-hover-push:active {
    animation: ewpda-push 0.3s linear 1;
}

/* Pop */
@keyframes ewpda-pop {
    50% { transform: scale(1.2); }
}
.ewpda-hover-pop:hover,
.ewpda-hover-pop:focus,
.ewpda-hover-pop:active {
    animation: ewpda-pop 0.3s linear 1;
}

/* Bounce In */
.ewpda-hover-bounce-in {
    transition-duration: 0.5s;
}
.ewpda-hover-bounce-in:hover,
.ewpda-hover-bounce-in:focus,
.ewpda-hover-bounce-in:active {
    transform: scale(1.2);
    transition-timing-function: cubic-bezier(0.47, 2.02, 0.31, -0.36);
}

/* Bounce Out */
.ewpda-hover-bounce-out {
    transition-duration: 0.5s;
}
.ewpda-hover-bounce-out:hover,
.ewpda-hover-bounce-out:focus,
.ewpda-hover-bounce-out:active {
    transform: scale(0.8);
    transition-timing-function: cubic-bezier(0.47, 2.02, 0.31, -0.36);
}

/* Rotate */
.ewpda-hover-rotate {
    transition-duration: var(--ewpda-hover-duration);
    transition-property: transform;
}
.ewpda-hover-rotate:hover,
.ewpda-hover-rotate:focus,
.ewpda-hover-rotate:active {
    transform: rotate(4deg);
}

/* Grow Rotate */
.ewpda-hover-grow-rotate {
    transition-duration: var(--ewpda-hover-duration);
    transition-property: transform;
}
.ewpda-hover-grow-rotate:hover,
.ewpda-hover-grow-rotate:focus,
.ewpda-hover-grow-rotate:active {
    transform: scale(1.1) rotate(4deg);
}

/* Float */
.ewpda-hover-float:hover,
.ewpda-hover-float:focus,
.ewpda-hover-float:active {
    transform: translateY(-8px);
}

/* Sink */
.ewpda-hover-sink:hover,
.ewpda-hover-sink:focus,
.ewpda-hover-sink:active {
    transform: translateY(8px);
}

/* Bob */
@keyframes ewpda-bob {
    0% { transform: translateY(-8px); }
    50% { transform: translateY(-4px); }
    100% { transform: translateY(-8px); }
}
@keyframes ewpda-bob-float {
    100% { transform: translateY(-8px); }
}
.ewpda-hover-bob:hover,
.ewpda-hover-bob:focus,
.ewpda-hover-bob:active {
    animation: ewpda-bob-float 0.35s ease-out forwards, ewpda-bob 1.5s ease-in-out infinite 0.35s;
}

/* Hang */
@keyframes ewpda-hang {
    0% { transform: translateY(8px); }
    50% { transform: translateY(4px); }
    100% { transform: translateY(8px); }
}
@keyframes ewpda-hang-sink {
    100% { transform: translateY(8px); }
}
.ewpda-hover-hang:hover,
.ewpda-hover-hang:focus,
.ewpda-hover-hang:active {
    animation: ewpda-hang-sink 0.35s ease-out forwards, ewpda-hang 1.5s ease-in-out infinite 0.35s;
}

/* Skew */
.ewpda-hover-skew:hover,
.ewpda-hover-skew:focus,
.ewpda-hover-skew:active {
    transform: skew(-10deg);
}

/* Skew Forward */
.ewpda-hover-skew-forward {
    transform-origin: 0 100%;
}
.ewpda-hover-skew-forward:hover,
.ewpda-hover-skew-forward:focus,
.ewpda-hover-skew-forward:active {
    transform: skew(-10deg);
}

/* Skew Backward */
.ewpda-hover-skew-backward {
    transform-origin: 0 100%;
}
.ewpda-hover-skew-backward:hover,
.ewpda-hover-skew-backward:focus,
.ewpda-hover-skew-backward:active {
    transform: skew(10deg);
}

/* Wobble Vertical */
@keyframes ewpda-wobble-vertical {
    16.65% { transform: translateY(8px); }
    33.3% { transform: translateY(-6px); }
    49.95% { transform: translateY(4px); }
    66.6% { transform: translateY(-2px); }
    83.25% { transform: translateY(1px); }
    100% { transform: translateY(0); }
}
.ewpda-hover-wobble-vertical:hover,
.ewpda-hover-wobble-vertical:focus,
.ewpda-hover-wobble-vertical:active {
    animation: ewpda-wobble-vertical 1s ease-in-out 1;
}

/* Wobble Horizontal */
@keyframes ewpda-wobble-horizontal {
    16.65% { transform: translateX(8px); }
    33.3% { transform: translateX(-6px); }
    49.95% { transform: translateX(4px); }
    66.6% { transform: translateX(-2px); }
    83.25% { transform: translateX(1px); }
    100% { transform: translateX(0); }
}
.ewpda-hover-wobble-horizontal:hover,
.ewpda-hover-wobble-horizontal:focus,
.ewpda-hover-wobble-horizontal:active {
    animation: ewpda-wobble-horizontal 1s ease-in-out 1;
}

/* Wobble To Bottom Right */
@keyframes ewpda-wobble-to-bottom-right {
    16.65% { transform: translate(8px, 8px); }
    33.3% { transform: translate(-6px, -6px); }
    49.95% { transform: translate(4px, 4px); }
    66.6% { transform: translate(-2px, -2px); }
    83.25% { transform: translate(1px, 1px); }
    100% { transform: translate(0, 0); }
}
.ewpda-hover-wobble-to-bottom-right:hover,
.ewpda-hover-wobble-to-bottom-right:focus,
.ewpda-hover-wobble-to-bottom-right:active {
    animation: ewpda-wobble-to-bottom-right 1s ease-in-out 1;
}

/* Wobble To Top Right */
@keyframes ewpda-wobble-to-top-right {
    16.65% { transform: translate(8px, -8px); }
    33.3% { transform: translate(-6px, 6px); }
    49.95% { transform: translate(4px, -4px); }
    66.6% { transform: translate(-2px, 2px); }
    83.25% { transform: translate(1px, -1px); }
    100% { transform: translate(0, 0); }
}
.ewpda-hover-wobble-to-top-right:hover,
.ewpda-hover-wobble-to-top-right:focus,
.ewpda-hover-wobble-to-top-right:active {
    animation: ewpda-wobble-to-top-right 1s ease-in-out 1;
}

/* Wobble Top */
@keyframes ewpda-wobble-top {
    16.65% { transform: skew(-12deg); }
    33.3% { transform: skew(10deg); }
    49.95% { transform: skew(-6deg); }
    66.6% { transform: skew(4deg); }
    83.25% { transform: skew(-2deg); }
    100% { transform: skew(0); }
}
.ewpda-hover-wobble-top {
    transform-origin: 0 100%;
}
.ewpda-hover-wobble-top:hover,
.ewpda-hover-wobble-top:focus,
.ewpda-hover-wobble-top:active {
    animation: ewpda-wobble-top 1s ease-in-out 1;
}

/* Wobble Bottom */
@keyframes ewpda-wobble-bottom {
    16.65% { transform: skew(-12deg); }
    33.3% { transform: skew(10deg); }
    49.95% { transform: skew(-6deg); }
    66.6% { transform: skew(4deg); }
    83.25% { transform: skew(-2deg); }
    100% { transform: skew(0); }
}
.ewpda-hover-wobble-bottom {
    transform-origin: 100% 0;
}
.ewpda-hover-wobble-bottom:hover,
.ewpda-hover-wobble-bottom:focus,
.ewpda-hover-wobble-bottom:active {
    animation: ewpda-wobble-bottom 1s ease-in-out 1;
}

/* Wobble Skew */
@keyframes ewpda-wobble-skew {
    16.65% { transform: skew(-12deg); }
    33.3% { transform: skew(10deg); }
    49.95% { transform: skew(-6deg); }
    66.6% { transform: skew(4deg); }
    83.25% { transform: skew(-2deg); }
    100% { transform: skew(0); }
}
.ewpda-hover-wobble-skew:hover,
.ewpda-hover-wobble-skew:focus,
.ewpda-hover-wobble-skew:active {
    animation: ewpda-wobble-skew 1s ease-in-out 1;
}

/* Buzz */
@keyframes ewpda-buzz {
    50% { transform: translateX(3px) rotate(2deg); }
    100% { transform: translateX(-3px) rotate(-2deg); }
}
.ewpda-hover-buzz:hover,
.ewpda-hover-buzz:focus,
.ewpda-hover-buzz:active {
    animation: ewpda-buzz 0.15s linear infinite;
}

/* Buzz Out */
@keyframes ewpda-buzz-out {
    10% { transform: translateX(3px) rotate(2deg); }
    20% { transform: translateX(-3px) rotate(-2deg); }
    30% { transform: translateX(3px) rotate(2deg); }
    40% { transform: translateX(-3px) rotate(-2deg); }
    50% { transform: translateX(2px) rotate(1deg); }
    60% { transform: translateX(-2px) rotate(-1deg); }
    70% { transform: translateX(2px) rotate(1deg); }
    80% { transform: translateX(-2px) rotate(-1deg); }
    90% { transform: translateX(1px) rotate(0); }
    100% { transform: translateX(-1px) rotate(0); }
}
.ewpda-hover-buzz-out:hover,
.ewpda-hover-buzz-out:focus,
.ewpda-hover-buzz-out:active {
    animation: ewpda-buzz-out 0.75s linear 1;
}

/* Forward */
.ewpda-hover-forward:hover,
.ewpda-hover-forward:focus,
.ewpda-hover-forward:active {
    transform: translateX(8px);
}

/* Backward */
.ewpda-hover-backward:hover,
.ewpda-hover-backward:focus,
.ewpda-hover-backward:active {
    transform: translateX(-8px);
}

/* ==========================================================================
   Background Transitions
   ========================================================================== */

/* Fade */
.ewpda-hover-fade {
    overflow: hidden;
    position: relative;
}
.ewpda-hover-fade::before {
    content: "";
    position: absolute;
    z-index: -1;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.1);
    opacity: 0;
    transition: opacity var(--ewpda-hover-duration) ease;
    transition-delay: var(--ewpda-hover-delay);
}
.ewpda-hover-fade:hover::before,
.ewpda-hover-fade:focus::before,
.ewpda-hover-fade:active::before {
    opacity: 1;
}

/* Back Pulse */
@keyframes ewpda-back-pulse {
    50% { background-color: rgba(0, 0, 0, 0.1); }
}
.ewpda-hover-back-pulse:hover,
.ewpda-hover-back-pulse:focus,
.ewpda-hover-back-pulse:active {
    animation: ewpda-back-pulse 1s linear infinite;
}

/* Sweep To Right */
.ewpda-hover-sweep-to-right {
    overflow: hidden;
    position: relative;
}
.ewpda-hover-sweep-to-right::before {
    content: "";
    position: absolute;
    z-index: -1;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.1);
    transform: scaleX(0);
    transform-origin: 0 50%;
    transition: transform var(--ewpda-hover-duration) ease-out;
    transition-delay: var(--ewpda-hover-delay);
}
.ewpda-hover-sweep-to-right:hover::before,
.ewpda-hover-sweep-to-right:focus::before,
.ewpda-hover-sweep-to-right:active::before {
    transform: scaleX(1);
}

/* Sweep To Left */
.ewpda-hover-sweep-to-left {
    overflow: hidden;
    position: relative;
}
.ewpda-hover-sweep-to-left::before {
    content: "";
    position: absolute;
    z-index: -1;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.1);
    transform: scaleX(0);
    transform-origin: 100% 50%;
    transition: transform var(--ewpda-hover-duration) ease-out;
    transition-delay: var(--ewpda-hover-delay);
}
.ewpda-hover-sweep-to-left:hover::before,
.ewpda-hover-sweep-to-left:focus::before,
.ewpda-hover-sweep-to-left:active::before {
    transform: scaleX(1);
}

/* Sweep To Bottom */
.ewpda-hover-sweep-to-bottom {
    overflow: hidden;
    position: relative;
}
.ewpda-hover-sweep-to-bottom::before {
    content: "";
    position: absolute;
    z-index: -1;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.1);
    transform: scaleY(0);
    transform-origin: 50% 0;
    transition: transform var(--ewpda-hover-duration) ease-out;
    transition-delay: var(--ewpda-hover-delay);
}
.ewpda-hover-sweep-to-bottom:hover::before,
.ewpda-hover-sweep-to-bottom:focus::before,
.ewpda-hover-sweep-to-bottom:active::before {
    transform: scaleY(1);
}

/* Sweep To Top */
.ewpda-hover-sweep-to-top {
    overflow: hidden;
    position: relative;
}
.ewpda-hover-sweep-to-top::before {
    content: "";
    position: absolute;
    z-index: -1;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.1);
    transform: scaleY(0);
    transform-origin: 50% 100%;
    transition: transform var(--ewpda-hover-duration) ease-out;
    transition-delay: var(--ewpda-hover-delay);
}
.ewpda-hover-sweep-to-top:hover::before,
.ewpda-hover-sweep-to-top:focus::before,
.ewpda-hover-sweep-to-top:active::before {
    transform: scaleY(1);
}

/* Bounce To Right */
.ewpda-hover-bounce-to-right {
    overflow: hidden;
    position: relative;
}
.ewpda-hover-bounce-to-right::before {
    content: "";
    position: absolute;
    z-index: -1;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.1);
    transform: scaleX(0);
    transform-origin: 0 50%;
    transition: transform 0.5s cubic-bezier(0.52, 1.64, 0.37, 0.66);
    transition-delay: var(--ewpda-hover-delay);
}
.ewpda-hover-bounce-to-right:hover::before,
.ewpda-hover-bounce-to-right:focus::before,
.ewpda-hover-bounce-to-right:active::before {
    transform: scaleX(1);
}

/* Bounce To Left */
.ewpda-hover-bounce-to-left {
    overflow: hidden;
    position: relative;
}
.ewpda-hover-bounce-to-left::before {
    content: "";
    position: absolute;
    z-index: -1;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.1);
    transform: scaleX(0);
    transform-origin: 100% 50%;
    transition: transform 0.5s cubic-bezier(0.52, 1.64, 0.37, 0.66);
    transition-delay: var(--ewpda-hover-delay);
}
.ewpda-hover-bounce-to-left:hover::before,
.ewpda-hover-bounce-to-left:focus::before,
.ewpda-hover-bounce-to-left:active::before {
    transform: scaleX(1);
}

/* Bounce To Bottom */
.ewpda-hover-bounce-to-bottom {
    overflow: hidden;
    position: relative;
}
.ewpda-hover-bounce-to-bottom::before {
    content: "";
    position: absolute;
    z-index: -1;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.1);
    transform: scaleY(0);
    transform-origin: 50% 0;
    transition: transform 0.5s cubic-bezier(0.52, 1.64, 0.37, 0.66);
    transition-delay: var(--ewpda-hover-delay);
}
.ewpda-hover-bounce-to-bottom:hover::before,
.ewpda-hover-bounce-to-bottom:focus::before,
.ewpda-hover-bounce-to-bottom:active::before {
    transform: scaleY(1);
}

/* Bounce To Top */
.ewpda-hover-bounce-to-top {
    overflow: hidden;
    position: relative;
}
.ewpda-hover-bounce-to-top::before {
    content: "";
    position: absolute;
    z-index: -1;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.1);
    transform: scaleY(0);
    transform-origin: 50% 100%;
    transition: transform 0.5s cubic-bezier(0.52, 1.64, 0.37, 0.66);
    transition-delay: var(--ewpda-hover-delay);
}
.ewpda-hover-bounce-to-top:hover::before,
.ewpda-hover-bounce-to-top:focus::before,
.ewpda-hover-bounce-to-top:active::before {
    transform: scaleY(1);
}

/* Radial Out */
.ewpda-hover-radial-out {
    overflow: hidden;
    position: relative;
}
.ewpda-hover-radial-out::before {
    content: "";
    position: absolute;
    z-index: -1;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.1);
    border-radius: 100%;
    transform: scale(0);
    transition: transform var(--ewpda-hover-duration) ease-out;
    transition-delay: var(--ewpda-hover-delay);
}
.ewpda-hover-radial-out:hover::before,
.ewpda-hover-radial-out:focus::before,
.ewpda-hover-radial-out:active::before {
    transform: scale(2);
}

/* Radial In */
.ewpda-hover-radial-in {
    overflow: hidden;
    position: relative;
}
.ewpda-hover-radial-in::before {
    content: "";
    position: absolute;
    z-index: -1;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.1);
    border-radius: 100%;
    transform: scale(2);
    transition: transform var(--ewpda-hover-duration) ease-out;
    transition-delay: var(--ewpda-hover-delay);
}
.ewpda-hover-radial-in:hover::before,
.ewpda-hover-radial-in:focus::before,
.ewpda-hover-radial-in:active::before {
    transform: scale(0);
}

/* Rectangle In */
.ewpda-hover-rectangle-in {
    overflow: hidden;
    position: relative;
}
.ewpda-hover-rectangle-in::before {
    content: "";
    position: absolute;
    z-index: -1;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.1);
    transform: scale(1);
    transition: transform var(--ewpda-hover-duration) ease-out;
    transition-delay: var(--ewpda-hover-delay);
}
.ewpda-hover-rectangle-in:hover::before,
.ewpda-hover-rectangle-in:focus::before,
.ewpda-hover-rectangle-in:active::before {
    transform: scale(0);
}

/* Rectangle Out */
.ewpda-hover-rectangle-out {
    overflow: hidden;
    position: relative;
}
.ewpda-hover-rectangle-out::before {
    content: "";
    position: absolute;
    z-index: -1;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.1);
    transform: scale(0);
    transition: transform var(--ewpda-hover-duration) ease-out;
    transition-delay: var(--ewpda-hover-delay);
}
.ewpda-hover-rectangle-out:hover::before,
.ewpda-hover-rectangle-out:focus::before,
.ewpda-hover-rectangle-out:active::before {
    transform: scale(1);
}

/* Shutter In Horizontal */
.ewpda-hover-shutter-in-horizontal {
    overflow: hidden;
    position: relative;
}
.ewpda-hover-shutter-in-horizontal::before {
    content: "";
    position: absolute;
    z-index: -1;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    background: rgba(0, 0, 0, 0.1);
    transform: scaleX(1);
    transform-origin: 50%;
    transition: transform var(--ewpda-hover-duration) ease-out;
    transition-delay: var(--ewpda-hover-delay);
}
.ewpda-hover-shutter-in-horizontal:hover::before,
.ewpda-hover-shutter-in-horizontal:focus::before,
.ewpda-hover-shutter-in-horizontal:active::before {
    transform: scaleX(0);
}

/* Shutter Out Horizontal */
.ewpda-hover-shutter-out-horizontal {
    overflow: hidden;
    position: relative;
}
.ewpda-hover-shutter-out-horizontal::before {
    content: "";
    position: absolute;
    z-index: -1;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    background: rgba(0, 0, 0, 0.1);
    transform: scaleX(0);
    transform-origin: 50%;
    transition: transform var(--ewpda-hover-duration) ease-out;
    transition-delay: var(--ewpda-hover-delay);
}
.ewpda-hover-shutter-out-horizontal:hover::before,
.ewpda-hover-shutter-out-horizontal:focus::before,
.ewpda-hover-shutter-out-horizontal:active::before {
    transform: scaleX(1);
}

/* Shutter In Vertical */
.ewpda-hover-shutter-in-vertical {
    overflow: hidden;
    position: relative;
}
.ewpda-hover-shutter-in-vertical::before {
    content: "";
    position: absolute;
    z-index: -1;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    background: rgba(0, 0, 0, 0.1);
    transform: scaleY(1);
    transform-origin: 50%;
    transition: transform var(--ewpda-hover-duration) ease-out;
    transition-delay: var(--ewpda-hover-delay);
}
.ewpda-hover-shutter-in-vertical:hover::before,
.ewpda-hover-shutter-in-vertical:focus::before,
.ewpda-hover-shutter-in-vertical:active::before {
    transform: scaleY(0);
}

/* Shutter Out Vertical */
.ewpda-hover-shutter-out-vertical {
    overflow: hidden;
    position: relative;
}
.ewpda-hover-shutter-out-vertical::before {
    content: "";
    position: absolute;
    z-index: -1;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    background: rgba(0, 0, 0, 0.1);
    transform: scaleY(0);
    transform-origin: 50%;
    transition: transform var(--ewpda-hover-duration) ease-out;
    transition-delay: var(--ewpda-hover-delay);
}
.ewpda-hover-shutter-out-vertical:hover::before,
.ewpda-hover-shutter-out-vertical:focus::before,
.ewpda-hover-shutter-out-vertical:active::before {
    transform: scaleY(1);
}