/*==================================================
FONTS & ICONS
==================================================*/

@import 'fonts.css';

/*================================================*/



/*==================================================
THEMES
==================================================*/

:root
{
    --scroll-margin: inset 0 0 10px 10px rgba(0, 0, 0, 0.20);

    --max-width: 1280px;
    --margin: 50px;
    --padding: 20px;
    --ultra-text: 54px;
    --super-text-x2: 48px;
    --super-text: 32px;
    --big-text: 24px;
    --main-text: 16px;
    --second-text: 13px;
    --third-text: 11px;
    --icon: 16px;
    --btn: 16px;
    --nav-icon: 20px;
    --border-radius: 15px;
    --border-radius-round: 1024px;

    --bg: #fff;

	--border: 2px solid;
	--border-color: rgba(0, 0, 0, 0.10);

	--text-color: #252e49;
	--selected-text: #fff;
	--selected-bg: rgba(0, 0, 0, 1);

    --main-color: #252e49;
    --second-color: #eceff1;
    --third-color: #fff;

    --blue: #252e49;
    --skyblue: #1b9bd7;
    --green: #1cbfbf;
    --red: #ef492b;
    --yellow: #e5bd13;

    --whatsapp: #28cf70;

    --shadow: rgba(0, 0, 0, 0.20);
    --popup-bg: rgba(245, 245, 240, 0.7);

    --transition: 0.25s;
}

.banner-title
{
    font-size: var(--banner-text);
    font-family: montserrat-bold;
}
.ultra-title
{
    font-size: var(--ultra-text);
    font-family: montserrat-bold;
}
.super-title-x2
{
    font-size: var(--super-text-x2);
    font-family: montserrat-bold;
}
.super-title
{
    font-size: var(--super-text);
    font-family: montserrat-bold;
}
.big-title
{
    font-size: var(--big-text);
    font-family: montserrat-bold;
}
.main-title
{
    font-size: var(--main-text);
    font-family: montserrat-bold;
}
.second-title
{
    font-size: var(--second-text);
    font-family: montserrat-bold;
}
.third-title
{
    font-size: var(--third-text);
    font-family: montserrat-bold;
}

.ultra-text{font-size: var(--ultra-text);}
.super-text-x2{font-size: var(--super-text-x2);}
.super-text{font-size: var(--super-text);}
.big-text{font-size: var(--big-text);}
.main-text{font-size: var(--main-text);}
.second-text{font-size: var(--second-text);}
.third-text{font-size: var(--third-text);}

.main-color{color: var(--main-color) !important;}
.second-color{color: var(--second-color) !important;}
.third-color{color: var(--third-color) !important;}
.fourth-color{color: var(--fourth-color) !important;}
.fifth-color{color: var(--fifth-color) !important;}
.sixth-color{color: var(--main-color) !important;}
.seventh-color{color: var(--seventh-color) !important;}
.eighth-color{color: var(--eighth-color) !important;}
.ninth-color{color: var(--ninth-color) !important;}
.tenth-color{color: var(--tenth-color) !important;}

.red-color{color: var(--blue) !important;}
.skyblue-color{color: var(--skyblue) !important;}
.green-color{color: var(--whatsapp) !important;}
.red-color{color: var(--red) !important;}
.yellow-color{color: var(--yellow) !important;}

.main-bg-color{background-color: var(--main-color) !important;}
.second-bg-color{background-color: var(--second-color) !important;}
.third-bg-color{background-color: var(--third-color) !important;}
.fourth-bg-color{background-color: var(--fourth-color) !important;}
.fifth-bg-color{background-color: var(--fifth-color) !important;}
.sixth-bg-color{background-color: var(--main-color) !important;}
.seventh-bg-color{background-color: var(--seventh-color) !important;}
.eighth-bg-color{background-color: var(--eighth-color) !important;}
.ninth-bg-color{background-color: var(--ninth-color) !important;}
.tenth-bg-color{background-color: var(--tenth-color) !important;}

.red-bg-color{background-color: var(--blue) !important;}
.skyblue-bg-color{background-color: var(--skyblue) !important;}
.green-bg-color{background-color: var(--whatsapp) !important;}
.red-bg-color{background-color: var(--red) !important;}
.yellow-bg-color{background-color: var(--yellow) !important;}

.main-border-color{border-color: var(--main-color) !important;}
.second-border-color{border-color: var(--second-color) !important;}
.third-border-color{border-color: var(--third-color) !important;}
.fourth-border-color{border-color: var(--fourth-color) !important;}
.fifth-border-color{border-color: var(--fifth-color) !important;}
.sixth-border-color{border-color: var(--main-color) !important;}
.seventh-border-color{border-color: var(--seventh-color) !important;}
.eighth-border-color{border-color: var(--eighth-color) !important;}
.ninth-border-color{border-color: var(--ninth-color) !important;}
.tenth-border-color{border-color: var(--tenth-color) !important;}

@media (prefers-color-scheme: light)
{

}

@media (prefers-color-scheme: dark)
{
    /*
    :root
    {
        --scroll-margin: inset 0 0 10px 10px rgba(255, 255, 255, 0.20);

        --bg: #000;

        --border-color: rgba(255, 255, 255, 0.20);

        --text-color: #ECEFF1;
        --selected-text: #000;
        --selected-bg: rgba(255, 255, 255, 1);

        --main-color: #ECEFF1;
        --second-color: #000;
        --third-color: #263238;

        --shadow: rgba(255, 255, 255, 0.20);
        --popup-bg: rgba(0, 0, 0, 0.7);
    }
    */
}

/*================================================*/



/*==================================================
MAIN TAGS
==================================================*/

html
{
    line-height: 1.25;
    scroll-behavior: smooth;
    /*overflow: hidden;*/
}

html, body
{
	width: -webkit-fill-available;
    width: -moz-available;
	height: -webkit-fill-available;
    height: -moz-available;
	margin: 0;
	padding: 0;
    border: 0;
}

body
{
    padding: 
        env(safe-area-inset-top, 50px) 
        env(safe-area-inset-right, 50px) 
        env(safe-area-inset-bottom, 50px) 
        env(safe-area-inset-left, 50px)
    ;
    position: relative;
	font-size: var(--main-text);
	font-family: montserrat-regular;
	color: var(--text-color);
    background-color: var(--bg);
    /*
    background-image: url(../img/concept-bg1.jpg);
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
    */
    overflow: hidden scroll;
    -webkit-overflow-scrolling: touch;
    scrollbar-gutter: stable;
    transition: var(--transition);
}

input, textarea, select, button, .input
{
    width: 100%;
    margin: 0;
    padding: 0;
    display: flex;
    justify-content: flex-start;
    align-items: center;
    position: relative;
    font-family: montserrat-regular;
    font-size: var(--main-text);
    color: var(--main-color);
	background-color: transparent;
	outline: none;
	border: none;
	resize: none;
	box-sizing: border-box;
    -moz-appearance: none;
    -webkit-appearance: none;
    transition: var(--transition);
}

input[type=password]::-ms-reveal,
input[type=password]::-ms-clear
{
    display: none;
}

button
{
    height: auto;
}

textarea{height: 96px;}

option
{
    padding: 10px;
    color: var(--main-color);
    background-color: var(--bg);
}

input[type="checkbox"], input[type="radio"]
{
    width: auto;
    height: auto;
    display: flex;
    justify-content: center;
    align-items: center;
    font-weight: bold;
    font-size: var(--main-text);
    /*background-color: var(--main-color);*/
    border-radius: 10px;
    transition: var(--transition);
}

input[type="checkbox"]:hover, input[type="radio"]:hover
{
    cursor: pointer;
    /*color: var(--main-color);*/
}

input[type='checkbox']:before, input[type="radio"]:before
{
    padding: 7.5px;
    font-family: 'icons';
    content: "\e92e";
    color: transparent;
    background-color: var(--second-color);
    border: 2px solid var(--border-color);
    border-radius: 10px;
    transition: var(--transition);
}

input[type='checkbox']:checked:before, input[type="radio"]:checked:before
{
    color: white;
    background-color: var(--main-color);
    border-color: var(--main-color);
}

input[type='checkbox']:hover:before, input[type='radio']:hover:before
{
    color: var(--main-color);
    border-color: var(--main-color);
}

input[type='checkbox']:hover:checked:before, input[type='radio']:hover:checked:before
{
    color: white;
    background-color: var(--main-color);
}

input[type="date"]::-webkit-calendar-picker-indicator, input[type="month"]::-webkit-calendar-picker-indicator
{
    width: auto;
    height: auto;
    position: absolute;
    top: 0;
    bottom: 0;
    right: 0;
    left: 0;
    color: transparent;
    background: transparent;
}

input::-webkit-datetime-edit-day-field:focus,
input::-webkit-datetime-edit-month-field:focus,
input::-webkit-datetime-edit-year-field:focus
{
    color: var(--main-color);
    background-color: transparent;
}

::placeholder
{
    color: var(--main-color);
    transition: var(--transition);
}

::selection
{
	color: var(--selected-text);
	background-color: var(--selected-bg);
}

input:-webkit-autofill,
input:-webkit-autofill:hover, 
input:-webkit-autofill:focus,
input:-webkit-autofill:active,
textarea:-webkit-autofill,
textarea:-webkit-autofill:hover,
textarea:-webkit-autofill:focus,
textarea:-webkit-autofill:active,
select:-webkit-autofill,
select:-webkit-autofill:hover,
select:-webkit-autofill:focus,
select:-webkit-autofill:active
{
    -webkit-text-fill-color: var(--main-color);
    -webkit-box-shadow: 0 0 0 1000px var(--second-color) inset;
    color: var(--second-color);
}

