*{
    margin: 0;
    padding: 0;
}
body {
    padding-right: 0 !important;
    top: 0 !important;
}
main {
    width: 100%;
    font-size: 1.2em;
    line-height: 1.168;
    position: relative;
    min-height: 100vh; /* Note this */
}
.wide {
    transform: scale(1, 1);
    transition: ease .5s;
    /* filter: brightness(90%); */
}
.wide:hover {
    transform: scale(1.02, 1.02);
    transition: ease .5s;
    overflow: hidden;
    filter: brightness(120%);
}
.contenedor:hover .wide {
    -webkit-transform: scale(1.1);
    transform: scale(1.1);
}
.contenedor {
    overflow: hidden;
}
.wallpeaper-lfc {
    background-image: url('../img/wallpeaper-login.png');
}
.notify-lfc{
    animation: notify 5s;
    -webkit-animation: notify 5s;
    animation-iteration-count:infinite;
    -webkit-animation-iteration-count:infinite;
}
.mov-sal-enc { 
    position: sticky;
    top: 0;
    z-index: 10;
}

.effect_desc {

    animation-iteration-count:1;
    -webkit-animation-iteration-count:1;

    animation: desc 1s;
    -webkit-animation: desc 1s;
    
}

@keyframes desc{ 
    0% {
        opacity: 0;
        transform: translate(0,-100px);
        -webkit-transform: translate(0,-100px);
        -o-transform: translate(0,-100px); 
        -moz-transform: translate(0,-100px);
   
    }

    100% {
        opacity: 1;
        transform: translate(0,0px);
        -webkit-transform: translate(0,0px);
        -o-transform: translate(0,0px); 
        -moz-transform: translate(0,0px);
    }
}

.effect {

    animation-iteration-count:1;
    -webkit-animation-iteration-count:1;

    animation: asc 1s;
    -webkit-animation: asc 1s;
    
}

@keyframes asc{ 
    0% {
        opacity: 0;
        transform: translate(0,350px);
        -webkit-transform: translate(0,350px);
        -o-transform: translate(0,350px); 
        -moz-transform: translate(0,350px);
   
    }

    100% {
        opacity: 1;
        transform: translate(0,0px);
        -webkit-transform: translate(0,0px);
        -o-transform: translate(0,0px); 
        -moz-transform: translate(0,0px);
    }
}

.effect_profile {
    animation-iteration-count:1;
    -webkit-animation-iteration-count:1;

    animation: asc_profile 0.5s;
    -webkit-animation: asc_profile 0.5s;
    
} 

@keyframes asc_profile{ 

    0% {
        opacity: 0;
        transform: translate(0,50px);
        -webkit-transform: translate(0,50px);
        -o-transform: translate(0,50px); 
        -moz-transform: translate(0,50px);
   
    }

    100% {
        opacity: 1;
        transform: translate(0,0px);
        -webkit-transform: translate(0,0px);
        -o-transform: translate(0,0px); 
        -moz-transform: translate(0,0px);
    }
}

.effect_sidebar_left {
    animation-iteration-count:1;
    -webkit-animation-iteration-count:1;

    animation: lat_effect_sidebar_left 0.5s;
    -webkit-animation: lat_effect_sidebar_left 0.5s;
    
}

.effect_noty_left {
    animation-iteration-count:1;
    -webkit-animation-iteration-count:1;

    animation: lat_effect_noty_left 2s;
    -webkit-animation: lat_effect_noty_left 2s;
    
}

@keyframes lat_effect_noty_left{ 
    0% {
        opacity: 0;
        transform: translate(-500px,0);
        -webkit-transform: translate(-500px,0);
        -o-transform: translate(-500px,0); 
        -moz-transform: translate(-500px,0);
   
    }

    100% {
        opacity: 1;
        transform: translate(0,0px);
        -webkit-transform: translate(0,0px);
        -o-transform: translate(0,0px); 
        -moz-transform: translate(0,0px);
    }
}


@keyframes lat_effect_sidebar_left{ 
    0% {
        opacity: 0;
        transform: translate(-50px,0);
        -webkit-transform: translate(-50px,0);
        -o-transform: translate(-50px,0); 
        -moz-transform: translate(-50px,0);
   
    }

    100% {
        opacity: 1;
        transform: translate(0,0px);
        -webkit-transform: translate(0,0px);
        -o-transform: translate(0,0px); 
        -moz-transform: translate(0,0px);
    }
}


