.elementor-kit-7{--e-global-color-primary:#6EC1E4;--e-global-color-secondary:#54595F;--e-global-color-text:#7A7A7A;--e-global-color-accent:#61CE70;--e-global-color-972fe72:#444444;--e-global-color-3332fc1:#CC0000;--e-global-color-3829ad3:#F2F2F2;--e-global-color-abaa754:#AFACAC;--e-global-color-bd41be5:#FFFFFF;--e-global-typography-primary-font-family:"Roboto";--e-global-typography-primary-font-weight:600;--e-global-typography-secondary-font-family:"Roboto Slab";--e-global-typography-secondary-font-weight:400;--e-global-typography-text-font-family:"Roboto";--e-global-typography-text-font-weight:400;--e-global-typography-accent-font-family:"Roboto";--e-global-typography-accent-font-weight:500;background-color:var( --e-global-color-bd41be5 );color:var( --e-global-color-972fe72 );font-family:"mundial", Sans-serif;font-size:20px;font-weight:300;line-height:1.4em;}.elementor-kit-7 e-page-transition{background-color:#FFBC7D;}.elementor-kit-7 h1{font-size:72px;font-weight:600;line-height:1em;}.elementor-kit-7 h2{font-size:32px;font-weight:600;line-height:1.2em;}.elementor-kit-7 h3{font-size:30px;font-weight:300;line-height:1.2em;}.elementor-kit-7 h4{font-size:25px;font-weight:400;line-height:1.2em;}.elementor-kit-7 h5{font-size:23px;font-weight:600;line-height:1.2em;}.elementor-kit-7 h6{font-size:18px;font-weight:600;line-height:1.2em;}.elementor-kit-7 button,.elementor-kit-7 input[type="button"],.elementor-kit-7 input[type="submit"],.elementor-kit-7 .elementor-button{font-size:20px;font-weight:600;text-decoration:underline;line-height:1em;}.elementor-section.elementor-section-boxed > .elementor-container{max-width:1920px;}.e-con{--container-max-width:1920px;--container-default-padding-top:0px;--container-default-padding-right:0px;--container-default-padding-bottom:0px;--container-default-padding-left:0px;}.elementor-widget:not(:last-child){margin-block-end:40px;}.elementor-element{--widgets-spacing:40px 40px;--widgets-spacing-row:40px;--widgets-spacing-column:40px;}{}h1.entry-title{display:var(--page-title-display);}.site-header .site-branding{flex-direction:column;align-items:stretch;}.site-header{padding-inline-end:0px;padding-inline-start:0px;}.site-footer .site-branding{flex-direction:column;align-items:stretch;}@media(max-width:1500px){.elementor-kit-7 h1{font-size:56px;}}@media(max-width:1024px){.elementor-kit-7{font-size:16px;}.elementor-kit-7 h1{font-size:40px;}.elementor-kit-7 h2{font-size:25px;}.elementor-kit-7 h3{font-size:22px;}.elementor-kit-7 h4{font-size:20px;}.elementor-kit-7 h5{font-size:17px;}.elementor-kit-7 h6{font-size:14px;}.elementor-kit-7 button,.elementor-kit-7 input[type="button"],.elementor-kit-7 input[type="submit"],.elementor-kit-7 .elementor-button{font-size:16px;}.elementor-section.elementor-section-boxed > .elementor-container{max-width:1024px;}.e-con{--container-max-width:1024px;}}@media(max-width:767px){.elementor-kit-7 h1{font-size:32px;}.elementor-section.elementor-section-boxed > .elementor-container{max-width:767px;}.e-con{--container-max-width:767px;}}/* Start custom CSS *//* Custom Button*/
.third-button a {
    padding: 0;
    background-color: transparent;
    color: #CC0000!important;
}

.third-button a:hover {
    color: #AFACAC!important;
}

.third-button .elementor-button-text:before {
    content: "* ";
}

/* ============================================================
   Custom Product Card
============================================================ */
.product-card {
    background: #ffffff;
    border: 1px solid #444444;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    height: 100%;
}

.product-image {
    width: 100%;
    /*aspect-ratio: 16/9;*/
    background: #f5f5f5;
    overflow: hidden;
}

.product-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.3s ease;
}

.product-image a:hover img {
    transform: scale(1.05);
}

.product-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 32px 32px 16px 32px;
    align-items: center;
}

.product-header h4,
.product-header h5 {
    margin-block-end: 0 !important;
    margin-block-start: 0 !important;
    margin: 0 !important;
}