input[data-autocompleted]
{
    background-color: var(--red);
}

picture
{
    text-align: center;
}

img
{
    max-width: 100%;
    width: 100%;
    height: auto;
    display: block;
    pointer-events: none;
    -webkit-touch-callout: none;
}

a
{
    color: unset;
    text-decoration: none;
}

hr
{
    width: 100%;
    margin-block: 10px;
    border: none;
    border-top: 2px solid var(--border-color);
    border-bottom: none;
}

/*================================================*/



/*==================================================
HEADER
==================================================*/

#header
{
    /*grid-area: header;*/
    width: -webkit-fill-available;
    width: -moz-available;
    padding: 20px;
    /*padding-right: 30px;*/
    display: flex;
    justify-content: space-between;
    align-items: center;
    position: fixed;
    top: 0;
    z-index: 10;
    /*border-bottom: 2px solid var(--border-color);*/
    transition: all var(--transition), opacity 0;
    backdrop-filter: blur(50px);
    -webkit-backdrop-filter: blur(50px);
    /*pointer-events: none;*/
}

.header-container
{
    /*max-width: var(--max-width);*/
    width: 100%;
    height: 100%;
    margin-inline: auto;
    padding: 20px;
    display: grid;
    grid-template-areas: 
        "logo nav profile"
    ;
    grid-template-columns: auto 1fr auto;
    align-items: center;
    gap: 10px;
    position: relative;
    background-color: var(--third-color);
    border-radius: var(--border-radius);
    box-shadow: 0 10px 20px -5px var(--shadow);
    transition: var(--transition);
}

.logo-container
{
    grid-area: logo;
    width: 100%;
    height: auto;
    display: flex;
    align-items: center;
    gap: 50px;
    position: relative;
    z-index: 5;
    /*background-color: var(--seventh-color);*/
}

.logo
{
    max-width: 100px;
    width: 100%;
    height: auto;
    margin: auto;
    transition: var(--transition);
}

.logo-text
{
    font-size: var(--big-text);
    font-family: montserrat-bold;
    font-weight: bold;
}

.logo-feria
{
    max-width: 180px;
    width: 100%;
    height: auto;
    margin: auto;
    position: absolute;
    bottom: 100px;
    left: 0;
    right: 0;
    transition: var(--transition);
}

.logo-feria-mini
{
    max-width: 65px;
}

/*================================================*/



/*==================================================
NAVS
==================================================*/

#nav
{
    grid-area: nav;
}


.nav-group
{
    width: -webkit-fill-available;
    width: -moz-available;
    padding: 5px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    align-items: center;
    gap: 10px;
    transition: var(--transition);
}

.nav
{
    width: fit-content;
    width: -moz-fit-content;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 10px;
    position: relative;
    /*overflow: scroll hidden;*/
    -webkit-overflow-scrolling: touch;
    transition: var(--transition);
    /*background-color: var(--seventh-color);*/
}

.nav-items
{
    margin: auto;
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 10px;
    position: relative;
    transition: var(--transition);
}

.nav-items-line:before
{
    content: "";
    width: -webkit-fill-available;
    width: -moz-available;
    height: 2px;
    position: relative;
    left: 0;
    background-color: var(--border-color);
}

.nav-items-line:after
{
    content: "";
    width: 100%;
    height: 2px;
    position: relative;
    right: 0;
    background-color: var(--border-color);
}

.nav-item
{
    padding: 5px 10px;
    display: flex;
    align-items: center;
    gap: 10px;
    flex-shrink: 0;
    position: relative;
    font-family: montserrat-bold;
    border: 2px solid transparent;
    border-radius: var(--border-radius-round);
    transition: var(--transition);
}

.nav-item:hover
{
    cursor: pointer;
    color: var(--third-color);
    background-color: var(--main-color);
}

.nav-item.btn-active:not(.logo-container)
{
    color: var(--third-color);
    background-color: var(--main-color);
}

.nav-item-circle
{
    padding: 5px;
}

.nav-icon
{
    margin: auto;
    display: flex;
    justify-content: center;
    align-items: center;
    position: relative;
    z-index: 1;
    font-size: var(--nav-icon);
}

.nav-text
{
    font-size: var(--main-text);
}





.nav-submenu
{
    position: relative;
    transition: var(--transition);
}

.nav-submenu-btn
{
    margin: auto;
    display: flex;
    align-items: center;
    gap: 5px;
    position: relative;
    color: var(--third-color);
    transition: var(--transition);
}

.nav-submenu-btn:hover
{
    cursor: pointer;
    color: var(--main-color);
}

.nav-submenu-items
{
    min-width: 150px;
    padding: 10px;
    display: grid;
    gap: 5px;
    position: absolute;
    top: 0;
    left: 0;
    z-index: 1;
    background-color: var(--third-color);
    border-radius: 15px;
    box-shadow: 0 20px 50px -10px rgba(0, 0, 0, 0.50);
    opacity: 0;
    visibility: hidden;
    transition: var(--transition);
}

.nav-submenu:hover > .nav-submenu-items
{
    cursor: pointer;
    top: 23px;
    opacity: 1;
    visibility: visible;
}

.nav-submenu-item
{
    padding: 5px;
    display: flex;
    align-items: center;
    opacity: 1;
    gap: 5px;
    font-size: var(--second-text);
    font-family: montserrat-bold;
    border-radius: 10px;
    transition: var(--transition);
}

.nav-submenu-item:hover
{
    color: var(--main-color);
    background-color: var(--second-color);
    border-color: var(--main-color);
}

.nav-submenu-item:last-child
{
    border: none;
}





.mobile-nav
{
    grid-area: mobilenav;
    /*height: 60px;*/
    padding-block: 10px;
    display: none;
    justify-content: center;
    align-items: center;
}

#mobile-nav-close
{
    display: none;
}

.mobile-header
{
    width: -webkit-fill-available !important;
    width: -moz-available !important;
    height: -webkit-fill-available !important;
    height: -moz-available !important;
    padding: 
        env(safe-area-inset-top, 50px) 
        env(safe-area-inset-right, 50px) 
        env(safe-area-inset-bottom, 50px) 
        env(safe-area-inset-left, 50px)
    ;
    margin: auto;
    color: var(--main-color);
    /*align-items: flex-start !important;*/
    /*bottom: 0;*/
    color: var(--main-color);
    background-color: var(--sixth-color);
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
}





#profile
{
    grid-area: profile;
}

.logged-img
{
    width: fit-content;
    height: fit-content;
    margin: auto;
    padding: 20px;
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 10px;
    font-size: var(--ultra-text);
    font-family: rethink-sans-bold;
    /*color: var(--second-color);*/
    background-color: var(--second-color);
    border: 3px solid var(--second-color);
    border-radius: var(--border-radius-round);
    transition: var(--transition);
}





.subnav
{
    /*margin-inline: 20px;*/
    padding: 15px;
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 10px;
    z-index: 1;
    overflow: scroll hidden;
    -webkit-overflow-scrolling: touch;
    /*border-radius: var(--border-radius-round);*/
    box-shadow: 0 10px 30px 0px rgba(0, 0, 0, 0.15);
    transition: var(--transition);
}

.subnav-sticky
{
    position: sticky;
    top: 133px;
    bottom: 0;
}

.subnav-group
{
    max-width: var(--max-width);
    width: -webkit-fill-available;
    width: -moz-available;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 10px;
    transition: var(--transition);
}

.subnav-items
{
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 10px;
    position: relative;
    overflow: scroll hidden;
    -webkit-overflow-scrolling: touch;
    transition: var(--transition);
}

.subnav-item
{
    width: max-content;
    margin-inline: auto;
    padding: 5px 10px;
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 10px;
    position: relative;
    font-family: montserrat-bold;
    font-size: var(--main-text);
    color: var(--second-color);
    border: 2px solid transparent;
    border-radius: var(--border-radius-round);
    transition: var(--transition);
}

.subnav-item:hover, .subnav-item.subnav-active
{
    cursor: pointer;
    color: var(--main-color);
    background-color: var(--third-color);
    border-color: var(--third-color);
}

.subnav-text
{
    font-size: var(--main-text);
}

.input-figure
{
    width: auto;
    height: 50px;
    margin: 0;
    /*padding: 10px;*/
    position: relative;
    overflow: hidden;
    transition: var(--transition);
}

.input-figure:has([data-input]:not([value=""]))
{
    /*background-color: var(--midblue);*/
}

.input-figure:has([data-input]:not([value=""])) figcaption
{
    /*color: white;*/
}

.input-img
{
    max-width: 50px;
    width: 100%;
    height: 100%;
    margin: auto;
    position: relative;
    inset: 0;
    object-fit: contain;
    object-position: center;
}

/*================================================*/



/*==================================================
MAIN CONTENT
==================================================*/

#body
{
    /*display: grid;*/
    grid-template-areas: 
        "header"
        "main"
    ;
    grid-template-columns: 1fr;
    grid-template-rows: auto 1fr;
    gap: 0;
}

#body-admin
{
    /*margin: auto;*/
    display: grid;
    grid-template-areas: 
        "header"
        "main"
        "footer"
    ;
    grid-template-columns: 1fr;
    grid-template-rows: auto 1fr auto;
    gap: 0;
}

#main
{
    /*grid-area: main;*/
    width: 100%;
    /*height: 100%;*/
    position: relative;
    z-index: 1;
    /*overflow: hidden scroll;*/
    /*-webkit-overflow-scrolling: touch;*/
}

