﻿/* Global reset */
* {
    box-sizing: border-box;
}
.close-modal {
    position: absolute;
    top: 10px;
    right: 15px;
    background: #E3E829;
    border: none;
    font-size: 1.5rem;
    cursor: pointer;
    color: #2d6df5;
    opacity: 0;
    transition: all .8s;
    z-index: 9999;
}


/* Modal container base */
#modal-container {
    position: fixed;
    display: table;
    height: 100%;
    width: 100%;
    top: 0;
    left: 0;
    transform: scale(0);
    z-index: 20;
}

/* Modal background & modal box */
.modal-background {
    display: table-cell;
    background: rgba(0, 0, 0, 0.8);
    text-align: center;
    vertical-align: middle;
}

    .modal-background .modal {
        background: white;
        padding: 30px 20px;
        display: inline-block;
        border-radius: 8px;
        font-weight: 300;
        position: relative;
        width: 90%;
        max-width: 600px;
        height: auto;
        max-height: 90vh;
        overflow-y: auto;
        box-sizing: border-box;
    }



        .modal-background .modal h2 {
            font-size: 25px;
            line-height: 25px;
            margin-bottom: 15px;
        }

        .modal-background .modal p {
            font-size: 18px;
            line-height: 22px;
        }

        .modal-background .modal .modal-svg {
            position: absolute;
            top: 0;
            left: 0;
            height: 100%;
            width: 10%;
            border-radius: 3px;
        }

            .modal-background .modal .modal-svg rect {
                stroke: #fff;
                stroke-width: 2px;
                stroke-dasharray: 778;
                stroke-dashoffset: 778;
            }

/* Content area */
.content {
    min-height: 100%;
    height: 100%;
    background: white;
    position: relative;
    z-index: 0;
}

    .content h1 {
        padding: 75px 0 30px 0;
        text-align: center;
        font-size: 30px;
        line-height: 30px;
    }

    .content .buttons {
        max-width: 800px;
        margin: 0 auto;
        padding: 0;
        text-align: center;
    }

        .content .buttons .button {
            display: inline-block;
            text-align: center;
            padding: 10px 15px;
            margin: 10px;
            background-color: #efefef;
            font-size: 18px;
            border-radius: 3px;
            box-shadow: 0 1px 2px rgba(0, 0, 0, 0.3);
            cursor: pointer;
        }

            .content .buttons .button:hover {
                color: white;
                background: #009bd5;
            }

/* Modal variations */

/* 1: Unfold/zoom */
#modal-container.one {
    transform: scaleY(0.01) scaleX(0);
    animation: unfoldIn 1s cubic-bezier(0.165, 0.84, 0.44, 1) forwards;
}

    #modal-container.one .modal-background .modal {
        transform: scale(0);
        animation: zoomIn 0.5s 0.8s cubic-bezier(0.165, 0.84, 0.44, 1) forwards;
    }

    #modal-container.one.out {
        transform: scale(1);
        animation: unfoldOut 1s 0.3s cubic-bezier(0.165, 0.84, 0.44, 1) forwards;
    }

        #modal-container.one.out .modal-background .modal {
            animation: zoomOut 0.5s cubic-bezier(0.165, 0.84, 0.44, 1) forwards;
        }

/* 2: Fade & scale page content */
#modal-container.two {
    transform: scale(1);
}

    #modal-container.two .modal-background {
        background: rgba(0, 0, 0, 0);
        animation: fadeIn 0.5s cubic-bezier(0.165, 0.84, 0.44, 1) forwards;
    }

        #modal-container.two .modal-background .modal {
            opacity: 0;
            animation: scaleUp 0.5s cubic-bezier(0.165, 0.84, 0.44, 1) forwards;
        }

    #modal-container.two + .content {
        animation: scaleBack 0.5s cubic-bezier(0.165, 0.84, 0.44, 1) forwards;
    }

    #modal-container.two.out {
        animation: quickScaleDown 0s 0.5s linear forwards;
    }

        #modal-container.two.out .modal-background {
            animation: fadeOut 0.5s cubic-bezier(0.165, 0.84, 0.44, 1) forwards;
        }

            #modal-container.two.out .modal-background .modal {
                animation: scaleDown 0.5s cubic-bezier(0.165, 0.84, 0.44, 1) forwards;
            }

        #modal-container.two.out + .content {
            animation: scaleForward 0.5s cubic-bezier(0.165, 0.84, 0.44, 1) forwards;
        }