.product-title a {
    color: #444444;
    text-decoration: none;
    transition: color 0.2s ease;
}

.product-title a:hover {
    color: #CC0000;
}

.product-year {
    white-space: nowrap;
}

.product-meta {
    padding: 0px 32px 32px 32px;
    color: #444444;
}

.product-meta p {
    margin: 0;
    margin-top: 4px;
}

.product-meta a {
    color: #CC0000;
    text-decoration: underline;
}

@media (max-width: 1500px) {
    .product-header {
        padding: 24px 24px 16px 24px;
    }

    .product-meta {
        padding: 0 24px 24px 24px;
    }
}

/* ============================================================
   Griglia prodotti e fallback message
============================================================ */
.products-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 40px;
    padding: 32px 0;
}

.fallback-message {
    padding: 32px 0;
    font-size: 18px;
    font-weight: 300;
    color: #AFACAC;
}

@media (max-width: 1500px) {
    .products-grid {
        gap: 24px;
    }
}

@media (max-width: 1024px) {
    .products-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 16px;
    }
}

@media (max-width: 767px) {
    .products-grid {
        grid-template-columns: repeat(1, 1fr);
    }
}

/* ============================================================
   Shortcode Timeline e Ordine Alfabetico
============================================================ */

/* Desktop vs Mobile */
.desktop-only {
    display: block;
}

.mobile-only {
    display: none;
}

@media (max-width: 767px) {
    .desktop-only {
        display: none;
    }

    .mobile-only {
        display: block;
    }
}

/* Barra desktop */
.timeline-filters-wrapper,
.alphabet-filters-wrapper {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}

.timeline-filters,
.alphabet-filters {
    display: flex;
    gap: 32px;
    min-width: max-content;
    justify-content: center;
    border-style: solid;
    border-color: #AFACAC;
    border-width: 0 0 2px 0;
}

.timeline-filter,
.alphabet-filter {
    padding: 0 0 12px 0;
    white-space: nowrap;
    cursor: pointer;
    border-radius: 4px;
    color: #AFACAC;
    text-decoration: none !important;
    background-color: transparent !important;
    font-size: 23px !important;
    border-color: #ffffff;
    border-width: 0 0 4px 0;
    border-radius: 0;
}

.timeline-filter:hover,
.alphabet-filter:hover {
    background-color: transparent;
    color: #AFACAC;
}

.timeline-filter.active,
.alphabet-filter.active {
    color: #444444;
    background-color: transparent !important;
    border-style: solid;
    border-color: #444444;
    border-width: 0 0 4px 0;
    border-radius: 0;
}

@media (max-width: 1500px) {
    .timeline-filters,
    .alphabet-filters {
        gap: 24px;
    }

    .timeline-filter,
    .alphabet-filter {
        font-size: 20px !important;
    }
}

@media (max-width: 1024px) {
    .timeline-filters,
    .alphabet-filters {
        gap: 16px;
    }

    .timeline-filter,
    .alphabet-filter {
        font-size: 16px !important;
    }
}

/* ============================================================
   Shortcode Product with Toggle/Accordion
============================================================ */
.accordion-item:last-child {
    border: solid 1px #444444;
    border-width: 0 0 1px 0;
}

.accordion-toggle {
    width: 100%;
    text-align: left;
    background: transparent;
    border-radius: 0;
    border: solid 1px #444444;
    border-width: 1px 0 0 0;
    padding: 32px 0;
    cursor: pointer;
    font-weight: 400 !important;
    position: relative;
    padding-right: 24px;
    text-decoration: none !important;
    color: #AFACAC;
    font-size: 23px !important;
    white-space: normal;
    display: flex;
    align-items: center;
}

.accordion-toggle:hover {
    background: transparent;
    color: #CC0000;
}

.accordion-toggle::after {
    content: "+";
    font-size: 23px;
    position: absolute;
    right: 0;
    transition: transform 0.2s ease;
}

.accordion-toggle.active {
    background: transparent;
    color: #444444;
    padding: 32px 24px 0 0;
}

.accordion-toggle.active::after {
    content: "−";
}

.accordion-content {
    display: none;
}

@media (max-width: 1500px) {
    .accordion-toggle {
        font-size: 20px !important;
    }
}

@media (max-width: 1024px) {
    .accordion-toggle {
        padding: 24px 0;
        font-size: 20px !important;
        padding-right: 48px;
    }

    .accordion-toggle.active {
        padding: 24px 48px 0 0;
    }
}/* End custom CSS */