@keyframes notify{

    0% {
        
        transform: scale(1,1);
        transition: ease 1s;
        filter: drop-shadow(0 2px 5px #FFFF00);
    }
    25% {
        transform: scale(1.1,1.1);
        transition: ease 1s;
        filter: drop-shadow(0 5px 10px #FFFF00);
    }
    50% {
        transform: scale(1,1);
        transition: ease 1s;
        filter: drop-shadow(0 2px 5px #FFFF00);
    }
    100% {
        transform: scale(1.1,1.1);
        transition: ease 1s;
        filter: drop-shadow(0 5px 10px #FFFF00);
    }
    
}

.puff{
    animation: FadeInMod 1s ease;
}

.puff:active{
    animation: FadeInMod2 2s ease;
    animation-duration: infinite;
}

@keyframes FadeInMod{
    0% { opacity: 0; filter: blur(20px) }
    10% { opacity: 1; filter: brightness(2) blur(10px) }
}

@keyframes FadeInMod2{
    0% { opacity: 0; filter: blur(20px) }
    10% { opacity: 1; filter: brightness(2) blur(10px) }
}


.wave {
    margin-bottom: 0px;
    fill: #ffffff;
    -webkit-animation: wave 5s linear;
    animation: wave 5s linear;
    -webkit-animation-iteration-count: infinite;
    animation-iteration-count: infinite;
}

html.dark body div svg .wave {
    --tw-bg-opacity: 1;
    fill: rgb(17 24 39 / var(--tw-bg-opacity));
}

.wave-black {
    fill: rgb(17 24 39);
    -webkit-animation: wave 5s linear;
    animation: wave 5s linear;
    -webkit-animation-iteration-count: infinite;
    animation-iteration-count: infinite;
}

#wave2 {
    animation-direction: reverse;
    -webkit-animation-duration: 8s;
    animation-duration: 8s;
    opacity: .6
}

#wave3 {
    -webkit-animation-duration: 10s;
    animation-duration: 10s;
    opacity: .3
}

@-webkit-keyframes wave {
    to {
        transform: translateX(-100%)
    }
}

@keyframes wave {
    to {
        transform: translateX(-100%)
    }
}

.maximized-card {
    height: 100% !important;
    left: 0;
    max-height: 100% !important;
    max-width: 100% !important;
    position: fixed;
    top: 0;
    width: 100% !important;
    z-index: 1040;
}


/*effect reg*/
.tarjeta{
    /*box-shadow: 16px 14px 20px #0000008c;*/
    position: relative;
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
}

.tarjeta::before{
    content: "";
    position: absolute;
    height: 800px;
    width: 800px;
    background-image: conic-gradient(rgb(225, 243, 125) 20deg, transparent 120deg);
    animation: rotar 15s linear infinite;
}

html.dark .tarjeta::before {
    background-image: conic-gradient(rgb(102, 102, 104) 20deg, transparent 120deg);
}

@keyframes rotar{
    from{
        transform: rotate(0deg);
    }
    to{
        transform: rotate(-360deg);
    }
}

/*.tarjeta::after{
    content: "";
    position: absolute;
    box-shadow: inset 16px 14px 20px #0000008c;
    border-radius: 10%;
}*/


/*Theme toggle effect - using view transitions api*/
/* circle */

::view-transition-group(root) { 
  animation-timing-function: var(--expo-out); 
}
::view-transition-old(root), .dark::view-transition-old(root) { 
  animation: none; 
  animation-fill-mode: both;
  z-index: -1; 
}
::view-transition-new(root) {
  mask: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 40 40"><circle cx="20" cy="20" r="20" fill="white"/></svg>') center / 0 no-repeat;
  animation: scale 1s;
  animation-fill-mode: both;
}
@keyframes scale { 
  to { 
    mask-size: 200vmax; 
  } 
}
    

/* circle-with-blur */

::view-transition-group(root) {
  animation-timing-function: var(--expo-out);
}
::view-transition-new(root) {
  mask: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 40 40"><defs><filter id="blur"><feGaussianBlur stdDeviation="2"/></filter></defs><circle cx="20" cy="20" r="18" fill="white" filter="url(%23blur)"/></svg>') center / 0 no-repeat;
  animation: scale 1s;
  animation-fill-mode: both;
}
::view-transition-old(root),
.dark::view-transition-old(root) {
  animation: none;
  animation-fill-mode: both;
  z-index: -1;
}
.dark::view-transition-new(root) {
  animation: scale 1s;
  animation-fill-mode: both;
}
@keyframes scale {
  to {
    mask-size: 200vmax;
  }
}
    

/* circle-blur-top-left */

::view-transition-group(root) {
  animation-timing-function: var(--expo-out);
}
::view-transition-new(root) {
  mask: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 40 40"><defs><filter id="blur"><feGaussianBlur stdDeviation="2"/></filter></defs><circle cx="0" cy="0" r="18" fill="white" filter="url(%23blur)"/></svg>') top left / 0 no-repeat;
  mask-origin: content-box;
  animation: scale 1s;
  animation-fill-mode: both;
  transform-origin: top left;
}
::view-transition-old(root),
.dark::view-transition-old(root) {
  animation: scale 1s;
  animation-fill-mode: both;
  transform-origin: top left;
  z-index: -1;
}
@keyframes scale {
  to {
    mask-size: 350vmax;
  }
}
    

/* polygon */

::view-transition-group(root) {
  animation-duration: 0.7s;
  animation-timing-function: var(--expo-out);
}
::view-transition-new(root) {
  animation-name: reveal-light;
  animation-fill-mode: both;
}
::view-transition-old(root),
.dark::view-transition-old(root) {
  animation: none;
  animation-fill-mode: both;
  z-index: -1;
}
.dark::view-transition-new(root) {
  animation-name: reveal-dark;
  animation-fill-mode: both;
}
@keyframes reveal-dark {
  from {
    clip-path: polygon(50% -71%, -50% 71%, -50% 71%, 50% -71%);
  }
  to {
    clip-path: polygon(50% -71%, -50% 71%, 50% 171%, 171% 50%);
  }
}
@keyframes reveal-light {
  from {
    clip-path: polygon(171% 50%, 50% 171%, 50% 171%, 171% 50%);
  }
  to {
    clip-path: polygon(171% 50%, 50% 171%, -50% 71%, 50% -71%);
  }
}
    

/* polygon-gradient */

::view-transition-group(root) {
  animation-timing-function: var(--expo-out);
}
::view-transition-new(root) {
  mask: url('assets/custom-svg.svg') top left / 0 no-repeat;
  mask-origin: top left;
  animation: scale 1.5s;
  animation-fill-mode: both;
}
::view-transition-old(root),
.dark::view-transition-old(root) {
  animation: scale 1.5s;
  animation-fill-mode: both;
  z-index: -1;
  transform-origin: top left;
}
@keyframes scale {
  to {
    mask-size: 200vmax;
  }
}
    

/* gif-1 */

::view-transition-group(root) {
  animation-timing-function: var(--expo-in);
}
::view-transition-new(root) {
  mask: url('https://media.tenor.com/cyORI7kwShQAAAAi/shigure-ui-dance.gif') center / 0 no-repeat;
  animation: scale 3s;
  animation-fill-mode: both;
}
::view-transition-old(root),
.dark::view-transition-old(root) {
  animation: scale 3s;
  animation-fill-mode: both;
}
@keyframes scale {
  0% {
    mask-size: 0;
  }
  10% {
    mask-size: 50vmax;
  }
  90% {
    mask-size: 50vmax;
  }
  100% {
    mask-size: 2000vmax;
  }
}
    

/* gif-2 */

::view-transition-group(root) {
  animation-timing-function: var(--expo-in);
}
::view-transition-new(root) {
  mask: url('https://media.tenor.com/Jz0aSpk9VIQAAAAi/i-love-you-love.gif') center / 0 no-repeat;
  animation: scale 2s;
  animation-fill-mode: both;
}
::view-transition-old(root),
.dark::view-transition-old(root) {
  animation: scale 2s;
  animation-fill-mode: both;
}
@keyframes scale {
  0% {
    mask-size: 0;
  }
  10% {
    mask-size: 50vmax;
  }
  90% {
    mask-size: 50vmax;
  }
  100% {
    mask-size: 2000vmax;
  }
}

/* animation timing functions */
:root {
  --expo-in: linear(
    0 0%, 0.0085 31.26%, 0.0167 40.94%,
    0.0289 48.86%, 0.0471 55.92%,
    0.0717 61.99%, 0.1038 67.32%,
    0.1443 72.07%, 0.1989 76.7%,
    0.2659 80.89%, 0.3465 84.71%,
    0.4419 88.22%, 0.554 91.48%,
    0.6835 94.51%, 0.8316 97.34%, 1 100%
  );
  --expo-out: linear(
    0 0%, 0.1684 2.66%, 0.3165 5.49%,
    0.446 8.52%, 0.5581 11.78%,
    0.6535 15.29%, 0.7341 19.11%,
    0.8011 23.3%, 0.8557 27.93%,
    0.8962 32.68%, 0.9283 38.01%,
    0.9529 44.08%, 0.9711 51.14%,
    0.9833 59.06%, 0.9915 68.74%, 1 100%
  );
}