.screen
{
    width: 100%;
    height: 100%;
    /*position: absolute;*/
}

.page-error, .post-error
{
    max-width: 640px;
    margin: auto;
    padding: 20px;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 10px;
    text-align: center;
    font-size: 20px;
}





.section
{
    width: -webkit-fill-available;
    width: -moz-available;
    padding: 100px 50px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    align-items: center;
    text-align: center;
    gap: 50px;
    position: relative;
    background-color: var(--third-color);
    scroll-margin-top: 180px;
}

.section-full
{
    height: 100vh;
}

.section-padding
{
    padding: 100px 50px;
}

.section-nopadding
{
    padding: 0 !important;
}

.section-content
{
    /*max-width: var(--max-width);*/
    /*width: 100%;*/
    height: 100%;
    display: grid;
    gap: 20px;
}

.section-menu
{
    padding: 20px;
    display: grid;
    grid-auto-columns: 1fr;
    grid-auto-rows: auto 1fr auto;
    gap: 20px;
}

.section-columns
{
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    align-items: center;
}

.section-rows
{
    flex-direction: column;
    justify-content: space-between;
    align-items: center;
}





.section-banner
{
    width: -webkit-fill-available;
    width: -moz-available;
    height: 100vh;
    display: flex;
    flex-direction: column;
    align-items: center;
    /*position: sticky;*/
    top: 0;
    z-index: 0;
    /*background-color: var(--main-color);*/
    overflow: hidden;
}

.section-banner-h-cut
{
    height: calc(100vh - 60px);
}

.section-banner-overlay
{
    width: 100%;
    height: 100%;
    position: absolute;
    inset: 0;
    z-index: 0;
    background-color: rgba(0, 0, 0, 0.50);
}

.section-banner-slider
{
    width: 100%;
    height: 100%;
    display: grid;
    align-items: center;
    position: relative;
    z-index: 1;
}

.section-banner-slide
{
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
}

.section-banner-img
{
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    position: absolute;
    inset: 0;
    z-index: 0;
}

.section-banner-info
{
    width: fit-content;
    width: -moz-fit-content;
    margin: auto;
    padding: 50px;
    padding-top: 120px;
    display: flex;
    flex-direction: column;
    place-content: center;
    align-items: center;
    gap: 0;
    position: relative;
    inset: 0;
    z-index: 1;
    text-align: center;
    font-family: montserrat-bold;
    font-size: var(--ultra-text);
    color: var(--third-color);
}

.section-banner-menu
{
    width: -webkit-fill-available;
    width: -moz-available;
    margin: auto;
    padding-block: 20px;
    display: flex;
    flex-direction: column;
    /*place-content: center;*/
    /*justify-content: center;*/
    align-items: center;
    gap: 20px;
    position: sticky;
    bottom: 0;
    left: 0;
    right: 0;
    z-index: 10;
}

.section-banner-options
{
    max-width: 1280px;
    width: -webkit-fill-available;
    width: -moz-available;
    margin: auto;
    padding: 0 20px;
    display: grid;
    grid-auto-flow: column;
    grid-auto-columns: 1fr;
    /*justify-content: center;*/
    align-items: center;
    gap: 0;
}

.section-banner-option
{
    margin-inline: 10px;
    padding: 10px 20px;
    display: grid;
    grid-auto-flow: column;
    align-items: center;
    gap: 20px;
    color: var(--third-color);
    background-color: var(--skyblue);
    border: 3px solid transparent;
    border-radius: var(--border-radius);
    opacity: 0.5;
    transition: var(--transition);
}

.section-banner-option:hover
{
    cursor: pointer;
    /*color: var(--main-color);*/
    /*background-color: var(--third-color);*/
    border-color: var(--third-color);
    opacity: 1;
    transition: var(--transition);
}

.section-banner-option.is-nav-selected
{
    cursor: pointer;
    /*color: var(--main-color);*/
    border-color: var(--third-color);
    /*background-color: var(--third-color);*/
    opacity: 1;
    transition: var(--transition);
}

.section-banner-title
{
    padding: 10px 20px;
    font-size: var(--big-text);
    background-color: var(--skyblue);
}

.flickity-button
{
    color: white;
    background-color: transparent;
}

.flickity-button:hover
{
    color: var(--main-color);
    background-color: var(--second-color);
}

.section-header
{
    width: -webkit-fill-available;
    width: -moz-available;
    height: 30vh;
    display: flex;
    place-content: center;
    position: relative;
    overflow: hidden;
}

.section-header-title
{
    max-width: var(--max-width);
    width: 100%;
    margin-inline: auto;
    padding-top: 110px;
    padding-inline: 20px;
    display: flex;
    align-items: center;
    gap: 20px;
    text-align: left;
    font-size: var(--ultra-text);
}

.section-header-title:after
{
    content: "";
    width: 100%;
    height: 2px;
    flex: 1;
    background-image: linear-gradient(to right, var(--third-color), transparent);
    opacity: 0.5;
}

.section-header-img
{
    max-width: var(--max-width);
    margin: auto;
    padding-inline: 20px;
}

.section-line1
{
    width: 100%;
    margin-block: 50px;
    border-bottom: 2px solid var(--border-color);
}

.section-line2
{
    width: 100%;
    margin-block: 10px;
    border-bottom: 2px solid var(--border-color);
}

.section-limit
{
    max-width: var(--max-width);
    width: -webkit-fill-available;
    width: -moz-available;
    margin-inline: auto;
}

.loader
{
    font-size: var(--super-text);
    animation: loader 1s linear infinite;
}

@keyframes loader
{
    from
    {
        transform: rotate(0deg);
    }
    to
    {
        transform: rotate(360deg);
    }
}

/*================================================*/



/*==================================================
ASIDE
==================================================*/

.aside
{
    width: 100%;
    height: -webkit-fill-available;
    height: -moz-available;
    /*padding: 20px;*/

    /*flex: 1;*/
    display: grid;
    gap: 20px;
    position: relative;
    text-align: center;
    overflow: hidden;
    transition: var(--transition);
}

.aside-bg
{
    background-image: url('../img/orange-bg.webp');
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
}

.aside-title
{
    padding: 10px;
    font-family: trajan-pro-regular;
    /*border-bottom: 2px solid var(--second-color);*/
    transition: var(--transition);
}

.aside-main
{
    padding: 10px;
    place-content: center;
    overflow: hidden scroll;
    transition: var(--transition);
}

.aside-footer
{
    padding: 10px;
    font-family: trajan-pro-regular;
    /*border-top: 2px solid var(--second-color);*/
    transition: var(--transition);
}

.aside-logo
{
    max-width: 320px;
    margin: auto;
}

#aside-left
{
    /*grid-area: asideleft;*/
    display: grid;
    grid-template-columns: 1fr;
    grid-template-rows: auto 1fr auto;
    gap: 0;
    background-color: var(--third-color);
}

#aside-right
{
    /*grid-area: asideright;*/
    display: grid;
    grid-template-areas: 
        "header"
        "main"
        "footer"
    ;
    grid-template-columns: auto;
    grid-template-rows: auto 1fr auto;
    gap: 0;
}

.aside-close
{
    width: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
    border: 0 !important;
}

/*================================================*/



/*==================================================
FOOTER
==================================================*/

#footer
{
    padding: var(--margin);
    display: flex;
    flex-direction: column;
    justify-content: center;
    flex: 0;
    flex-shrink: 0;
    position: relative;
    bottom: 0;
    z-index: 1;
    color: var(--third-color);
    background-color: var(--main-color);
    transition: var(--transition);
    overflow: hidden;
}

.footer-container
{
    max-width: var(--max-width);
    width: 100%;
    margin: auto;
}

.footer-items
{
    padding: 30px 0;
    display: grid;
    justify-content: space-between;
    gap: 50px;
}

.footer-items:first-child{padding-top: 0;}
.footer-items:last-child{padding-bottom: 0}

.footer-block
{
    display: flex;
    align-items: center;
    gap: 30px;
}

.footer-icon
{
    font-size: 32px;
    background-color: var(--third-color);
    border: 0px solid var(--main-color);
    border-radius: 50%;
    /*transition: var(--transition);*/
}

.footer-icon:hover
{
    color: var(--third-color);
    background-color: var(--main-color);
    border: 2px solid var(--main-color);
}

.footer-img
{
    max-width: 150px;
    width: 100%;
    height: auto;
}

.footer-top
{
    justify-content: center;
}

.footer-center
{
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    justify-content: center;
}

.footer-bottom
{
    grid-template-columns: repeat(auto-fit, minmax(150px, auto));
    align-items: center;
}

.footer-nav
{
    margin: 10px 0;
    padding: 10px 10px;
    color: var(--third-color);
    background-color: var(--third-color)
}

.footer-btn
{
    margin: 5px 0;
    padding: 5px 0;
    display: grid;
    grid-auto-flow: column;
    justify-content: flex-start;
    align-items: center;
    gap: 5px;
    /*font-weight: bold;*/
    color: var(--third-color);
    background-color: transparent;
    border-radius: 5px;
    transition: var(--transition);
}

.footer-btn:hover
{
    padding-inline: 10px;
    cursor: pointer;
    color: var(--main-color);
    background-color: var(--second-color);
}

.footer-logo
{
    max-width: 320px;
    transition: var(--transition);
}

/*================================================*/





/*==================================================
GALLERY
==================================================*/

.section-gallery
{
    max-width: 960px;
    width: 100%;
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 20px;
}

