/*
Theme Name: IMMUNE Block Theme
Theme URI: 
Author: 
Author URI: 
Description: 
Requires at least: 6.8
Tested up to: 6.8
Requires PHP: 5.7
Version: 
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: immune-block-theme
Tags: 
*/

/* For browsers that support `scrollbar-*` properties */
@supports (scrollbar-color: auto) {
    .is-modal-box>div {
        scrollbar-color: var(--wp--preset--color--link-light) transparent;
    }
}

/* Otherwise, use `::-webkit-scrollbar-*` pseudo-elements */
@supports selector(::-webkit-scrollbar) {
    .is-modal-box>div::-webkit-scrollbar {
        background: transparent;
    }

    .is-modal-box>div::-webkit-scrollbar-thumb {
        background: var(--wp--preset--color--link-light);
    }
}

:focus-visible {
    outline: var(--wp--preset--color--link-light) auto 1px;
}

.has-mask {
    -webkit-mask: linear-gradient(90deg, transparent, #ffffff 20%, #ffffff 80%, transparent);
    mask: linear-gradient(90deg, transparent, #ffffff 20%, #ffffff 80%, transparent);
}

/* Megamenu */

header.wp-block-template-part {
    position: relative;
    z-index: 99;
}

.main-nav>*>:is(a, button) {
    color: inherit;
    display: flex;
    padding-top: var(--wp--preset--spacing--40);
    padding-bottom: var(--wp--preset--spacing--40);
    width: 100%;
}

.main-nav>*>:is(a, button):hover {
    text-decoration: underline;
}

/* Posicionar el contenedor */
.has-megamenu {
    position: initial;
}

.has-megamenu>.megamenu {
    margin-block-start: 1px;
}

@media (max-width: 782px) {
    .main-header {
        padding-top: var(--wp--preset--spacing--40) !important;
        padding-bottom: var(--wp--preset--spacing--40) !important;
    }

    .main-header .wp-block-site-logo {
        margin-inline-end: auto;
    }

    .main-nav {
        gap: 0;
        position: absolute;
        background-color: var(--wp--preset--color--body);
        top: 3.51rem;
        left: 0;
        width: 100%;
    }

    .main-nav:not(.is-active) {
        display: none;
    }

    .main-nav>* {
        width: 100%;
    }

    .main-nav>*>:is(a, button) {
        border-bottom: 1px solid var(--wp--preset--color--border-dark);
        padding-right: var(--wp--preset--spacing--40);
        padding-left: var(--wp--preset--spacing--40);
    }

    .has-megamenu:not(.is-active)>.megamenu {
        display: none;
    }
}

@media (min-width: 781px) {
    .main-nav {
        flex-direction: row !important;
    }

    .has-megamenu>.megamenu {
        position: absolute;
        left: 0;
        width: 100%;
    }

    .has-megamenu:not(:hover)>.megamenu {
        display: none;
    }
}

/* Forms */

.hbspt-form {
    width: 100%;
}

form {
    display: flex;
    flex-direction: column;
    accent-color: var(--wp--preset--color--link-light);
}

.hs-richtext>* {
    margin-block-start: 0;
}

.hs-richtext h2 {
    font-size: var(--wp--preset--font-size--medium);
}

fieldset {
    max-width: 100% !important;
}

.form-columns-2 {
    display: flex;
    gap: 2%;
}

.hs-form-field {
    margin-block-end: var(--wp--style--block-gap);
}

label {
    font-size: var(--wp--preset--font-size--small);
}

.hs-input:not([type="checkbox"]) {
    width: 100% !important;
    box-sizing: border-box;
}

.input {
    margin-right: 0 !important
}

input:not([type="checkbox"], [type="submit"]),
select,
textarea {
    background: none;
    border: 1px solid var(--wp--preset--color--border-light);
    border-radius: var(--wp--preset--spacing--20);
    min-height: 40px;
    color: inherit;
    padding: var(--wp--preset--spacing--20);
    font: inherit;
    line-height: 1;
}

select {
    appearance: none;
}

.hs-form-required {
    color: var(--wp--preset--color--vivid-red)
}

.inputs-list {
    list-style-type: none;
    margin: 0;
    padding: 0;
    font-size: var(--wp--preset--font-size--small);
}

input[type="checkbox" i] {
    margin: 0 0.25rem 0 0;
}

input[type="submit"] {
    background-color: var(--wp--preset--color--link-light);
    border: 1px solid var(--wp--preset--color--link-light);
    color: var(--wp--preset--color--background);
    font: inherit;
    font-size: var(--wp--preset--font-size--small);
    font-weight: 500;
    cursor: pointer;
    width: 100%;
}

/* Tabs */

.is-tab-content:not(.is-active):not(.wp-block-post-template),
.wp-block-post-template.is-tab-content>li:not(.is-active),
.is-modal-box:not(.is-active) {
    display: none;
}

/* Scroller */

.scroller {
    width: 100%;
    overflow: hidden;
}

.scroller__content {
    width: max-content;
    animation: scroll 60s forwards linear infinite;
    display: flex;
}

@keyframes scroll {
    to {
        transform: translate(-50%);
    }
}

/* Lite youtube */

lite-youtube {
    background-color: #000;
    position: relative;
    display: block;
    contain: content;
    background-position: center center;
    background-size: cover;
    cursor: pointer;
    max-width: 720px;
    width: 100%;
    border-radius: var(--wp--preset--spacing--20);
}

lite-youtube::before {
    content: attr(data-title);
    display: block;
    position: absolute;
    bottom: 0;
    /* Pixel-perfect port of YT's gradient PNG, using https://github.com/bluesmoon/pngtocss plus optimizations */
    background-image: linear-gradient(0deg,
            rgb(0 0 0 / 67%) 0%,
            rgb(0 0 0 / 54%) 14%,
            rgb(0 0 0 / 15%) 54%,
            rgb(0 0 0 / 5%) 72%,
            rgb(0 0 0 / 0%) 94%);
    /*height: 99px;*/
    width: 100%;
    font-family: "YouTube Noto", Roboto, Arial, Helvetica, sans-serif;
    color: hsl(0deg 0% 93.33%);
    text-shadow: 0 0 2px rgba(0, 0, 0, 0.5);
    padding: 16px 64px 13px 20px;
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
    box-sizing: border-box;
}

lite-youtube:hover::before {
    color: white;
}

/* responsive iframe with a 16:9 aspect ratio
    thanks https://css-tricks.com/responsive-iframes/
*/
lite-youtube::after {
    content: "";
    display: block;
    padding-bottom: calc(100% / (16 / 9));
}

lite-youtube>iframe {
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    border: 0;
}

/* play button */
lite-youtube>.lyt-playbtn {
    display: block;
    width: 100%;
    height: 100%;
    /* …but visually it's still the same size */
    background: no-repeat 95% 92%/34px 24px;
    /* YT's actual play button svg */
    background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 68 48"><path d="M66.52 7.74c-.78-2.93-2.49-5.41-5.42-6.19C55.79.13 34 0 34 0S12.21.13 6.9 1.55c-2.93.78-4.63 3.26-5.42 6.19C.06 13.05 0 24 0 24s.06 10.95 1.48 16.26c.78 2.93 2.49 5.41 5.42 6.19C12.21 47.87 34 48 34 48s21.79-.13 27.1-1.55c2.93-.78 4.64-3.26 5.42-6.19C67.94 34.95 68 24 68 24s-.06-10.95-1.48-16.26z" fill="red"/><path d="M45 24 27 14v20" fill="white"/></svg>');
    position: absolute;
    cursor: pointer;
    z-index: 1;
    filter: grayscale(100%);
    transition: filter 0.1s cubic-bezier(0, 0, 0.2, 1);
    border: 0;
}

lite-youtube:hover>.lyt-playbtn,
lite-youtube .lyt-playbtn:focus {
    filter: none;
}

/* Post-click styles */
lite-youtube.lyt-activated {
    cursor: unset;
}

lite-youtube.lyt-activated::before,
lite-youtube.lyt-activated>.lyt-playbtn {
    opacity: 0;
    pointer-events: none;
}

.lyt-visually-hidden {
    clip: rect(0 0 0 0);
    clip-path: inset(50%);
    height: 1px;
    overflow: hidden;
    position: absolute;
    white-space: nowrap;
    width: 1px;
}