/* 3: Slide up large */
#modal-container.three {
    z-index: 0;
    transform: scale(1);
}

    #modal-container.three .modal-background {
        background: rgba(0, 0, 0, 0.6);
    }

        #modal-container.three .modal-background .modal {
            animation: moveUp 0.5s cubic-bezier(0.165, 0.84, 0.44, 1) forwards;
        }

    #modal-container.three + .content {
        z-index: 1;
        animation: slideUpLarge 0.5s cubic-bezier(0.165, 0.84, 0.44, 1) forwards;
    }

    #modal-container.three.out .modal-background .modal {
        animation: moveDown 0.5s cubic-bezier(0.165, 0.84, 0.44, 1) forwards;
    }

    #modal-container.three.out + .content {
        animation: slideDownLarge 0.5s cubic-bezier(0.165, 0.84, 0.44, 1) forwards;
    }

/* 4: Blow up */
#modal-container.four {
    z-index: 9999;
    transform: scale(1);
}

    #modal-container.four .modal-background {
        background: rgba(0, 0, 0, 0.7);
    }

        #modal-container.four .modal-background .modal {
            animation: blowUpModal 0.5s cubic-bezier(0.165, 0.84, 0.44, 1) forwards;
        }

    #modal-container.four + .content {
        z-index: 1;
        animation: blowUpContent 0.5s cubic-bezier(0.165, 0.84, 0.44, 1) forwards;
    }

    #modal-container.four.out .modal-background .modal {
        animation: blowUpModalTwo 0.5s cubic-bezier(0.165, 0.84, 0.44, 1) forwards;
    }

    #modal-container.four.out + .content {
        animation: blowUpContentTwo 0.5s cubic-bezier(0.165, 0.84, 0.44, 1) forwards;
    }

/* 5: Road runner in/out */
#modal-container.five {
    transform: scale(1);
}

    #modal-container.five .modal-background {
        background: rgba(0, 0, 0, 0);
        animation: fadeIn 0.5s cubic-bezier(0.165, 0.84, 0.44, 1) forwards;
    }

        #modal-container.five .modal-background .modal {
            transform: translateX(-1500px);
            animation: roadRunnerIn 0.3s cubic-bezier(0.165, 0.84, 0.44, 1) forwards;
        }

    #modal-container.five.out {
        animation: quickScaleDown 0s 0.5s linear forwards;
    }

        #modal-container.five.out .modal-background {
            animation: fadeOut 0.5s cubic-bezier(0.165, 0.84, 0.44, 1) forwards;
        }

            #modal-container.five.out .modal-background .modal {
                animation: roadRunnerOut 0.5s cubic-bezier(0.165, 0.84, 0.44, 1) forwards;
            }

/* 6: Fade with SVG sketch */
#modal-container.six {
    transform: scale(1);
}

    #modal-container.six .modal-background {
        background: rgba(0, 0, 0, 0);
        animation: fadeIn 0.5s cubic-bezier(0.165, 0.84, 0.44, 1) forwards;
    }

        #modal-container.six .modal-background .modal {
            background-color: transparent;
            animation: modalFadeIn 0.5s 0.8s cubic-bezier(0.165, 0.84, 0.44, 1) forwards;
        }

            #modal-container.six .modal-background .modal h2,
            #modal-container.six .modal-background .modal p
            #modal-container.six .modal-background .modal button {
                opacity: 0;
                position: relative;
                animation: modalContentFadeIn 0.5s 1s cubic-bezier(0.165, 0.84, 0.44, 1) forwards;
            }

            #modal-container.six .modal-background .modal .modal-svg rect {
                animation: sketchIn 0.5s 0.3s cubic-bezier(0.165, 0.84, 0.44, 1) forwards;
            }

    #modal-container.six.out {
        animation: quickScaleDown 0s 0.5s linear forwards;
    }

        #modal-container.six.out .modal-background {
            animation: fadeOut 0.5s cubic-bezier(0.165, 0.84, 0.44, 1) forwards;
        }

            #modal-container.six.out .modal-background .modal {
                animation: modalFadeOut 0.5s cubic-bezier(0.165, 0.84, 0.44, 1) forwards;
            }

                #modal-container.six.out .modal-background .modal h2,
                #modal-container.six.out .modal-background .modal p {
                    animation: modalContentFadeOut 0.5s cubic-bezier(0.165, 0.84, 0.44, 1) forwards;
                }

                #modal-container.six.out .modal-background .modal .modal-svg rect {
                    animation: sketchOut 0.5s cubic-bezier(0.165, 0.84, 0.44, 1) forwards;
                }