.section-gallery-item
{
    padding: 20px;
    background-color: var(--second-color);
}

.section-video
{
    width: 100%;
    position: relative;
    aspect-ratio: 16/9;
    overflow: hidden;
    border-radius: var(--border-radius);
}

.section-video iframe
{
    width: 100%;
    height: 100%;
    position: relative;
    top: 0;
    left: 0;
}

.gmap
{
    width: 100%;
    height: 100%;
    margin-inline: auto;
    position: relative;
    /*border-radius: var(--border-radius);*/
    overflow: hidden;
    /*box-shadow: 0 10px 20px 0px rgba(0, 0, 0, 0.15);*/
}

.map360
{
    height: 100%;
    position: relative;
    overflow: hidden;
}

.gmap iframe, .map360 iframe
{
    width: 100%;
    height: 100%;
    position: relative;
    top: 0;
    left: 0;
}

/*================================================*/





/*==================================================
BLOCKS
==================================================*/

.block-columns
{
    /*max-width: var(--max-width);*/
    /*height: 100%;*/
    display: grid;
    grid-auto-flow: column;
    grid-auto-columns: 1fr;
    grid-auto-rows: 1fr;
    gap: 20px;
    justify-content: space-between;
    align-items: center;
    position: relative;
    text-align: center;
}

.block-limit
{
    max-width: var(--max-width);
}

.block
{
    height: 100%;
    flex: 1;
    position: relative;
    align-content: center;
}
/*
[data-bgcolor]
{
    margin: attr(data-margin px) !important;
    padding: attr(data-padding px) !important;
    background-color: attr(data-bgcolor type(<color>)) !important;
}
*/
.block-full
{
    height: 100%;
}

.block-content
{
    padding: 50px;
    display: grid;
    grid-auto-columns: 1fr;
    grid-auto-rows: auto;
    align-content: center;
    align-items: center;
    gap: 20px;
    position: relative;
}

.block-block
{
    display: grid;
}

.block-gallery
{
    display: flex;
    flex-wrap: wrap;
    gap: 100px;
    justify-content: center;
    align-items: center;
    position: relative;
    text-align: center;
}

.block-gallery-item
{
    
}

.block-gallery-img
{
    width: auto;
    height: 50px;
}

.block-img
{
    width: -webkit-fill-available;
    width: -moz-available;
    height: -webkit-fill-available;
    height: -moz-available;
    object-fit: cover;
    object-position: center;
    /*border: 10px solid white;*/
    border-radius: var(--border-radius);
}

.block-img-height
{
    max-height: 320px;
}

.block-title
{
    /*font-family: montserrat-regular;*/
    font-size: var(--ultra-text);
}

.block-text
{
    /*font-family: montserrat-regular;*/
    font-size: var(--big-text);
}

.block-footer
{
    display: grid;
    gap: 20px;
}

.block-line
{
    width: 100%;
    border-bottom: 2px solid rgba(255, 255, 255, 0.20);
}

.block-btn
{
    margin: auto;
    padding: 20px 50px;
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 10px;
    position: relative;
    font-size: var(--big-text);
    font-family: montserrat-regular;
    color: var(--main-color);
    /*background-color: var(--main-color);*/
    border: 2px solid var(--main-color);
    border-radius: var(--border-radius-round);
    transition: var(--transition);
}

.block-btn:hover
{
    cursor: pointer;
    color: white;
    background-color: var(--main-color);
    border-color: var(--main-color);
}





.block-profiles
{
    max-width: 960px;
    width: 100%;
    margin: auto;
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 30px;
}

.block-profile
{
    padding: 10px;
    display: grid;
    grid-template-columns: auto 1fr;
    align-items: center;
    gap: 5px;
    text-align: left;
    background-color: var(--third-color);
    /*border: 2px solid var(--second-color);*/
    border-radius: var(--border-radius);
    box-shadow: 0 10px 30px -5px rgba(0, 0, 0, 0.10);
}

.block-profile-info
{
    padding: 10px;
    display: grid;
    align-items: center;
    gap: 10px;
}

.block-profile-img
{
    max-width: 200px;
    max-height: 200px;
    width: 100%;
    /*height: 100%;*/
    object-fit: cover;
    object-position: center;
    border-radius: 10px;
    aspect-ratio: 1/1;
}

.block-profile-logo
{
    max-width: 100px;
    width: 100%;
    /*height: 100%;*/
    border-radius: 10px;
}

/*================================================*/





/*==================================================
POSTS
==================================================*/

.post-list
{
    /*max-width: 960px;*/
    width: -webkit-fill-available;
    width: -moz-available;
    margin-inline: auto;
    /*padding: 20px;*/
    display: grid;
    grid-auto-columns: 1fr;
    gap: 20px;
}

.post-list-item
{
    padding: 20px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 20px;
    position: relative;
    background-color: var(--second-color);
    border-radius: var(--border-radius);
    transition: all var(--transition), opacity 0;
}

.post-list-item-hover:hover
{
    cursor: pointer;
    background-image: linear-gradient(to right, transparent, var(--skyblue));
}

.post-list-item-first
{
    flex: 0.3 !important;
}

.post-list-item-header
{
    color: white;
    background-color: var(--main-color);
    border-radius: 10px;
}

.post-list-item-info
{
    /*padding: 5px;*/
    display: flex;
    flex-direction: column;
    gap: 5px;
    flex: 1;
    text-align: left;
    transition: var(--transition);
}

.post-list-item-options
{
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 10px;
    text-align: left;
    transition: var(--transition);
}

.post-list-item-num
{
    padding: 10px 15px;
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 10px;
    font-weight: bold;
    color: var(--third-color);
    background-color: var(--main-color);
    border-radius: var(--border-radius-round);
    transition: var(--transition);
}

.post-list-item-btn
{
    padding: 7.5px;
    font-weight: bold;
    border: 2px solid transparent;
    border-radius: var(--border-radius-round);
    transition: var(--transition);
}

.post-list-item-btn:hover
{
    cursor: pointer;
    color: var(--second-color);
    background-color: var(--main-color);
    border-color: var(--border-color);
}

.post-list-item-title
{
    font-family: montserrat-bold;
    transition: var(--transition);
}

.post-list-item-text
{
    font-size: var(--main-text);
    transition: var(--transition);
}

.post-list-item-icon
{
    font-weight: bold;
}

.post-logo
{
    max-width: 480px;
}

.ctct-inline-form *
{
    font-family: montserrat-regular !important;
}





.ticketbook
{
    display: grid;
    gap: 20px;
}

.ticketbook-ticket
{
    padding: 10px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 20px;
    position: relative;
    /*background-color: var(--second-color);*/
    border: 2px dashed var(--second-color);
    border-radius: var(--border-radius);
    transition: all var(--transition), opacity 0;
}

.ticketbook-ticket-info
{
    text-align: left;
}

.ticketbook-ticket-code
{

}

.ticketbook-ticket-img
{
    max-width: 100px;
    width: -webkit-fill-available;
    width: -moz-available;
    height: auto;
    padding: 10px;
    background-color: var(--fourth-color);
    border-radius: var(--border-radius);
}

.ticket-block
{
    display: grid;
    gap: 20px;
}

.ticket-status
{
    width: fit-content;
    width: -moz-fill-content;
    margin-block: 10px;
    /*padding: 10px;*/
    font-weight: bold;
    color: var(--main-color);
    /*background-color: var(--second-color);*/
    border-radius: 10px;
}

.ticket-user
{
    display: none;
}

.ticket-bg
{
    display: none;
}

.ticket-status[data-status="pending"]
{
    color: var(--third-color);
    color: var(--yellow);
}

.ticket-status[data-status="redeemed"]
{
    color: var(--third-color);
    color: var(--green);
}

.ticket-status[data-status="printed"]
{
    color: var(--third-color);
    color: var(--whatsapp);
}

.ticket-status[data-status="scanned"]
{
    color: var(--third-color);
    color: var(--whatsapp);
}

.ticket-status[data-status="canceled"]
{
    color: var(--third-color);
    color: var(--red);
}

.ticket-status[data-status="pending"]:after {content: "Sin canjear";}
.ticket-status[data-status="redeemed"]:after {content: "Canjeado";}
.ticket-status[data-status="printed"]:after {content: "Impreso";}
.ticket-status[data-status="scanned"]:after {content: "Escaneado";}
.ticket-status[data-status="canceled"]:after {content: "Cancelado";}





.accordeon
{
    width: -webkit-fill-available;
    width: -moz-available;
    height: fit-content;
    height: -moz-fit-content;
    padding: 20px;
    display: grid;
    gap: 10px;
    position: sticky;
    top: 155px;
    border: 1px solid var(--border-color);
    border-radius: 10px;
    overflow: hidden;
    transition: var(--transition);
}

.accordeon-details
{
    interpolate-size: allow-keywords;
    /*border-radius: 5px;*/
    overflow: clip;
}
/*
.accordeon-details[name="feria"] > .accordeon-summary, .accordeon-details[name="feria"] > .accordeon-details
{
    padding-left: 20px;
}
*/
.accordeon-summary
{
    padding: 10px 20px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 20px;
    position: relative;
    border: 2px solid var(--second-color);
    border-radius: var(--border-radius-round);
    transition: var(--transition);
}

.accordeon-summary:hover
{
    cursor: pointer;
    color: var(--third-color);
    background-color: var(--main-color);
}

.accordeon-details[open] > .accordeon-summary
{
    background-color: var(--second-color);
}

.accordeon-details[open] > .accordeon-summary:hover
{
    color: var(--main-color);
    border-color: var(--main-color);
}

.accordeon-details[open] > .accordeon-summary > .accordeon-icon
{
    rotate: -180deg;
}

.accordeon-details[open]::details-content
{
    height: auto;
}

.accordeon-details::details-content
{
    height: 0;
    overflow-y: clip;
    transition: content-visibility 0.25s allow-discrete, height 0.25s;
}

.accordeon-info
{
    padding: 5px;
    padding-left: 20px;
    display: grid;
    gap: 5px;
    transition: var(--transition);
}

.accordeon-info-item
{
    /*padding-left: 30px;*/
    display: flex;
    align-items: center;
    gap: 10px;
    transition: var(--transition);
}

.accordeon-title
{
    flex: 1;
    margin: 0;
}

.accordeon-icon
{
    font-size: var(--big-text);
    transition: var(--transition);
}





.section-tickets
{
    padding: 50px 0;
    position: sticky;
    top: 200px;
    z-index: 10;
}

.tickets-tabs
{
    padding: 50px;
    border-top: 4px solid transparent;
}

.tickets-tab
{
    /*max-width: var(--max-width);*/
    margin: auto;
}

.tickets-tab-container
{
    display: grid;
    gap: 10px;
}

.tickets-menu
{
    /*margin: auto;*/
    display: flex;
    flex-direction: column;
    /*place-content: center;*/
    /*justify-content: center;*/
    align-items: center;
    gap: 20px;
    overflow: scroll hidden;
    -webkit-overflow-scrolling: touch;
}

.tickets-options
{
    margin: auto;
    padding-inline: 20px;
    display: flex;
    justify-content: flex-start;
    align-items: center;
    gap: 20px;
}

.tickets-option
{
    width: max-content;
    padding: 10px;
    display: grid;
    grid-template-columns: 1fr auto;
    align-items: center;
    gap: 20px;
    color: var(--third-color);
    background-color: var(--skyblue);
    border: 3px solid transparent;
    border-radius: 20px 20px 0 0;
    opacity: 0.5;
    transition: var(--transition);
}

.tickets-option:hover, .tickets-option.btn-active
{
    cursor: pointer;
    /*color: var(--main-color);*/
    /*background-color: var(--third-color);*/
    /*border-color: var(--third-color);*/
    opacity: 1;
    transition: var(--transition);
}

.tickets-option-info
{

}

.tickets-title
{
    padding: 10px 20px;
    font-size: var(--big-text);
    background-color: var(--skyblue);
}





.tickets-rows
{
    padding: 20px;
}

.tickets-row
{
    padding-block: 15px;
    display: grid;
    grid-auto-flow: column;
    grid-auto-columns: 1fr;
    border-bottom: 1px solid var(--second-color);
}

.tickets-row:last-child
{
    border-color: transparent;
}

.tickets-row-info
{

}

.tickets-row-info:first-child
{
    grid-column: 1/span 2;
}

.tickets-icon
{
    font-size: var(--big-text);
}





.tickets-cards
{
    padding-inline: 50px;
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(360px, 1fr));
    justify-content: center;
    gap: 50px;
}

.tickets-card
{
    padding: 10px;
    display: flex;
    flex-direction: column;
    grid-template-rows: auto 1fr;
    background-color: var(--second-color);
    border: 2px solid var(--second-color);
    border-radius: 25px;
}

.tickets-card-header
{
    min-height: 260px;
    padding: 20px;
    color: var(--third-color);
    background-color: var(--main-color);
    border-radius: var(--border-radius);
}

.tickets-card-title
{
    padding: 20px;
    display: flex;
    justify-content: center;
    align-items: center;
    font-family: montserrat-bold;
    font-size: var(--big-text);
    border-radius: var(--border-radius-round);
}

.tickets-card-info
{
    padding: 20px;
}

.tickets-card-item
{
    padding-block: 10px;
    display: flex;
    align-items: center;
    gap: 20px;
    border-bottom: 1px solid rgba(0, 0, 0, 0.10);
}

.tickets-card-item:last-child
{
    padding-bottom: 0;
    border-color: transparent;
}

.tickets-card-product
{
    padding: 10px 0;
    display: grid;
    grid-template-columns: auto 1fr;
    justify-content: flex-end;
    align-items: center;
    gap: 20px;
    border-bottom: 2px solid rgba(255, 255, 255, 0.10);
}

.tickets-card-product:last-child
{
    border-color: transparent;
}

.tickets-card-price
{
    display: flex;
    justify-content: flex-end;
    align-items: center;
    gap: 20px;
    text-align: right;
}

.tickets-card-btn
{
    padding: 10px;
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 10px;
    position: relative;
    font-family: montserrat-bold;
    font-size: var(--main-text);
    color: var(--main-color);
    background-color: var(--third-color);
    border: 2px solid var(--third-color);
    border-radius: var(--border-radius-round);
    overflow: hidden;
    transition: var(--transition);
}

.tickets-card-btn:hover, .tickets-card-btn.btn-active
{
    cursor: pointer;
    color: var(--third-color);
    background-color: transparent;
    border-color: var(--third-color);
}

.tickets-card-btn-white
{
    width: fit-content;
    width: -moz-fit-content;
    padding: 10px;
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 10px;
    position: relative;
    font-family: montserrat-bold;
    font-size: var(--main-text);
    color: var(--third-color);
    border: 2px solid var(--third-color);
    border-radius: var(--border-radius-round);
    transition: var(--transition);
}

.tickets-card-btn-white:hover, .tickets-card-btn-white.btn-active
{
    cursor: pointer;
    color: var(--main-color);
    background-color: var(--third-color);
    border-color: var(--third-color);
}





.cart-buttons
{
    max-width: 180px;
    padding: 5px;
    display: flex;
    margin: auto;
    background-color: var(--second-color);
    border-radius: var(--border-radius-round);
    user-select: none;
}

.cart-quantity
{
    text-align: center;
    font-weight: bold;
}

.cart-quantity-btn
{
    padding: 10px;
    display: grid;
    grid-auto-flow: column;
    grid-auto-columns: 1fr;
    justify-content: space-between;
    align-items: center;
    gap: 20px;
    font-size: var(--big-text);
    text-align: center;
    color: var(--third-color);
    background-color: var(--main-color);
    border: 2px solid var(--main-color);
    border-radius: var(--border-radius-round);
    transition: var(--transition);
}

.cart-quantity-btn:hover
{
    cursor: pointer;
    color: var(--main-color);
    background-color: transparent;
}

.cart-group
{
    padding: 20px;
    display: grid;
    gap: 20;
    border: 2px solid var(--second-color);
    border-radius: var(--border-radius);
}

.cart-summary-container
{
    width: -webkit-fill-available;
    width: -moz-available;
    margin-top: auto;
    /*margin-bottom: 20px;*/
    padding: 20px;
    display: grid;
    grid-auto-flow: column;
    grid-auto-columns: 1fr;
    justify-content: space-between;
    align-items: center;
    gap: 20px;
    /*position: sticky;*/
    bottom: 0;
    z-index: 2;
    /* font-weight: bold; */
    text-align: center;
    color: var(--main-color);
    background-color: var(--second-color);
    border-radius: 30px;
    transition: var(--transition);
}

.cart-summary
{
    /* padding: 30px; */
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    gap: 10px;
    text-align: right;
}

.cart-summary-item
{
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 16px;
    font-weight: bold;
}

.cart-checkout
{
    /*width: max-content;*/
    /*margin-inline: auto;*/
    padding: 10px 20px;
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 10px;
    position: relative;
    font-family: montserrat-bold;
    font-size: var(--main-text);
    color: var(--third-color);
    background-color: var(--main-color);
    border: 2px solid var(--main-color);
    border-radius: var(--border-radius-round);
    transition: var(--transition);
}

.cart-checkout:hover, .cart-checkout.btn-active
{
    cursor: pointer;
    color: var(--main-color);
    background-color: transparent;
    border-color: var(--main-color);
}

/*================================================*/





/*==================================================
FORMS, MAP AND SUMMARY ACCORDION
==================================================*/

.form-error-message
{
    max-width: 640px;
    width: fit-content;
    width: -moz-available;
    height: fit-content;
    height: -moz-fit-content;
    /*width: fit-content;*/
    margin: auto;
    padding: 10px 15px;
    position: fixed;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    z-index: 10;
}

.form-error-message-info
{
    margin: auto;
    padding: 10px 15px;
    display: flex;
    flex-direction: column;
    gap: 10px;
    text-align: center;
    color: var(--third-color);
    background-color: var(--red);
    border-radius: var(--border-radius);
    border: 3px solid var(--fourth-color) !important;
    box-shadow: 0 10px 20px -5px rgba(0, 0, 0, 0.25);
}

.form-container
{
    max-width: 640px;
    width: -webkit-fill-available;
    width: -moz-available;
    margin-inline: auto;
    padding: 20px;
    border-radius: var(--border-radius);
    transition: var(--transition);
}

.form
{
    /*max-width: 360px;*/
    width: -webkit-fill-available;
    width: -moz-available;
    margin-inline: auto;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 20px;
    transition: var(--transition);
}

.input-set
{
    width: -webkit-fill-available;
    width: -moz-available;
    padding: 20px;
    display: grid;
    gap: 20px;
    transition: var(--transition);
}

.input-set-border
{
    width: -webkit-fill-available;
    width: -moz-available;
    padding: 20px;
    display: grid;
    gap: 20px;
    border: 2px solid rgba(0, 0, 0, 0.10);
    border-radius: 10px;
    transition: var(--transition);
}