#modal-container.seven {
    transform: scale(1);
}

    /* Fondo animado */
    #modal-container.seven .modal-background {
        background: rgba(0,0,0,0);
        animation: fadeIn 0.5s cubic-bezier(0.165,0.84,0.44,1) forwards;
    }

        /* Círculo con “X” */
        #modal-container.seven .modal-background .modal {
            position: absolute;
            top: 50%;
            left: 50%;
            transform: translate(-50%,-50%) scale(0);
            width: 75px;
            height: 75px;
            border-radius: 50%;
            overflow: hidden;
            animation: circleIn 0.5s ease-out forwards, morphModal 1s ease-in-out 0.5s   forwards;
        }

            /* “X” dibujada */
            #modal-container.seven .modal-background .modal::before,
            #modal-container.seven .modal-background .modal::after {
                content: "";
                position: absolute;
                top: 50%;
                left: 50%;
                width: 60%;
                height: 4px;
                background: red;
                transform-origin: center;
                animation: xFadeOut 0.5s linear 0.5s forwards;
            }

            #modal-container.seven .modal-background .modal::before {
                transform: translate(-50%,-50%) rotate(45deg);
            }

            #modal-container.seven .modal-background .modal::after {
                transform: translate(-50%,-50%) rotate(-45deg);
            }

            /* Contenido espera a morph */
            #modal-container.seven .modal-background .modal h2,
            #modal-container.seven .modal-background .modal p
            #modal-container.seven .modal-background .modal button {
                opacity: 0;
                animation: modalContentFadeIn 0.5s linear 1s forwards;
            }



    #modal-container.seven.out {
        transform: scale(1);
        animation: unfoldOut 1s 0.3s cubic-bezier(0.165, 0.84, 0.44, 1) forwards;
    }

        #modal-container.seven.out .modal-background .modal {
            animation: zoomOut 1.5s cubic-bezier(0.165, 0.84, 0.44, 1) forwards;
        }
/* Keyframes */
@keyframes unfoldIn {
    0% {
        transform: scaleY(0.005) scaleX(0);
    }

    50% {
        transform: scaleY(0.005) scaleX(1);
    }

    100% {
        transform: scaleY(1) scaleX(1);
    }
}

@keyframes unfoldOut {
    0% {
        transform: scaleY(1) scaleX(1);
    }

    50% {
        transform: scaleY(0.005) scaleX(1);
    }

    100% {
        transform: scaleY(0.005) scaleX(0);
    }
}

@keyframes zoomIn {
    0% {
        transform: scale(0);
    }

    100% {
        transform: scale(1);
    }
}

@keyframes zoomOut {
    0% {
        transform: scale(1);
    }

    100% {
        transform: scale(0);
    }
}

@keyframes fadeIn {
    0% {
        background: rgba(0, 0, 0, 0);
    }

    100% {
        background: rgba(0, 0, 0, 0.7);
    }
}

@keyframes fadeOut {
    0% {
        background: rgba(0, 0, 0, 0.7);
    }

    100% {
        background: rgba(0, 0, 0, 0);
    }
}

@keyframes scaleUp {
    0% {
        transform: scale(0.8) translateY(1000px);
        opacity: 0;
    }

    100% {
        transform: scale(1) translateY(0);
        opacity: 1;
    }
}

@keyframes scaleDown {
    0% {
        transform: scale(1) translateY(0);
        opacity: 1;
    }

    100% {
        transform: scale(0.8) translateY(1000px);
        opacity: 0;
    }
}

@keyframes scaleBack {
    0% {
        transform: scale(1);
    }

    100% {
        transform: scale(0.85);
    }
}

@keyframes scaleForward {
    0% {
        transform: scale(0.85);
    }

    100% {
        transform: scale(1);
    }
}

@keyframes quickScaleDown {
    0% {
        transform: scale(1);
    }

    99.9% {
        transform: scale(1);
    }

    100% {
        transform: scale(0);
    }
}