.input-group-block
{
    width: -webkit-fill-available;
    width: -moz-available;
    padding: 10px;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 20px;
    border-radius: var(--border-radius);
    transition: var(--transition);
}

.input-group-border
{
    width: -webkit-fill-available;
    width: -moz-available;
    padding: 10px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 10px;
    position: relative;
    border: 2px solid rgba(0, 0, 0, 0.10);
    border-radius: 10px;
    transition: var(--transition);
}

.input-group-rows
{
    width: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 20px;
    transition: var(--transition);
}

.input-group-cols
{
    width: -webkit-fill-available;
    width: -moz-available;
    display: flex;
    flex-direction: row;
    /*align-items: center;*/
    gap: 20px;
    transition: var(--transition);
}

.input-group-wrap
{
    width: 100%;
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 20px;
    transition: var(--transition);
}

.input-block
{
    width: -webkit-fill-available;
    width: -moz-available;
    padding: 15px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 10px;
    position: relative;
    background-color: var(--second-color);
    border: 2px solid transparent;
    border-radius: 10px;
    transition: var(--transition);
}

.input-block-rounded
{
    width: -webkit-fill-available;
    width: -moz-available;
    padding: 5px;
    padding-left: 15px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 10px;
    position: relative;
    background-color: var(--third-color);
    border-bottom: 2px solid transparent;
    border-radius: var(--border-radius-round);
    transition: var(--transition);
}

.input-check
{
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 10px;
    border: 2px solid transparent;
    border-radius: 10px;
    transition: var(--transition);
}

.input-icon
{
    max-width: 30px;
    width: auto;
    height: auto;
}

.input-text
{
    width: 100%;
    text-align: left;
}

.input-label
{
    width: fit-content;
    height: fit-content;
    margin: auto;
    display: flex;
    align-items: center;
    gap: 5px;
    position: absolute;
    top: 0;
    bottom: 0;
    left: 15px;
    z-index: 0;
    font-family: montserrat-regular;
    pointer-events: none;
    transition: var(--transition);
}

.input:not(:placeholder-shown) ~ .input-label, .input:placeholder-shown:focus ~ .input-label
{
    /*margin: 0;*/
    top: -60%;
    font-size: var(--third-text);
}

.input-separator
{
    width: -webkit-fill-available;
    width: -moz-available;
    border-bottom: 2px solid var(--second-color);
    transition: var(--transition);
}

.input-error
{
    border-color: var(--red);
}

.input-error .input-label
{
    color: var(--red);
}

.input-error .input-label::after
{
    content: "";
}

.input-error:has([type=checkbox]), .input-error:has([type=radio])
{
    border-color: var(--red);
}





.btn
{
    width: max-content;
    margin-inline: auto;
    padding: 10px;
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 10px;
    position: relative;
    font-family: montserrat-bold;
    font-size: var(--main-text);
    color: var(--third-color);
    background-color: var(--main-color);
    border: 2px solid var(--main-color);
    border-radius: var(--border-radius-round);
    transition: var(--transition);
}

.btn:hover, .btn.btn-active
{
    cursor: pointer;
    color: var(--main-color);
    background-color: var(--third-color);
    border-color: var(--main-color);
}

.btn-white
{
    width: max-content;
    margin-inline: auto;
    padding: 10px;
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 10px;
    position: relative;
    font-family: montserrat-bold;
    font-size: var(--main-text);
    color: var(--main-color);
    background-color: var(--third-color);
    border: 2px solid var(--third-color);
    border-radius: var(--border-radius-round);
    transition: var(--transition);
}

.btn-white:hover, .btn-white.btn-active
{
    cursor: pointer;
    color: var(--third-color);
    background-color: var(--main-color);
    border-color: var(--third-color);
}

.btn-full
{
    /*margin: auto;*/
    padding: 15px;
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 10px;
    font-family: montserrat-bold;
    font-size: var(--main-text);
    color: var(--third-color);
    background-color: var(--main-color);
    border: 2px solid var(--main-color);
    border-radius: 10px;
    transition: var(--transition);
}

.btn-full:hover
{
    color: var(--main-color);
    cursor: pointer;
    background-color: var(--third-color);
    border-color: var(--main-color);
}

.btn-outline
{
    width: max-content;
    margin-inline: auto;
    padding: 10px;
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 10px;
    position: relative;
    font-family: montserrat-bold;
    color: var(--main-color);
    background-color: transparent;
    border: 2px solid var(--main-color);
    border-radius: var(--border-radius-round);
    transition: var(--transition);
}

.btn-outline:hover, .btn-outline.btn-active
{
    cursor: pointer;
    color: var(--third-color);
    background-color: var(--main-color);
}

.btn-outline-red
{
    width: max-content;
    margin-inline: auto;
    padding: 10px;
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 10px;
    position: relative;
    font-family: montserrat-bold;
    color: var(--red);
    background-color: transparent;
    border: 2px solid var(--red);
    border-radius: var(--border-radius-round);
    transition: var(--transition);
}

.btn-outline-red:hover, .btn-outline-red.btn-active
{
    cursor: pointer;
    color: var(--third-color);
    background-color: var(--red);
}

.btn-fill
{
    width: max-content;
    margin: auto;
    padding: 10px;
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 10px;
    position: relative;
    font-family: montserrat-regular;
    color: var(--main-color);
    background-color: transparent;
    border: 2px solid var(--border-color);
    border-radius: var(--border-radius-round);
    transition: var(--transition);
}

.btn-fill:hover, .btn-fill.btn-active
{
    cursor: pointer;
    color: var(--second-color);
    background-color: var(--main-color);
    border-color: var(--main-color);
}

.btn-text
{
    width: fit-content;
    width: -moz-fit-content;
    margin: auto;
    padding: 10px;
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 10px;
    font-size: var(--main-text);
    font-family: montserrat-regular;
    color: var(--main-color);
    background-color: transparent;
    border: 2px solid transparent;
    border-radius: var(--border-radius-round);
    transition: var(--transition);
}

.btn-text:hover
{
    cursor: pointer;
    border-color: var(--border-color);
}

.btn-text
{
    width: fit-content;
    width: -moz-fit-content;
    margin: auto;
    padding: 10px;
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 10px;
    font-size: var(--main-text);
    font-family: montserrat-regular;
    color: var(--main-color);
    background-color: transparent;
    border: 2px solid transparent;
    border-radius: var(--border-radius-round);
    transition: var(--transition);
}

.btn-text:hover
{
    cursor: pointer;
    border-color: var(--border-color);
}

.btn-link
{
    width: fit-content;
    width: -moz-fit-content;
    padding: 2.5px;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 5px;
    position: relative;
    font-family: montserrat-bold;
    color: var(--main-color);
    border-bottom: 2px solid transparent;
    transition: var(--transition);
}

.btn-link:hover, .btn-link-active
{
    cursor: pointer;
    color: var(--main-color);
    border-color: var(--main-color);
}

.btn-circle
{
    width: fit-content;
    padding: 10px;
    display: flex;
    justify-content: center;
    align-items: center;
    border: 2px solid var(--main-color);
    border-radius: var(--border-radius-round);
    transition: var(--transition);
}

.btn-circle:hover
{
    cursor: pointer;
    color: var(--third-color);
    background-color: var(--main-color);
}

.btn-whatsapp
{
    padding: 15px;
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: var(--super-text);
    position: fixed;
    bottom: 100px;
    right: 20px;
    z-index: 5;
    color: var(--third-color);
    background-color: var(--whatsapp);
    border: 2px solid var(--whatsapp);
    box-shadow: 0 20px 30px -10px rgba(0, 0, 0, 0.75);
    border-radius: var(--border-radius-round);
    transition: var(--transition);
}

.btn-whatsapp:hover
{
    cursor: pointer;
    color: var(--whatsapp);
    background-color: var(--third-color);
}

.action-btn:hover
{
    cursor: pointer;
}

/*================================================*/



/*==================================================
POPUPS
==================================================*/

.popup
{
    width: auto;
    height: auto;
    margin: auto;
    display: flex;
    justify-content: center;
    align-items: center;
    position: fixed;
    inset: 0;
    z-index: 10;
    background-color: var(--popup-bg);
    backdrop-filter: blur(2.5px);
    border: none;
    transition: all var(--transition), opacity 0;
}

.popup-container
{
    max-width: 640px;
    max-height: 480px;
    min-height: 380px;
    width: -webkit-fill-available;
    width: -moz-available;
    height: -webkit-fill-available;
    height: -moz-available;
    display: grid;
    grid-template-areas: 
        "popupheader"
        "popupmain"
        "popupfooter"
    ;
    grid-template-columns: 1fr;
    grid-template-rows: auto 1fr auto;
    color: var(--text-color);
    background-color: var(--bg);
    border-radius: var(--border-radius);
    box-shadow: 0 100px 100px -10px var(--shadow);
    overflow: hidden;
    /*transition: var(--transition);*/
}

.popup-header
{
    grid-area: popupheader;
    margin: 10px 20px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 20px;
    position: relative;
    top: 0;
    right: 0;
    z-index: 2;
    font-weight: bold;
    /*transition: var(--transition);*/
}

.popup-title
{
    font-size: var(--big-text);
    font-weight: bold;
}

.popup-content
{
    grid-area: popupmain;
    width: 100%;
    height: 100%;
    margin: auto;
    display: flex;
    justify-content: center;
    align-items: center;
    text-align: center;
    overflow-y: scroll;
    -webkit-overflow-scrolling: touch;
    scroll-behavior: smooth;
    /*transition: var(--transition);*/
}

.popup-info
{
    width: 100%;
    margin: auto;
    padding-inline: 20px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    /*font-size: var(--big-text);*/
    /*transition: var(--transition);*/
}

.popup-icon
{
    padding: 10px;
}

.popup-footer
{
    grid-area: popupfooter;
    margin: 10px;
    padding: 10px;
    display: grid;
    grid-auto-flow: column;
    grid-auto-columns: 1fr;
    justify-content: space-between;
    align-items: center;
    gap: 20px;
    position: relative;
    z-index: 2;
    /*font-weight: bold;*/
    text-align: center;
    transition: var(--transition);
}

.popup-header-options
{
    display: flex;
    gap: 20px;
}

.popup-close
{
    width: fit-content;
    width: -moz-fit-content;
    height: fit-content;
    height: -moz-fit-content;
    padding: 10px;
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 10px;
    font-size: var(--main-text);
    font-family: montserrat-regular;
    color: var(--main-color);
    background-color: var(--second-color);
    border: 2px solid transparent;
    border-radius: var(--border-radius-round);
    transition: var(--transition);
}

.popup-close:hover
{
    cursor: pointer;
    color: var(--main-color);
    background-color: transparent;
    border-color: var(--border-color);
}





.popup-full
{
    /*padding: 0;*/
}

.popup-full .popup-container
{
    max-width: unset;
    max-height: unset;
    min-height: unset;
    height: -webkit-fill-available;
    height: -moz-available;
    /*border-radius: unset;*/
}

.popup-full .popup-info
{
    height: -webkit-fill-available;
    height: -moz-available;
    gap: 40px;
    flex-direction: row;
}

.popup-sidebar
{
    max-width: 280px;
    width: 100%;
    height: -webkit-fill-available;
    height: -moz-available;
    padding: 20px;
    display: flex;
    z-index: 1;
    position: sticky;
    top: 0;
    background-color: var(--second-color);
    box-shadow: 10px 0 25px -10px rgba(0, 0, 0, 0.20);
    /*overflow: hidden;*/
    /*transition: var(--transition);*/
}

.popup-sidebar-content
{
    width: 100%;
    height: -webkit-fill-available;
    height: -moz-available;
    /*overflow: hidden;*/
}

.popup-sidebar-item
{
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 10px;
    border-top: 1px solid var(--main-color);
    border-bottom: 1px solid transparent;
    transition: var(--transition);
}





#popup-cart .popup-container, 
#popup-login .popup-container, 
#popup-register .popup-container, 
#popup-tickets .popup-container, 
#popup-billing .popup-container, 
#popup-holder .popup-container
{
    max-height: unset;
    /*height: max-content;*/
}

#popup-cart .popup-info, 
#popup-login .popup-info, 
#popup-register .popup-info, 
#popup-tickets .popup-info, 
#popup-billing .popup-info, 
#popup-holder .popup-info
{
    /*margin: unset;*/
}

#popup-payment .popup-container
{
    color: var(--third-color);
    background-color: var(--whatsapp);
}





.loading-message
{
    width: 100%;
    height: 100%;
    margin: auto;
    display: flex;
    justify-content: center;
    align-items: center;
    position: fixed;
    inset: 0;
    z-index: 12;
    background-color: rgba(255, 255, 255, 0.5);
    border: none;
    transition: var(--transition);
}

.loading-message-text
{
    padding: 50px;
    position: relative;
    z-index: 1;
    font-size: var(--big-text);
    color: var(--fourth-color);
    background-color: var(--main-color);
    border-radius: 25px;
}

/*================================================*/



/*==================================================
WEBKIT SCROLL
==================================================*/

::-webkit-scrollbar
{
	width: 12.5px;
	height: 0;
}

::-webkit-scrollbar-thumb
{
    border: 3px solid transparent;
	border-radius: var(--border-radius-round);
    box-shadow: var(--scroll-margin);
}

/*================================================*/



/*==================================================
RESPONSIVE
==================================================*/

@media (max-width: 1280px)
{
    :root
    {
        --max-width: 960px;
        --margin: 30px;
        --padding: 20px;
        --ultra-text: 42px;
        --super-text-x2: 32px;
        --super-text: 24px;
        --big-text: 20px;
        --main-text: 13px;
        --second-text: 13px;
        --third-text: 11px;
    }

    .header-container
    {
        padding: 15px;
    }

    .subnav
    {
        padding: 15px;
        top: 120px;
    }

    .logo-feria
    {
        max-width: 130px;
    }

    .footer-logo
    {
        max-width: 240px;
    }

    .footer-img
    {
        max-width: 120px;
    }

    .section-header
    {
        height: 30vh;
    }

    .section
    {
        padding: 50px 30px;
    }

    .section-banner-option
    {
        padding: 15px;
    }

    .btn-whatsapp
    {
        bottom: 100px;
        right: 30px;
    }

    .block-gallery
    {
        gap: 75px;
    }

    .block-gallery-img
    {
        height: 40px;
    }

    .block-content
    {
        padding: 30px;
    }

    .padding100
    {
        padding: 50px !important;
    }
}

@media (max-width: 1080px)
{
    :root
    {
        
    }
}

@media (max-width: 960px)
{
    :root
    {
        --max-width: 960px;
        --margin: 30px;
        --padding: 20px;
        --ultra-text: 32px;
        --super-text-x2: 24px;
        --super-text: 20px;
        --big-text: 16px;
        --main-text: 13px;
        --second-text: 13px;
        --third-text: 11px;
    }

    #body
    {
        
    }

    #header
    {
        padding: 10px;
    }

    .header-container
    {
        padding: 0 10px;
        grid-template-areas: 
            "logo profile mobilenav"
            "nav nav nav"
        ;
        grid-template-columns: 1fr auto auto;
        grid-template-rows: auto 1fr;
        gap: 0;
        align-items: center;
        /*align-items: center;*/
        overflow: auto;
    }

    #profile .btn
    {
        padding: 10px;
    }

    .logo
    {
        max-width: 75px;
    }

    .logo-text
    {
        font-size: var(--main-text);
    }

    .logo-feria
    {
        max-width: 100px;
    }

    #nav
    {
        width: auto;
        padding-bottom: env(safe-area-inset-bottom);
        flex-direction: column;
        inset: auto 0 0 0;
        background-color: var(--bg1);
        display: none;
        /* -webkit-backdrop-filter: blur(10px); */
        /* backdrop-filter: blur(10px);*/

    }

    #nav .nav
    {
        padding: 20px;
        flex-direction: column;
    }

    #profile
    {
        margin-bottom: auto;
        padding: 10px;
        /*display: none;*/
    }

    #profile .nav
    {
        flex-direction: column;
    }

    .nav-group-rows
    {
        flex-direction: column;
    }

    .nav-item
    {
        font-size: var(--big-text);
    }

    .nav-show{display: flex !important;}
    .nav-hide{display: none !important;}

    .mobile-nav
    {
        display: flex;
    }

    .mobile-body{overflow-y: hidden;}

    .subnav
    {
        top: 79px;
    }

    .section-header
    {
        height: 20vh;
    }

    .section-banner-h-cut
    {

    }

    .section-header-title
    {
        padding-top: 75px;
    }

    .section-banner-info
    {
        /*margin-top: 0;*/
        /*line-height: 1;*/
    }

    .section-banner-option
    {
        padding: 10px;
    }

    .input-set
    {
        padding: 0;
    }

    .input-group-cols
    {
        flex-direction: column;
    }

    #footer
    {
        overflow: scroll hidden;
        -webkit-overflow-scrolling: touch;
    }

    .footer-logo
    {
        max-width: 180px;
    }

    .footer-img
    {
        max-width: 100px;
    }

    .section
    {
        padding: 50px 20px;
    }

    .section-columns
    {
        grid-template-columns: 1fr;
    }

    .post-logo
    {
        max-width: 260px;
    }

    .block-columns
    {
        grid-auto-flow: unset;
        /*grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));*/
    }

    .block-content
    {
        padding: 20px;
    }

    .block-img
    {
        height: 160px;
    }

    .block-gallery
    {
        gap: 50px;
    }

    .block-gallery-img
    {
        height: 30px;
    }

    .btn-whatsapp
    {
        padding: 10px;
        bottom: 100px;
        right: 20px;
    }





    .block-profile-img
    {
        max-width: 100px;
        /*max-height: 100px;*/
    }





    .tickets-tabs
    {
        padding: 20px;
    }





    .tickets-cards
    {
        padding: 0;
        grid-template-columns: 1fr;
    }

    .tickets-card-info
    {
        padding: 10px;
    }





    .ticketbook-ticket
    {
        padding: 20px;
        display: flex;
        flex-direction: column;
        justify-content: space-between;
        align-items: center;
        gap: 20px;
        position: relative;
        /*background-color: var(--second-color);*/
        border-radius: var(--border-radius);
        transition: all var(--transition), opacity 0;
    }

    .ticketbook-ticket-info
    {
        text-align: center;
    }

    .ticket-status
    {
        margin-inline: auto;
    }





    .post-list-item
    {
        flex-direction: column;
        justify-content: space-between;
        align-items: flex-start;
        gap: 5px;
    }





    .popup
    {
        padding: 0;
        align-items: flex-end;
    }

    .popup-container
    {
        max-width: unset;
        max-height: 64%;
        min-height: unset;
        border-radius: var(--border-radius) var(--border-radius) 0 0;
        box-shadow: 0 0px 50px -10px rgba(0, 0, 0, 0.75);
    }

    .popup-info
    {
        
    }

    .popup-full
    {
        padding-top: 20px;
    }

    .popup-sidebar
    {
        max-width: unset;
        width: -webkit-fill-available;
        width: -moz-available;
        height: fit-content;
        height: -moz-fit-content;
        padding: 0;
        display: flex;
        flex-direction: column;
        gap: 10px;
        flex-shrink: 0;
        box-shadow: none;
        /* border-bottom: 1px solid var(--main-color); */
        /* overflow-x: scroll; */
        /* scroll-behavior: smooth; */
    }

    .popup-full .popup-info
    {
        display: grid;
        grid-template-columns: 1fr;
    }

    .popup-footer
    {
        /*display: none;*/
    }
}