@keyframes slideUpLarge {
    0% {
        transform: translateY(0%);
    }

    100% {
        transform: translateY(-100%);
    }
}

@keyframes slideDownLarge {
    0% {
        transform: translateY(-100%);
    }

    100% {
        transform: translateY(0%);
    }
}

@keyframes moveUp {
    0% {
        transform: translateY(150px);
    }

    100% {
        transform: translateY(0);
    }
}

@keyframes moveDown {
    0% {
        transform: translateY(0);
    }

    100% {
        transform: translateY(150px);
    }
}

@keyframes blowUpContent {
    0% {
        transform: scale(1);
        opacity: 1;
    }

    99.9% {
        transform: scale(2);
        opacity: 0;
    }

    100% {
        transform: scale(0);
    }
}

@keyframes blowUpContentTwo {
    0% {
        transform: scale(2);
        opacity: 0;
    }

    100% {
        transform: scale(1);
        opacity: 1;
    }
}

@keyframes blowUpModal {
    0% {
        transform: scale(0);
    }

    100% {
        transform: scale(1);
    }
}

@keyframes blowUpModalTwo {
    0% {
        transform: scale(1);
        opacity: 1;
    }

    100% {
        transform: scale(0);
        opacity: 0;
    }
}

@keyframes roadRunnerIn {
    0% {
        transform: translateX(-1500px) skewX(30deg) scaleX(1.3);
    }

    70% {
        transform: translateX(30px) skewX(0deg) scaleX(0.9);
    }

    100% {
        transform: translateX(0) skewX(0deg) scaleX(1);
    }
}

@keyframes roadRunnerOut {
    0% {
        transform: translateX(0) skewX(0deg) scaleX(1);
    }

    30% {
        transform: translateX(-30px) skewX(-5deg) scaleX(0.9);
    }

    100% {
        transform: translateX(1500px) skewX(30deg) scaleX(1.3);
    }
}

@keyframes sketchIn {
    0% {
        stroke-dashoffset: 778;
    }

    100% {
        stroke-dashoffset: 0;
    }
}

@keyframes sketchOut {
    0% {
        stroke-dashoffset: 0;
    }

    100% {
        stroke-dashoffset: 778;
    }
}

@keyframes modalFadeIn {
    0% {
        background-color: transparent;
    }

    100% {
        background-color: white;
    }
}

@keyframes modalFadeOut {
    0% {
        background-color: white;
    }

    100% {
        background-color: transparent;
    }
}

@keyframes modalContentFadeIn {
    0% {
        opacity: 0;
        top: -20px;
    }

    100% {
        opacity: 1;
        top: 0;
    }
}

@keyframes modalContentFadeOut {
    0% {
        opacity: 1;
        top: 0;
    }

    100% {
        opacity: 0;
        top: -20px;
    }
}

@keyframes bondJamesBond {
    0% {
        transform: translateX(1000px);
    }

    80% {
        transform: translateX(0);
        border-radius: 75px;
        height: 75px;
        width: 75px;
    }

    90% {
        border-radius: 3px;
        height: 182px;
        width: 247px;
    }

    100% {
        border-radius: 3px;
        height: 162px;
        width: 227px;
    }
}

@keyframes killShot {
    0% {
        transform: translateY(0) rotate(0deg);
        opacity: 1;
    }

    100% {
        transform: translateY(300px) rotate(45deg);
        opacity: 0;
    }
}

@keyframes fadeToRed {
   0% {
        background-color: rgba(0, 0, 0, 0.6);
    }
    100% {
        background-color: rgba(255, 0, 0, 0.8);
    }
}

@keyframes slowFade {
    0% {
        opacity: 1;
    }

    99.9% {
        opacity: 0;
        transform: scale(1);
    }

    100% {
        transform: scale(0);
    }
}
@keyframes circleIn {

    from {
        transform: translate(-50%, -50%) scale(0);
    }

    to {
        transform: translate(-50%, -50%) scale(1);
    }
}

@keyframes morphModal {
    from {
        width: 75px;
        height: 75px;
        border-radius: 50%;
    }

    to {
        
        width: 60%;
        height: 40%;
        border-radius: 10px;
    }
}

@keyframes xFadeOut {
    from {
        opacity: 1;
    }

    to {
        opacity: 0;
    }
}