@media (max-width: 640px)
{
    :root
    {
        --ultra-text: 24px;
    }
}

@media (max-width: 480px)
{
	
}

/*================================================*/



/*==================================================
UTILITIES
==================================================*/

.margin{margin: var(--margin);}
.marginauto{margin: auto;}
.margin-right-auto{margin-right: auto;}
.margin-inline-auto{margin-inline: auto;}
.nomargin{margin: 0;}
.padding{padding: var(--padding);}
.padding-v{padding: 10px 0;}
.nopadding{padding: 0 !important;}
.nopaddingtop{padding-top: 0 !important;}
.nopaddingbottom{padding-bottom: 0 !important;}
.nopaddingblock{padding-block: 0 !important;}
.nopaddinginline{padding-inline: 0 !important;}
.padding20{padding: 20px;}
.padding50{padding: 50px;}
.padding100{padding: 100px;}
.padding-submenu{padding: 20px 100px !important;}

.width-full{width: 100% !important;}
.height-full{height: 100% !important;}
.width-fit{width: fit-content !important; width: -moz-fit-content !important;}
.height-fit{height: fit-content !important; height: -moz-fit-content !important;}
.width-auto{width: auto !important;}
.height-auto{height: auto !important;}
.max-width-unset{max-width: unset;}

.text-capitalize{text-transform: capitalize !important;}

.text-left{text-align: left !important;}
.text-right{text-align: right;}
.text-center{text-align: center;}
.text-justify{text-align: justify;}

.justify-content-start{justify-content: start !important;}
.justify-content-center{justify-content: center !important;}
.justify-content-end{justify-content: end !important;}
.justify-content-between{justify-content: space-between !important;}
.justify-self-start{justify-self: start !important;}
.justify-self-center{justify-self: center !important;}
.justify-self-end{justify-self: end !important;}
.align-content-start{align-content: start !important;}
.align-content-end{align-content: end !important;}
.align-content-center{align-content: center !important;}
.align-items-start{align-items: start !important;}
.align-items-end{align-items: end !important;}
.align-items-center{align-items: center !important;}
.align-self-start{align-self: start !important;}
.align-self-end{align-self: end !important;}
.align-self-center{align-self: center !important;}

.grid-col-full{grid-column: 1 / -1;}
.grid-col{grid-column: span 1;}
.grid-col-x1-5{grid-column: span 1.5;}
.grid-col-x2{grid-column: span 2;}
.grid-col-x3{grid-column: span 3;}
.grid-col-x4{grid-column: span 4;}

.grid-row-full{grid-row: 1 / -1;}
.grid-row{grid-row: span 1;}
.grid-row-x1-5{grid-row: span 1.5;}
.grid-row-x2{grid-row: span 2;}
.grid-row-x3{grid-row: span 3;}
.grid-row-x4{grid-row: span 4;}

.flex{flex: 1;}
.flex-noshrink{flex-shrink: 0;}

.gap50{gap: 50px}
.gap30{gap: 30px}
.gap25{gap: 25px}
.gap20{gap: 20px}
.gap10{gap: 10px}
.nogap{gap: 0}

.opacity95{opacity: 0.95;}
.opacity90{opacity: 0.90;}
.opacity85{opacity: 0.85;}
.opacity80{opacity: 0.80;}
.opacity75{opacity: 0.75;}
.opacity70{opacity: 0.70;}
.opacity50{opacity: 0.50;}
.opacity25{opacity: 0.25;}
.opacity20{opacity: 0.20;}
.opacity10{opacity: 0.10;}
.opacity05{opacity: 0.05;}
.opacity025{opacity: 0.025;}
.opacity020{opacity: 0.020;}
.opacity015{opacity: 0.015;}
.opacity010{opacity: 0.010;}
.opacity005{opacity: 0.005;}
.opacity0{opacity: 0;}

.absolute{position: absolute;}
.top{top: 0;}
.right{right: 0;}
.bottom{bottom: 0;}
.left{left: 0;}
.center{top: 0; right: 0; bottom: 0; left: 0;}

.object-position-top{object-position: top;}
.object-position-right{object-position: right;}
.object-position-bottom{object-position: bottom;}
.object-position-left{object-position: left;}
.object-position-center{object-position: center;}

.fixed{position: fixed !important;}
.sticky-top{position: sticky !important; top: 0;}
.sticky-bottom{position: sticky !important; bottom: 0;}

.display-none
{
    display: none;
    opacity: 0;
}

.text-shadow{text-shadow: 0 10px 20px rgba(0, 0, 0, 0.50);}
.shadow{box-shadow: 0 10px 50px 0px rgba(0, 0, 0, 0.50);}
.drop-shadow{filter: drop-shadow(0px 20px 20px rgb(0, 0, 0, 0.50));}
.grayscale-filter{filter: grayscale(1);}
.backdrop-filter{-webkit-backdrop-filter: blur(20px); backdrop-filter: blur(20px);}

.mixblend-color{mix-blend-mode: color;}

.border-botton{border-bottom: 7.5px solid var(--second-color);}
.border-right-white{border-right: 5px solid white;}
.border-radius{border-radius: var(--border-radius);}
.border-radius-round{border-radius: var(--border-radius-round);}
.noborder-radius{border-radius: 0;}

.overflow-hidden{overflow: hidden;}
.overflow-unset{overflow: unset !important;}

[data-color="blue"]{color: var(--blue);}
[data-color="skyblue"]{color: var(--skyblue);}
[data-color="green"]{color: var(--green);}
[data-color="red"]{color: var(--red);}
[data-color="yellow"]{color: var(--yellow);}

[data-bgcolor="blue"]{background-color: var(--blue);}
[data-bgcolor="skyblue"]{background-color: var(--skyblue);}
[data-bgcolor="green"]{background-color: var(--green);}
[data-bgcolor="red"]{background-color: var(--red);}
[data-bgcolor="yellow"]{background-color: var(--yellow);}

[data-bordercolor="blue"]{border-color: var(--blue);}
[data-bordercolor="skyblue"]{border-color: var(--skyblue);}
[data-bordercolor="green"]{border-color: var(--green);}
[data-bordercolor="red"]{border-color: var(--red);}
[data-bordercolor="yellow"]{border-color: var(--yellow);}

[data-gradient="blue"]{background-image: linear-gradient(to top, var(--blue), transparent);}
[data-gradient="skyblue"]{background-image: linear-gradient(to top, var(--skyblue), transparent);}
[data-gradient="green"]{background-image: linear-gradient(to top, var(--green), transparent);}
[data-gradient="red"]{background-image: linear-gradient(to top, var(--red), transparent);}
[data-gradient="yellow"]{background-image: linear-gradient(to top, var(--yellow), transparent);}

[data-anim], [data-postanim]{opacity: 0;}

/*================================================*/





@media print
{
    @page
    {
        margin: 0;
        padding: 0;
        size: 9.7cm 11.3cm;
    }

    .ticketbook
    {
        max-width: 9.7cm;
        width: 100%;
        margin: auto;
        display: grid;
        /*grid-template-columns: auto auto;*/
        justify-content: center;
        gap: 0;
    }

    .ticketbook-ticket
    {
        all: unset;
        width: 9.7cm;
        height: 11.3cm;
        padding: 0;
        display: flex;
        flex-direction: column;
        justify-content: center;
        align-items: center;
        gap: 10px;
        position: relative;
        text-align: center;
        /*background-color: var(--second-color);*/
        /*border: 2px dashed var(--second-color);*/
        border: none;
        border-radius: unset;
        transition: all var(--transition), opacity 0;
    }

    .ticketbook-ticket-info
    {
        display: none;
        text-align: center;
    }

    .ticketbook-ticket-code
    {
        width: 2.70cm;
        height: auto;
        display: flex;
        justify-content: center;
        align-items: center;
        position: relative;
        inset: auto;
        border: 2px solid var(--main-color);
        border-radius: 10px;
    }

    .ticketbook-ticket-img
    {
        margin: 0;
        padding: 5px;
    }

    .ticket-user
    {
        display: block;
    }

    .ticket-name
    {
        padding-inline: 10px;
        font-family: montserrat-bold;
        text-transform: uppercase;
        font-size: 24px;
    }

    .ticket-product
    {
        padding-inline: 10px;
        font-family: montserrat-bold;
        text-transform: uppercase;
        font-size: 14px;
        display: block;
    }

    .ticket-bg
    {
        width: 100%;
        height: 100%;
        object-fit: cover;
        object-position: center;
        position: absolute;
        inset: 0;
        z-index: -1;
        display: block;
    }

    .ticket-download
    {
        display: none;
    }

    .ticket-status
    {
        margin-inline: auto;
    }
    .ticketbook-ticket:nth-child(0n)
    {
        page-break-after: always;
    }
}