/*!
Theme Name: GBS
Theme URI: https://www.gbs-group.it/
Author: Global Business Solution S.r.l.
Author URI: https://www.gbs-group.it/
Description: GBS Custom WordPress Theme. This theme is not available for you to download or buy.
Version: 1.0.0
Tested up to: 5.4
Requires PHP: 5.6
License: GNU General Public License v2 or later
License URI: LICENSE
Text Domain: gbs
Tags: custom-background, custom-logo, custom-menu, featured-images, threaded-comments, translation-ready

This theme, like WordPress, is licensed under the GPL.
Use it to make something cool, have fun, and share what you've learned.

GBS is based on Underscores https://underscores.me/, (C) 2012-2020 Automattic, Inc.
Underscores is distributed under the terms of the GNU GPL v2 or later.

Normalizing styles have been helped along thanks to the fine work of
Nicolas Gallagher and Jonathan Neal https://necolas.github.io/normalize.css/
*/

/*--------------------------------------------------------------
>>> TABLE OF CONTENTS:
----------------------------------------------------------------
# Generic
	- Normalize
	- Box sizing
# Base
	- Typography
	- Elements
	- Links
	- Forms
## Layouts
# Components
	- Navigation
	- Posts and pages
	- Comments
	- Widgets
	- Media
	- Captions
	- Galleries
# plugins
	- Jetpack infinite scroll
# Utilities
	- Accessibility
	- Alignments

--------------------------------------------------------------*/

/*--------------------------------------------------------------
# Generic
--------------------------------------------------------------*/

/* Normalize
--------------------------------------------- */

/*! normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css */

/* Document
	 ========================================================================== */

/**
 * 1. Correct the line height in all browsers.
 * 2. Prevent adjustments of font size after orientation changes in iOS.
 */
:root {
    --rating-max: 5;
    /*--rating-content: "★★★★★";*/
    --rating-content: "star star star star star";
    --rating-inactive-color: #00000030;
    --rating-background: #000000;
}

html {
    line-height: 1.15;
    -webkit-text-size-adjust: 100%;
}

/* Sections
	 ========================================================================== */

/**
 * Remove the margin in all browsers.
 */
body {
    margin: 0;
}

/**
 * Render the `main` element consistently in IE.
 */
main {
    display: block;
}

/**
 * Correct the font size and margin on `h1` elements within `section` and
 * `article` contexts in Chrome, Firefox, and Safari.
 */
h1, .title-h1 {
    font-size: 2em;
    margin: 0.67em 0;
}

/* Grouping content
	 ========================================================================== */

/**
 * 1. Add the correct box sizing in Firefox.
 * 2. Show the overflow in Edge and IE.
 */
hr {
    box-sizing: content-box;
    height: 0;
    overflow: visible;
}

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */
pre {
    font-family: monospace, monospace;
    font-size: 1em;
}

/* Text-level semantics
	 ========================================================================== */

/**
 * Remove the gray background on active links in IE 10.
 */
a {
    background-color: transparent;
}

/**
 * 1. Remove the bottom border in Chrome 57-
 * 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.
 */
abbr[title] {
    border-bottom: none;
    text-decoration: underline;
    text-decoration: underline dotted;
}

/**
 * Add the correct font weight in Chrome, Edge, and Safari.
 */
b,
strong {
    font-weight: bolder;
}

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */
code,
kbd,
samp {
    font-family: monospace, monospace;
    font-size: 1em;
}

/**
 * Add the correct font size in all browsers.
 */
small {
    font-size: 80%;
}

/**
 * Prevent `sub` and `sup` elements from affecting the line height in
 * all browsers.
 */
sub,
sup {
    font-size: 75%;
    line-height: 0;
    position: relative;
    vertical-align: baseline;
}

sub {
    bottom: -0.25em;
}

sup {
    top: -0.5em;
}

/* Embedded content
	 ========================================================================== */

/**
 * Remove the border on images inside links in IE 10.
 */
img {
    border-style: none;
}

img,
picture,
video,
canvas,
svg {
    display: block;
    max-width: 100%;
}

/* Forms
	 ========================================================================== */

/**
 * 1. Change the font styles in all browsers.
 * 2. Remove the margin in Firefox and Safari.
 */
button,
input,
optgroup,
select,
textarea {
    font-family: inherit;
    font-size: 100%;
    line-height: 1.15;
    margin: 0;
}

/**
 * Show the overflow in IE.
 * 1. Show the overflow in Edge.
 */
button,
input {
    overflow: visible;
}

/**
 * Remove the inheritance of text transform in Edge, Firefox, and IE.
 * 1. Remove the inheritance of text transform in Firefox.
 */
button,
select {
    text-transform: none;
}

/**
 * Correct the inability to style clickable types in iOS and Safari.
 */
button,
[type="button"],
[type="reset"],
[type="submit"] {
    -webkit-appearance: button;
}

/**
 * Remove the inner border and padding in Firefox.
 */
button::-moz-focus-inner,
[type="button"]::-moz-focus-inner,
[type="reset"]::-moz-focus-inner,
[type="submit"]::-moz-focus-inner {
    border-style: none;
    padding: 0;
}

/**
 * Restore the focus styles unset by the previous rule.
 */
button:-moz-focusring,
[type="button"]:-moz-focusring,
[type="reset"]:-moz-focusring,
[type="submit"]:-moz-focusring {
    outline: 1px dotted ButtonText;
}

/**
 * Correct the padding in Firefox.
 */
fieldset {
    padding: 0.35em 0.75em 0.625em;
}

/**
 * 1. Correct the text wrapping in Edge and IE.
 * 2. Correct the color inheritance from `fieldset` elements in IE.
 * 3. Remove the padding so developers are not caught out when they zero out
 *		`fieldset` elements in all browsers.
 */
legend {
    box-sizing: border-box;
    color: inherit;
    display: table;
    max-width: 100%;
    padding: 0;
    white-space: normal;
}

/**
 * Add the correct vertical alignment in Chrome, Firefox, and Opera.
 */
progress {
    vertical-align: baseline;
}

/**
 * Remove the default vertical scrollbar in IE 10+.
 */
textarea {
    overflow: auto;
}

/**
 * 1. Add the correct box sizing in IE 10.
 * 2. Remove the padding in IE 10.
 */
[type="checkbox"],
[type="radio"] {
    box-sizing: border-box;
    padding: 0;
}

/**
 * Correct the cursor style of increment and decrement buttons in Chrome.
 */
[type="number"]::-webkit-inner-spin-button,
[type="number"]::-webkit-outer-spin-button {
    height: auto;
}

/**
 * 1. Correct the odd appearance in Chrome and Safari.
 * 2. Correct the outline style in Safari.
 */
[type="search"] {
    -webkit-appearance: textfield;
    outline-offset: -2px;
}

/**
 * Remove the inner padding in Chrome and Safari on macOS.
 */
[type="search"]::-webkit-search-decoration {
    -webkit-appearance: none;
}

/**
 * 1. Correct the inability to style clickable types in iOS and Safari.
 * 2. Change font properties to `inherit` in Safari.
 */
::-webkit-file-upload-button {
    -webkit-appearance: button;
    font: inherit;
}

/* Interactive
	 ========================================================================== */

/*
 * Add the correct display in Edge, IE 10+, and Firefox.
 */
details {
    display: block;
}

/*
 * Add the correct display in all browsers.
 */
summary {
    display: list-item;
}

/* Misc
	 ========================================================================== */

/**
 * Add the correct display in IE 10+.
 */
template {
    display: none;
}

/**
 * Add the correct display in IE 10.
 */
[hidden] {
    display: none;
}

/* Box sizing
--------------------------------------------- */

/* Inherit box-sizing to more easily change it's value on a component level.
@link http://css-tricks.com/inheriting-box-sizing-probably-slightly-better-best-practice/ */
*,
*::before,
*::after {
    box-sizing: border-box;
}

html {
    box-sizing: border-box;
}

/*--------------------------------------------------------------
# Base
--------------------------------------------------------------*/

/* Typography
--------------------------------------------- */
body,
button,
input,
select,
optgroup,
textarea {
    color: #404040;
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen-Sans, Ubuntu, Cantarell, "Helvetica Neue", sans-serif;
    font-size: 1rem;
    line-height: 1.5;
}

h1,
h2,
h3,
h4,
h5,
h6 {
    clear: both;
    text-wrap: balance;
}

p {
    margin-bottom: 1.5em;
    text-wrap: pretty;
}

p,
h1,
h2,
h3,
h4,
h5,
h6 {
    overflow-wrap: break-word;
}

dfn,
cite,
em,
i {
    font-style: italic;
}

blockquote {
    margin: 0 1.5em;
}

address {
    margin: 0 0 1.5em;
}

pre {
    background: #eee;
    font-family: "Courier 10 Pitch", courier, monospace;
    line-height: 1.6;
    margin-bottom: 1.6em;
    max-width: 100%;
    overflow: auto;
    padding: 1.6em;
}

code,
kbd,
tt,
var {
    font-family: monaco, consolas, "Andale Mono", "DejaVu Sans Mono", monospace;
}

abbr,
acronym {
    border-bottom: 1px dotted #666;
    cursor: help;
}

mark,
ins {
    background: var(--accent-color);
    color: #ffffff;
    padding: 0 5px;
}

big {
    font-size: 125%;
}

/* Elements
--------------------------------------------- */
body {
    background: #fff;
}

hr {
    background-color: #ccc;
    border: 0;
    height: 1px;
    margin-bottom: 1.5em;
}

ul,
ol {
    margin: 0 0 1.5em 3em;
}

ul {
    list-style: disc;
}

ol {
    list-style: decimal;
}

li>ul,
li>ol {
    margin-bottom: 0;
    margin-left: 1.5em;
}

dt {
    font-weight: 700;
}

dd {
    margin: 0 1.5em 1.5em;
}

/* Make sure embeds and iframes fit their containers. */
embed,
iframe,
object {
    max-width: 100%;
}

img {
    height: auto;
    max-width: 100%;
}

figure {
    margin: 1em 0;
}

table {
    margin: 0 0 1.5em;
    width: 100%;
}

/* Links
--------------------------------------------- */
a {
    color: #4169e1;
}

a:visited {
    color: #800080;
}

a:hover,
a:focus,
a:active {
    color: #191970;
}

/*a:focus{
	outline: thin dotted;
}*/

a:hover,
a:active {
    outline: 0;
}

/* Forms
--------------------------------------------- */
button,
input[type="button"],
input[type="reset"],
input[type="submit"] {
    border: 1px solid;
    border-color: #ccc #ccc #bbb;
    border-radius: 3px;
    background: #e6e6e6;
    color: rgba(0, 0, 0, 0.8);
    line-height: 1;
    padding: 0.6em 1em 0.4em;
}

button:hover,
input[type="button"]:hover,
input[type="reset"]:hover,
input[type="submit"]:hover {
    border-color: #ccc #bbb #aaa;
}

button:active,
button:focus,
input[type="button"]:active,
input[type="button"]:focus,
input[type="reset"]:active,
input[type="reset"]:focus,
input[type="submit"]:active,
input[type="submit"]:focus {
    border-color: #aaa #bbb #bbb;
}

input[type="text"],
input[type="email"],
input[type="url"],
input[type="password"],
input[type="search"],
input[type="number"],
input[type="tel"],
input[type="range"],
input[type="date"],
input[type="month"],
input[type="week"],
input[type="time"],
input[type="datetime"],
input[type="datetime-local"],
input[type="color"],
textarea {
    color: #666;
    border: 1px solid #ccc;
    border-radius: 3px;
    padding: 3px;
}

input[type="text"]:focus,
input[type="email"]:focus,
input[type="url"]:focus,
input[type="password"]:focus,
input[type="search"]:focus,
input[type="number"]:focus,
input[type="tel"]:focus,
input[type="range"]:focus,
input[type="date"]:focus,
input[type="month"]:focus,
input[type="week"]:focus,
input[type="time"]:focus,
input[type="datetime"]:focus,
input[type="datetime-local"]:focus,
input[type="color"]:focus,
textarea:focus {
    color: #111;
}

select {
    border: 1px solid #ccc;
}

textarea {
    width: 100%;
}

/*--------------------------------------------------------------
# Layouts
--------------------------------------------------------------*/

/*--------------------------------------------------------------
# Components
--------------------------------------------------------------*/

/* Navigation
--------------------------------------------- */
.main-navigation {
    display: block;
    width: 100%;
}

.main-navigation ul {
    display: none;
    list-style: none;
    margin: 0;
    padding-left: 0;
}

.main-navigation ul ul {
    box-shadow: 0 3px 3px rgba(0, 0, 0, 0.8);
    float: left;
    position: absolute;
    top: 100%;
    left: -999em;
    z-index: 99999;
    background-color: #FFF;
    border-radius: 20px;
}

.main-navigation ul ul ul {
    left: -999em;
    top: 0;
}

.main-navigation ul ul li:hover>ul,
.main-navigation ul ul li.focus>ul {
    display: block;
    left: auto;
}

.main-navigation ul ul a {
    width: 350px;
    padding: 10px;
}

.main-navigation ul li:hover>ul,
.main-navigation ul li.focus>ul {
    left: auto;
}

.main-navigation li {
    position: relative;
}

.main-navigation a {
    display: block;
    text-decoration: none;
}

/* Small menu. */
.menu-toggle,
.main-navigation.toggled ul {
    display: block;
}

/*@media screen and (min-width: 37.5em){

	.menu-toggle{
		display: none;
	}

	.main-navigation ul{
		display: flex;
		align-items:center;
	}
}
*/
.site-main .comment-navigation,
.site-main .posts-navigation,
.site-main .post-navigation {
    margin: 0 0 1.5em;
}

.comment-navigation .nav-links,
.posts-navigation .nav-links,
.post-navigation .nav-links {
    display: flex;
}

.comment-navigation .nav-previous,
.posts-navigation .nav-previous,
.post-navigation .nav-previous {
    flex: 1 0 50%;
}

.comment-navigation .nav-next,
.posts-navigation .nav-next,
.post-navigation .nav-next {
    text-align: end;
    flex: 1 0 50%;
}

/* Posts and pages
--------------------------------------------- */
.sticky {
    display: block;
}

.post,
.page {
    margin: 0 0 1.5em;
}

.updated:not(.published) {
    display: none;
}

.page-content,
.entry-content,
.entry-summary {
    margin: 1.5em 0 0;
}

.page-links {
    clear: both;
    margin: 0 0 1.5em;
}

/* Comments
--------------------------------------------- */
.comment-content a {
    word-wrap: break-word;
}

.bypostauthor {
    display: block;
}

/* Widgets
--------------------------------------------- */
.widget {
    margin: 0 0 1.5em;
}

.widget select {
    max-width: 100%;
}

/* Media
--------------------------------------------- */
.page-content .wp-smiley,
.entry-content .wp-smiley,
.comment-content .wp-smiley {
    border: none;
    margin-bottom: 0;
    margin-top: 0;
    padding: 0;
}

/* Make sure logo link wraps around logo image. */
.custom-logo-link {
    display: inline-block;
}

/* Captions
--------------------------------------------- */
.wp-caption {
    margin-bottom: 1.5em;
    max-width: 100%;
}

.wp-caption img[class*="wp-image-"] {
    display: block;
    margin-left: auto;
    margin-right: auto;
}

.wp-caption .wp-caption-text {
    margin: 0.8075em 0;
}

.wp-caption-text {
    text-align: center;
}

/* Galleries
--------------------------------------------- */
.gallery {
    margin-bottom: 1.5em;
    display: grid;
    grid-gap: 1.5em;
}

.gallery-item {
    display: inline-block;
    text-align: center;
    width: 100%;
}

.gallery-columns-2 {
    grid-template-columns: repeat(2, 1fr);
}

.gallery-columns-3 {
    grid-template-columns: repeat(3, 1fr);
}

.gallery-columns-4 {
    grid-template-columns: repeat(4, 1fr);
}

.gallery-columns-5 {
    grid-template-columns: repeat(5, 1fr);
}

.gallery-columns-6 {
    grid-template-columns: repeat(6, 1fr);
}

.gallery-columns-7 {
    grid-template-columns: repeat(7, 1fr);
}

.gallery-columns-8 {
    grid-template-columns: repeat(8, 1fr);
}

.gallery-columns-9 {
    grid-template-columns: repeat(9, 1fr);
}

.gallery-caption {
    display: block;
}

/*--------------------------------------------------------------
# Plugins
--------------------------------------------------------------*/

/* Jetpack infinite scroll
--------------------------------------------- */

/* Hide the Posts Navigation and the Footer when Infinite Scroll is in use. */
.infinite-scroll .posts-navigation,
.infinite-scroll.neverending .site-footer {
    display: none;
}

/* Re-display the Theme Footer when Infinite Scroll has reached its end. */
.infinity-end.neverending .site-footer {
    display: block;
}

/*--------------------------------------------------------------
# Utilities
--------------------------------------------------------------*/

/* Accessibility
--------------------------------------------- */

/* Text meant only for screen readers. */
.screen-reader-text {
    border: 0;
    clip: rect(1px, 1px, 1px, 1px);
    clip-path: inset(50%);
    height: 1px;
    margin: -1px;
    overflow: hidden;
    padding: 0;
    position: absolute !important;
    width: 1px;
    word-wrap: normal !important;
}

.screen-reader-text:focus {
    background-color: #f1f1f1;
    border-radius: 3px;
    box-shadow: 0 0 2px 2px rgba(0, 0, 0, 0.6);
    clip: auto !important;
    clip-path: none;
    color: #21759b;
    display: block;
    font-size: 0.875rem;
    font-weight: 700;
    height: auto;
    left: 5px;
    line-height: normal;
    padding: 15px 23px 14px;
    text-decoration: none;
    top: 5px;
    width: auto;
    z-index: 100000;
}

/* Do not show the outline on the skip link target. */
#primary[tabindex="-1"]:focus {
    outline: 0;
}

/* Alignments
--------------------------------------------- */
.alignleft {

    /*rtl:ignore*/
    float: left;

    /*rtl:ignore*/
    margin-right: 1.5em;
    margin-bottom: 1.5em;
}

.alignright {

    /*rtl:ignore*/
    float: right;

    /*rtl:ignore*/
    margin-left: 1.5em;
    margin-bottom: 1.5em;
}

.aligncenter {
    clear: both;
    display: block;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 1.5em;
}


:root {
    --sideNav-width: 450px;
    --viewportHeight: 100vh;
    --sideNav-paddingY: 20px;
    --sideNav-paddingX: 25px;
    --gray-border: #c9c9c9;
}

* {
    box-sizing: border-box;
}


html {
    background-color: var(--background-color) !important;
}

main {
    min-height: 100vh;
}

/*classi per correggere impostazioni tema */
::-moz-selection {
    /* Code for Firefox */
    color: var(--text-color);
    background: var(--accent-color);
}

::selection {
    background: var(--text-color-alt);
    color: #fff;
}

::-webkit-scrollbar {
    width: var(--width-scrollbar);
}

::-webkit-scrollbar-thumb {
    background: var(--background-scrollbar-thumb);
    border-radius: var(--radius-scrollbar);
}

::-webkit-scrollbar-track {
    background: var(--background-scrollbar-track);
}

/*reset*/
*:focus {
    outline: none;
}

* img {
    image-rendering: -webkit-optimize-contrast !important;
}

* {
    text-rendering: optimizeLegibility !important;
}

html {
    scroll-behavior: smooth;
    overflow-x: hidden;
}

body,
html {
    width: 100vw !important;
    overflow-x: hidden !important;
    background: var(--background-color-body);
}

main {
    overflow: hidden;
}

figure {
    margin: 0;
}

p {
    margin-block-start: initial;
    margin-block-end: 1,5em;
}

a:hover {
    text-decoration: none;
}

/*----------------extra----------------*/
div#Content {
    padding: 0;
}

.post,
.page {
    margin: 0em;
}

.page-content,
.entry-content,
.entry-summary {
    margin: 0em 0 0;
}

html.stop {
    overflow: hidden !important;
}

/*----------------clear----------------*/
.clearfix:before,
.clearfix:after {
    content: "\0020";
    display: block;
    overflow: hidden;
    visibility: hidden;
    width: 0;
    height: 0;
}

.clearfix:after {
    clear: both;
}

.clear {
    clear: both;
    display: block;
    overflow: hidden;
    visibility: hidden;
    width: 0;
    height: 0;
}

/*----------------Rules for icon sizes----------------*/
i.material-icons,
span.material-icons {
    line-height: inherit;
    vertical-align: text-bottom;
    font-size: 16px;
}

i.material-icons.md-12,
span.material-icons.md-12 {
    font-size: 12px;
}

i.material-icons.md-14,
span.material-icons.md-14 {
    font-size: 14px;
}

i.material-icons.md-18,
span.material-icons.md-18 {
    font-size: 18px;
}

i.material-icons.md-24,
span.material-icons.md-24 {
    font-size: 24px;
}

/* Default */
i.material-icons.md-36,
span.material-icons.md-36 {
    font-size: 36px;
}

i.material-icons.md-48,
span.material-icons.md-48 {
    font-size: 48px;
}

/*----------------righe e colonne----------------*/
section {
    margin: 0 auto;
}

section.margin {
    margin-top: var(--space-margin);
    margin-bottom: var(--space-margin);
}

section.margin.first {
    margin-top: calc(var(--space-margin) * 2);
    margin-bottom: var(--space-margin);
}

section.margin.last {
    margin-bottom: calc(var(--space-margin) * 2);
    margin-top: var(--space-margin);
}

section.margin.last.margin0bottom {
    margin-bottom: 0;
    margin-top: var(--space-margin);
}

.margin-top {
    margin-top: var(--space-margin);
}

.margin-bottom {
    margin-bottom: var(--space-margin);
}

.full-height {
    height: 100vh;
}

.height-100 {
    height: 100%;
}

.full-width {
    max-width: none !important;
}

.width-100 {
    width: 100%;
}

.width-auto {
    width: auto;
}

section,
.w-container,
.w-container-small,
.col-100,
.col-85,
.col-80,
.col-75,
.col-70,
.col-60,
.col-50,
.col-40,
.col-33,
.col-30,
.col-25,
.col-15 {
    box-sizing: border-box;
}

.contenuto {
    padding: var(--padding-container);
}

/*----------------colonne----------------*/
.w-container {
    max-width: var(--w-container);
    width: 100%;
}

.w-container-small {
    max-width: var(--w-container-stretto);
    width: 100%;
}

.w-container-header {
    max-width: var(--w-container-header);
    width: 100%;
}

.col-100,
.full-width {
    width: 100%;
    max-width: none;
}

/*grid*/
section .grid-container {
    grid-template-columns: repeat(12, 1fr);
    grid-template-rows: auto;
    grid-auto-flow: dense;
    /* align-items: start; */
    display: grid;
    margin-left: auto;
    margin-right: auto;
    /* border:#ff00004a 0.5px dotted; */
    box-sizing: border-box;
}

section .grid-container .cell {
    box-sizing: border-box;
    position: relative;
}

section .grid-container .cell.g12 {
    grid-column-end: span 12;
}

section .grid-container .cell.g11 {
    grid-column-end: span 11;
}

section .grid-container .cell.g10 {
    grid-column-end: span 10;
}

section .grid-container .cell.g9 {
    grid-column-end: span 9;
}

section .grid-container .cell.g8 {
    grid-column-end: span 8;
}

section .grid-container .cell.g7 {
    grid-column-end: span 7;
}

section .grid-container .cell.g6 {
    grid-column-end: span 6;
}

section .grid-container .cell.g5 {
    grid-column-end: span 5;
}

section .grid-container .cell.g4 {
    grid-column-end: span 4;
}

section .grid-container .cell.g3 {
    grid-column-end: span 3;
}

section .grid-container .cell.g2 {
    grid-column-end: span 2;
}

section .grid-container .cell.g1 {
    grid-column-end: span 1;
}

section .grid-container .cell.start1 {
    grid-column-start: 1;
}

section .grid-container .cell.start2 {
    grid-column-start: 2;
}

section .grid-container .cell.start3 {
    grid-column-start: 3;
}

section .grid-container .cell.start4 {
    grid-column-start: 4;
}

section .grid-container .cell.start5 {
    grid-column-start: 5;
}

section .grid-container .cell.start6 {
    grid-column-start: 6;
}

section .grid-container .cell.start7 {
    grid-column-start: 7;
}

section .grid-container .cell.start8 {
    grid-column-start: 8;
}

section .grid-container .cell.start9 {
    grid-column-start: 9;
}

section .grid-container .cell.start10 {
    grid-column-start: 10;
}

section .grid-container .cell.start11 {
    grid-column-start: 11;
}

section .grid-container .cell.start12 {
    grid-column-start: 12;
}

.grid-gap10 {
    grid-gap: 10px;
}

.grid-gap20 {
    grid-gap: 20px;
}

.grid-gap30 {
    grid-gap: 30px;
}

.grid-gap40 {
    grid-gap: 40px;
}

.grid-gap50 {
    grid-gap: 50px;
}

.grid-gap60 {
    grid-gap: 60px;
}

.cell.gutter {
    display: block;
    overflow: hidden;
    visibility: hidden;
    width: 0;
    height: 0;
}

/*colonne standard*/
.col-85 {
    width: 85%;
}

.col-80 {
    width: 80%;
}

.col-75 {
    width: 75%;
}

.col-70 {
    width: 70%;
}

.col-66 {
    width: 66%;
}

.col-65 {
    width: 65%;
}

.col-60 {
    width: 60%;
}

.col-55 {
    width: 55%;
}

.col-50 {
    width: 50%;
}

.col-45 {
    width: 45%;
}

.col-40 {
    width: 40%;
}

.col-35 {
    width: 35%;
}

.col-33 {
    width: 33%;
}

.col-30 {
    width: 30%;
}

.col-25 {
    width: 25%;
}

.col-20 {
    width: 20%;
}

.col-15 {
    width: 15%;
}

.col-12 {
    width: 12.5%;
}

.col-10 {
    width: 10%;
}

/*colonne-flex + gap*/
.col-20-flex {
    flex-grow: 1;
    flex-shrink: 0;
    flex-basis: 14%;
}

.col-25-flex {
    flex-grow: 1;
    flex-shrink: 0;
    flex-basis: 20%;
}

.col-30-flex {
    flex-grow: 1;
    flex-shrink: 0;
    flex-basis: 24%;
}

.col-40-flex {
    flex-grow: 1;
    flex-shrink: 0;
    flex-basis: 34%;
}

.col-50-flex {
    flex-grow: 1;
    flex-shrink: 0;
    flex-basis: 44%;
}

.col-60-flex {
    flex-grow: 1;
    flex-shrink: 0;
    flex-basis: 54%;
}

.col-80-flex {
    flex-grow: 1;
    flex-shrink: 0;
    flex-basis: 74%;
}



/* GAP */

/* GAP */

.gap-4px {
    gap: 4px;
}

.gap-5px {
    gap: 5px;
}

.gap-10px {
    gap: 10px;
}

.gap-15px {
    gap: 15px;
}

.gap-16px {
	gap: 16px;
}

.gap-20px {
    gap: 20px;
}

.gap-25px {
    gap: 25px;
}

.gap-30px {
    gap: 30px;
}

.gap-35px {
    gap: 35px;
}

.gap-40px {
    gap: 40px;
}

.gap-50px {
    gap: 50px;
}

.gap-60px {
    gap: 60px;
}

.gap-65px {
    gap: 65px;
}

.gap-70px {
    gap: 70px;
}

.gap-100px {
    gap: 100px;
}

.gap-140px {
    gap: 140px;
}

.column-gap-1 {
    column-gap: 3%;
}

.column-gap-3 {
    column-gap: 6%;
}

.column-gap-6 {
    column-gap: 12%;
}

.row-gap-12 {
    row-gap: 12px;
}

.row-gap-24 {
    row-gap: 24px;
}

.row-gap-48 {
    row-gap: 48px;
}

.gap-5px>.col-20 {
    width: calc(20% - 10px);
}

.gap-5px>.col-33 {
    width: calc(33% - 1px);
}
.gap-15px>.col-25 {
    width: calc(25% - 12px);
}
.gap-15px>.col-50 {
    width: calc(50% - 7.5px);
}
.gap-20px>.col-20 {
    width: calc(20% - 17px);
}

.gap-20px>.col-50 {
    width: calc(50% - 11px);
}

.gap-20px .col-33 {
    width: calc(33% - 11px);
}

.gap-20px>.col-25 {
    width: calc(25% - 16px);
}

.column-gap-20px>.col-33 {
    width: calc(33% - 11px);
}

.gap-25px>.col-25 {
    width: calc(25% - 19px);
}

.gap-25px>.col-33 {
    width: calc(33% - 15px);
}

.gap-30px>.col-20 {
    width: calc(20% - 24px);
}

.gap-30px>.col-25 {
    width: calc(25% - 23px);
}
.gap-30px>.col-30 {
    width: calc(30% - 15px);
}

.gap-30px .col-33 {
    width: calc(33% - 18px);
}

.gap-30px>.col-40 {
    width: calc(40% - 15px);
}

.gap-30px>.col-50 {
    width: calc(50% - 15px);
}

.gap-30px>.col-60 {
    width: calc(60% - 15px);
}
.gap-30px>.col-70 {
    width: calc(70% - 15px);
}
.gap-35px>.col-33 {
    width: calc(33% - 21px);
}

.gap-40px>.col-25 {
    width: calc(25% - 30px);
}

.gap-40px>.col-50 {
    width: calc(50% - 20px);
}

.gap-50px>.col-25 {
    width: calc(25% - 38px);
}

.gap-50px>.col-33 {
    width: calc(33% - 31px);
}

.gap-50px>.col-50,
.woocommerce-page div.product .gap-50px>div.summary.col-50 {
    width: calc(50% - 25px);
}

.gap-60px>.col-50 {
    width: calc(50% - 30px);
}

.gap-60px>.col-45 {
    width: calc(45% - 30px) !important;
}

.gap-65px > .col-35{
    width: calc(35% - 33px);   
}

.gap-65px > .col-65{
    width: calc(65% - 33px);   
}

.gap-65px.columns-3>.col-70 {
    width: calc(70% - 40px);
}
.gap-65px.columns-3>.col-15 {
    width: calc(15% - 40px);
}

.gap-60px>.col-55 {
    width: calc(55% - 30px);
}

.gap-70px .col-50 {
    width: calc(50% - 35px);
}

.gap-140px .col-55{
    width: calc(55% - 70px) !important;
}
.gap-140px .col-45{
    width: calc(45% - 70px) !important;
}

/*----------------flex----------------*/

.block {
    display: block;
}

.flex {
    display: flex;
}

.flex-row {
    flex-direction: row;
}

.flex-column {
    flex-direction: column;
}

.flex-row-rev {
    flex-direction: row-reverse;
}

.flex-column-rev {
    flex-direction: column-reverse;
}

.flex-wrap {
    flex-wrap: wrap;
}

.flex-nowrap {
    flex-wrap: nowrap;
}

.flex-shrink-0 {
    flex-shrink: 0;
}

.flex-shrink-1 {
    flex-shrink: 1;
}

.flex-grow-0 {
    flex-grow: 0;
}

.flex-grow-1 {
    flex-grow: 1;
}

.align-items-center {
    align-items: center;
}

.align-items-end {
    align-items: flex-end;
}

.align-items-start {
    align-items: flex-start;
}

.align-items-stretch {
    align-items: stretch;
}

.align-content-center {
    align-content: center;
}

.align-content-end {
    align-content: flex-end;
}

.align-content-start {
    align-content: flex-start;
}

.align-content-stretch {
    align-content: stretch;
}

.align-self-center {
    align-content: center;
}

.align-self-end {
    align-content: flex-end;
}

.align-self-start {
    align-content: flex-start;
}

.align-self-stretch {
    align-content: stretch;
}

.justify-content-center {
    justify-content: center;
}

.justify-content-end {
    justify-content: end;
}

.justify-content-start {
    justify-content: flex-start;
}

.justify-content-space-around {
    justify-content: space-around;
}

.justify-content-space-between {
    justify-content: space-between;
}

.justify-content-space-evenly {
    justify-content: space-evenly;
}

.align-self-center {
    align-self: center;
}

/*----------------spazi dinamici----------------*/

/* padding */

.padding {
    padding: var(--padding-box);
}

.padding0 {
    padding: 0px !important;
}

.padding0sx {
    padding-left: 0px !important;
}

.padding0dx {
    padding-right: 0px !important;
}

.padding0top {
    padding-top: 0px !important;
}

.padding0bottom {
    padding-bottom: 0px !important;
}

.paddingbase05 {
    padding: calc(var(--baseline) / 2);
}

.paddingbasetop05 {
    padding-top: calc(var(--baseline) / 2);
}

.paddingbasebottom05 {
    padding-bottom: calc(var(--baseline) / 2);
}

.paddingbaseleft05 {
    padding-left: calc(var(--baseline) / 2);
}

.paddingbaseright05 {
    padding-right: calc(var(--baseline) / 2);
}

.paddingbasey05 {
    padding-top: calc(var(--baseline) / 2);
    padding-bottom: calc(var(--baseline) / 2);
}

.paddingbasex05 {
    padding-left: calc(var(--baseline) / 2);
    padding-right: calc(var(--baseline) / 2);
}

.paddingbase {
    padding: var(--baseline);
}

.paddingbasetop {
    padding-top: var(--baseline);
}

.paddingbasebottom {
    padding-bottom: var(--baseline);
}

.paddingbaseleft {
    padding-left: var(--baseline);
}

.paddingbaseright {
    padding-right: var(--baseline);
}

.paddingbasey {
    padding-top: var(--baseline);
    padding-bottom: var(--baseline);
}

.paddingbasex {
    padding-left: var(--baseline);
    padding-right: var(--baseline);
}

.paddingbase2 {
    padding: var(--spacing-2);
}

.paddingbasetop2 {
    padding-top: var(--spacing-2);
}

.paddingbasebottom2 {
    padding-bottom: var(--spacing-2);
}

.paddingbaseleft2 {
    padding-left: var(--spacing-2);
}

.paddingbaseright2 {
    padding-right: var(--spacing-2);
}

.paddingbasey2 {
    padding-top: var(--spacing-2);
    padding-bottom: var(--spacing-2);
}

.paddingbasex2 {
    padding-left: var(--spacing-2);
    padding-right: var(--spacing-2);
}

.paddingbase3 {
    padding: var(--spacing-3);
}

.paddingbasetop3 {
    padding-top: var(--spacing-3);
}

.paddingbasebottom3 {
    padding-bottom: var(--spacing-3);
}

.paddingbaseleft3 {
    padding-left: var(--spacing-3);
}

.paddingbaseright3 {
    padding-right: var(--spacing-3);
}

.paddingbasey3 {
    padding-top: var(--spacing-3);
    padding-bottom: var(--spacing-3);
}

.paddingbasex3 {
    padding-left: var(--spacing-3);
    padding-right: var(--spacing-3);
}

.paddingbase4 {
    padding: var(--spacing-4);
}

.paddingbasetop4 {
    padding-top: var(--spacing-4);
}

.paddingbasebottom4 {
    padding-bottom: var(--spacing-4);
}

.paddingbaseleft4 {
    padding-left: var(--spacing-4);
}

.paddingbaseright4 {
    padding-right: var(--spacing-4);
}

.paddingbasey4 {
    padding-top: var(--spacing-4);
    padding-bottom: var(--spacing-4);
}

.paddingbasex4 {
    padding-left: var(--spacing-4);
    padding-right: var(--spacing-4);
}

.paddingbase5 {
    padding: var(--spacing-5);
}

.paddingbasetop5 {
    padding-top: var(--spacing-5);
}

.paddingbasebottom5 {
    padding-bottom: var(--spacing-5);
}

.paddingbaseleft5 {
    padding-left: var(--spacing-5);
}

.paddingbaseright5 {
    padding-right: var(--spacing-5);
}

.paddingbasey5 {
    padding-top: var(--spacing-5);
    padding-bottom: var(--spacing-5);
}

.paddingbasex5 {
    padding-left: var(--spacing-5);
    padding-right: var(--spacing-5);
}

.paddingbase6 {
    padding: var(--spacing-6);
}

.paddingbasetop6 {
    padding-top: var(--spacing-6);
}

.paddingbasebottom6 {
    padding-bottom: var(--spacing-6);
}

.paddingbaseleft6 {
    padding-left: var(--spacing-6);
}

.paddingbaseright6 {
    padding-right: var(--spacing-6);
}

.paddingbasey6 {
    padding-top: var(--spacing-6);
    padding-bottom: var(--spacing-6);
}

.paddingbasex6 {
    padding-left: var(--spacing-6);
    padding-right: var(--spacing-6);
}

.paddingbase7 {
    padding: var(--spacing-7);
}

.paddingbasetop7 {
    padding-top: var(--spacing-7);
}

.paddingbasebottom7 {
    padding-bottom: var(--spacing-7);
}

.paddingbaseleft7 {
    padding-left: var(--spacing-7);
}

.paddingbaseright7 {
    padding-right: var(--spacing-7);
}

.paddingbasey7 {
    padding-top: var(--spacing-7);
    padding-bottom: var(--spacing-7);
}

.paddingbasex7 {
    padding-left: var(--spacing-7);
    padding-right: var(--spacing-7);
}

.paddingbase8 {
    padding: var(--spacing-8);
}

.paddingbasetop8 {
    padding-top: var(--spacing-8);
}

.paddingbasebottom8 {
    padding-bottom: var(--spacing-8);
}

.paddingbaseleft8 {
    padding-left: var(--spacing-8);
}

.paddingbaseright8 {
    padding-right: var(--spacing-8);
}

.paddingbasey8 {
    padding-top: var(--spacing-8);
    padding-bottom: var(--spacing-8);
}

.paddingbasex8 {
    padding-left: var(--spacing-8);
    padding-right: var(--spacing-8);
}

.paddingbase9 {
    padding: var(--spacing-9);
}

.paddingbasetop9 {
    padding-top: var(--spacing-9);
}

.paddingbasebottom9 {
    padding-bottom: var(--spacing-9);
}

.paddingbaseleft9 {
    padding-left: var(--spacing-9);
}

.paddingbaseright9 {
    padding-right: var(--spacing-9);
}

.paddingbasey9 {
    padding-top: var(--spacing-9);
    padding-bottom: var(--spacing-9);
}

.paddingbasex9 {
    padding-left: var(--spacing-9);
    padding-right: var(--spacing-9);
}

.paddingbase10 {
    padding: var(--spacing-10);
}

.paddingbasetop10 {
    padding-top: var(--spacing-10);
}

.paddingbasebottom10 {
    padding-bottom: var(--spacing-10);
}

.paddingbaseleft10 {
    padding-left: var(--spacing-10);
}

.paddingbaseright10 {
    padding-right: var(--spacing-10);
}

.paddingbasey10 {
    padding-top: var(--spacing-10);
    padding-bottom: var(--spacing-10);
}

.paddingbasex10 {
    padding-left: var(--spacing-10);
    padding-right: var(--spacing-10);
}

.paddingbase11 {
    padding: var(--spacing-11);
}

.paddingbasetop11 {
    padding-top: var(--spacing-11);
}

.paddingbasebottom11 {
    padding-bottom: var(--spacing-11);
}

.paddingbaseleft11 {
    padding-left: var(--spacing-11);
}

.paddingbaseright11 {
    padding-right: var(--spacing-11);
}

.paddingbasey11 {
    padding-top: var(--spacing-11);
    padding-bottom: var(--spacing-11);
}

.paddingbasex11 {
    padding-left: var(--spacing-11);
    padding-right: var(--spacing-11);
}

.paddingbase12 {
    padding: var(--spacing-12);
}

.paddingbasetop12 {
    padding-top: var(--spacing-12);
}

.paddingbasebottom12 {
    padding-bottom: var(--spacing-12);
}

.paddingbaseleft12 {
    padding-left: var(--spacing-12);
}

.paddingbaseright12 {
    padding-right: var(--spacing-12);
}

.paddingbasey12 {
    padding-top: var(--spacing-12);
    padding-bottom: var(--spacing-12);
}

.paddingbasex12 {
    padding-left: var(--spacing-12);
    padding-right: var(--spacing-12);
}


/* gap */


.gapbase {
    gap: var(--spacing-1);
}

.gapbase2 {
    gap: var(--spacing-2);
}

.gapbase3 {
    gap: var(--spacing-3);
}

.gapbase4 {
    gap: var(--spacing-4);
}

.gapbase5 {
    gap: var(--spacing-5);
}

.gapbase6 {
    gap: var(--spacing-6);
}

.gapbase7 {
    gap: var(--spacing-7);
}

.gapbase8 {
    gap: var(--spacing-8);
}

.gapbase9 {
    gap: var(--spacing-9);
}

.gapbase10 {
    gap: var(--spacing-10);
}








/*margin*/
.margin0 {
    margin: 0px !important;
}

.margin0sx {
    margin-left: 0px !important;
}

.margin0dx {
    margin-right: 0px !important;
}

.margin0top {
    margin-top: 0px !important;
}

.margin0bottom {
    margin-bottom: 0px !important;
}

.marginbase {
    margin: var(--baseline);
}

.marginbasetop {
    margin-top: var(--baseline);
}

.marginbasebottom {
    margin-bottom: var(--baseline) !important;
}

.marginbaseleft {
    margin-left: var(--baseline);
}

.marginbaseright {
    margin-right: var(--baseline);
}

.marginbasey {
    margin-top: var(--baseline);
    margin-bottom: var(--baseline);
}

.marginbasex {
    margin-left: var(--baseline);
    margin-right: var(--baseline);
}

.marginbase2 {
    margin: var(--spacing-2);
}

.marginbasetop2 {
    margin-top: var(--spacing-2);
}

.marginbasebottom2 {
    margin-bottom: var(--spacing-2) !important;
}

.marginbaseleft2 {
    margin-left: var(--spacing-2);
}

.marginbaseright2 {
    margin-right: var(--spacing-2);
}

.marginbasey2 {
    margin-top: var(--spacing-2);
    margin-bottom: var(--spacing-2);
}

.marginbasex2 {
    margin-left: var(--spacing-2);
    margin-right: var(--spacing-2);
}

.marginbase3 {
    margin: var(--spacing-3);
}

.marginbasetop3 {
    margin-top: var(--spacing-3);
}

.marginbasebottom3 {
    margin-bottom: var(--spacing-3);
}

.marginbaseleft3 {
    margin-left: var(--spacing-3);
}

.marginbaseright3 {
    margin-right: var(--spacing-3);
}

.marginbasey3 {
    margin-top: var(--spacing-3);
    margin-bottom: var(--spacing-3);
}

.marginbasex3 {
    margin-left: var(--spacing-3);
    margin-right: var(--spacing-3);
}

.marginbase4 {
    margin: var(--spacing-4);
}

.marginbasetop4 {
    margin-top: var(--spacing-4);
}

.marginbasebottom4 {
    margin-bottom: var(--spacing-4);
}

.marginbaseleft4 {
    margin-left: var(--spacing-4);
}

.marginbaseright4 {
    margin-right: var(--spacing-4);
}

.marginbasey4 {
    margin-top: var(--spacing-4);
    margin-bottom: var(--spacing-4);
}

.marginbasex4 {
    margin-left: var(--spacing-4);
    margin-right: var(--spacing-4);
}

.marginbase5 {
    margin: var(--spacing-5);
}

.marginbasetop5 {
    margin-top: var(--spacing-5);
}

.marginbasebottom5 {
    margin-bottom: var(--spacing-5);
}

.marginbaseleft5 {
    margin-left: var(--spacing-5);
}

.marginbaseright5 {
    margin-right: var(--spacing-5);
}

.marginbasey5 {
    margin-top: var(--spacing-5);
    margin-bottom: var(--spacing-5);
}

.marginbasex5 {
    margin-left: var(--spacing-5);
    margin-right: var(--spacing-5);
}

.marginbase6 {
    margin: var(--spacing-6);
}

.marginbasetop6 {
    margin-top: var(--spacing-6);
}

.marginbasebottom6 {
    margin-bottom: var(--spacing-6);
}

.marginbaseleft6 {
    margin-left: var(--spacing-6);
}

.marginbaseright6 {
    margin-right: var(--spacing-6);
}

.marginbasey6 {
    margin-top: var(--spacing-6);
    margin-bottom: var(--spacing-6);
}

.marginbasex6 {
    margin-left: var(--spacing-6);
    margin-right: var(--spacing-6);
}

.marginbase7 {
    margin: var(--spacing-7);
}

.marginbasetop7 {
    margin-top: var(--spacing-7);
}

.marginbasebottom7 {
    margin-bottom: var(--spacing-7);
}

.marginbaseleft7 {
    margin-left: var(--spacing-7);
}

.marginbaseright7 {
    margin-right: var(--spacing-7);
}

.marginbasey7 {
    margin-top: var(--spacing-7);
    margin-bottom: var(--spacing-7);
}

.marginbasex7 {
    margin-left: var(--spacing-7);
    margin-right: var(--spacing-7);
}

.marginbase8 {
    margin: var(--spacing-8);
}

.marginbasetop8 {
    margin-top: var(--spacing-8);
}

.marginbasebottom8 {
    margin-bottom: var(--spacing-8);
}

.marginbaseleft8 {
    margin-left: var(--spacing-8);
}

.marginbaseright8 {
    margin-right: var(--spacing-8);
}

.marginbasey8 {
    margin-top: var(--spacing-8);
    margin-bottom: var(--spacing-8);
}

.marginbasex8 {
    margin-left: var(--spacing-8);
    margin-right: var(--spacing-8);
}

.marginbase9 {
    margin: var(--spacing-9);
}

.marginbasetop9 {
    margin-top: var(--spacing-9);
}

.marginbasebottom9 {
    margin-bottom: var(--spacing-9);
}

.marginbaseleft9 {
    margin-left: var(--spacing-9);
}

.marginbaseright9 {
    margin-right: var(--spacing-9);
}

.marginbasey9 {
    margin-top: var(--spacing-9);
    margin-bottom: var(--spacing-9);
}

.marginbasex9 {
    margin-left: var(--spacing-9);
    margin-right: var(--spacing-9);
}

.marginbase10 {
    margin: var(--spacing-10);
}

.marginbasetop10 {
    margin-top: var(--spacing-10);
}

.marginbasebottom10 {
    margin-bottom: var(--spacing-10);
}

.marginbaseleft10 {
    margin-left: var(--spacing-10);
}

.marginbaseright10 {
    margin-right: var(--spacing-10);
}

.marginbasey10 {
    margin-top: var(--spacing-10);
    margin-bottom: var(--spacing-10);
}

.marginbasex10 {
    margin-left: var(--spacing-10);
    margin-right: var(--spacing-10);
}

.marginbase11 {
    margin: var(--spacing-11);
}

.marginbasetop11 {
    margin-top: var(--spacing-11);
}

.marginbasebottom11 {
    margin-bottom: var(--spacing-11);
}

.marginbaseleft11 {
    margin-left: var(--spacing-11);
}

.marginbaseright11 {
    margin-right: var(--spacing-11);
}

.marginbasey11 {
    margin-top: var(--spacing-11);
    margin-bottom: var(--spacing-11);
}

.marginbasex11 {
    margin-left: var(--spacing-11);
    margin-right: var(--spacing-11);
}
/*----------------spazi px----------------*/
.padding10 {
    padding: 10px;
}

.padding10sx {
    padding-left: 10px;
}

.padding10dx {
    padding-right: 10px;
}

.padding10top {
    padding-top: 10px;
}

.padding10bottom {
    padding-bottom: 10px;
}

.padding20 {
    padding: 20px;
}

.padding20sx {
    padding-left: 20px;
}

.padding20dx {
    padding-right: 20px;
}

.padding20top {
    padding-top: 20px;
}

.padding20bottom {
    padding-bottom: 20px;
}

.padding30 {
    padding: 30px;
}

.padding30sx {
    padding-left: 30px;
}

.padding30dx {
    padding-right: 30px;
}

.padding30top {
    padding-top: 30px;
}

.padding30bottom {
    padding-bottom: 30px;
}

.padding40 {
    padding: 40px;
}

.padding40sx {
    padding-left: 40px;
}

.padding40dx {
    padding-right: 40px;
}

.padding40top {
    padding-top: 40px;
}

.padding40bottom {
    padding-bottom: 40px;
}

.padding60 {
    padding: 60px;
}

.padding60sx {
    padding-left: 60px;
}

.padding60dx {
    padding-right: 60px;
}

.padding60top {
    padding-top: 60px;
}

.padding60bottom {
    padding-bottom: 60px;
}

.padding80 {
    padding: 80px;
}

.padding80sx {
    padding-left: 80px;
}

.padding80dx {
    padding-right: 80px;
}

.padding80top {
    padding-top: 80px;
}

.padding80bottom {
    padding-bottom: 80px;
}

.padding90bottom {
    padding-bottom: 90px;
}

.padding90top {
    padding-top: 90px;
}

.padding100 {
    padding: 100px;
}

.padding100sx {
    padding-left: 100px;
}

.padding100dx {
    padding-right: 100px;
}

.padding100top {
    padding-top: 100px;
}

.padding100bottom {
    padding-bottom: 100px;
}

.padding70 {
    padding: 70px;
}

.padding70sx {
    padding-left: 70px;
}

.padding70dx {
    padding-right: 70px;
}

.padding70top {
    padding-top: 70px;
}

.padding70bottom {
    padding-bottom: 70px;
}

.padding125top {
    padding-top: 125px;
}

.padding125bottom {
    padding-bottom: 125px;
}

/*margin*/
.margin0 {
    margin: 0px;
}

.margin0sx {
    margin-left: 0px;
}

.margin0dx {
    margin-right: 0px;
}

.margin0top {
    margin-top: 0px;
}

.margin0bottom {
    margin-bottom: 0px;
}

.margin10 {
    margin: 10px;
}

.margin10sx {
    margin-left: 10px;
}

.margin10dx {
    margin-right: 10px;
}

.margin10top {
    margin-top: 10px;
}

.margin10bottom {
    margin-bottom: 10px;
}

.margin20 {
    margin: 20px;
}

.margin20sx {
    margin-left: 20px;
}

.margin20dx {
    margin-right: 20px;
}

.margin20top {
    margin-top: 20px;
}

.margin20bottom {
    margin-bottom: 20px;
}

.margin30 {
    margin: 30px;
}

.margin30sx {
    margin-left: 30px;
}

.margin30dx {
    margin-right: 30px;
}

.margin30top {
    margin-top: 30px;
}

.margin30bottom {
    margin-bottom: 30px;
}

.margin40 {
    margin: 40px;
}

.margin40sx {
    margin-left: 40px;
}

.margin40dx {
    margin-right: 40px;
}

.margin40top {
    margin-top: 40px;
}

.margin40bottom {
    margin-bottom: 40px;
}

.margin60 {
    margin: 60px;
}

.margin60sx {
    margin-left: 60px;
}

.margin60dx {
    margin-right: 60px;
}

.margin60top {
    margin-top: 60px;
}

.margin60bottom {
    margin-bottom: 60px;
}

.margin70bottom {
    margin-bottom: 70px;
}

.margin70top {
    margin-top: 70px;
}

.margin80bottom {
    margin-bottom: 80px;
}

.margin80top {
    margin-top: 80px;
}

.margin100bottom {
    margin-bottom: 100px;
}

.margin100top {
    margin-top: 100px;
}

.margin150bottom {
    margin-bottom: 150px;
}

.margin150top {
    margin-top: 150px;
}

.margin250bottom {
    margin-bottom: 250px;
}

.margin250top {
    margin-top: 250px;
}

.margin-125top {
    margin-top: -125px;
}

.margin-auto {
    margin: 0 auto;
}

.no-margin {
    margin: 0px !important;
}

.no-padding {
    padding: 0px !important;
}


.margin0 {
    margin: 0px !important;
}

.margin0sx {
    margin-left: 0px !important;
}

.margin0dx {
    margin-right: 0px !important;
}

.margin0top {
    margin-top: 0px !important;
}

.margin0bottom {
    margin-bottom: 0px !important;
}



/*----------------z-index----------------*/
.z-index-negativo {
    z-index: -1;
}

.z-index-1 {
    z-index: 1;
}

.z-index-2 {
    z-index: 2;
}

.z-index-3 {
    z-index: 3;
}

.z-index-4 {
    z-index: 4;
}

.z-index-5 {
    z-index: 5;
}

.z-index-6 {
    z-index: 6;
}

.z-index-7 {
    z-index: 7;
}

.z-index-8 {
    z-index: 8;
}

.z-index-9 {
    z-index: 9;
}

.z-index-10 {
    z-index: 10;
}

.z-index-100 {
    z-index: 100;
}

.z-index-1000 {
    z-index: 1000;
}

.z-index-10000 {
    z-index: 10000;
}

/*----------------classi generiche----------------*/
.display-block {
    display: block !important;
}

.display-inline-block {
    display: inline-block;
}

.display-inline-flex {
    display: inline-flex;
}

.clear-both {
    clear: both;
}

.hidden{
    display: none;
}

.super-hidden {
    display: none !important;
}

.display-block-mb,
.flex-mob-xs{
    display: none !important;
}

.display-inline-block-mb {
    display: none !important;
}

.float-left {
    float: left;
}

.float-right {
    float: right;
}

.float-none {
    float: none;
}

.align-center {
    text-align: center;
}

.align-right {
    text-align: right;
}

.align-left {
    text-align: left;
}

.vertical-top {
    vertical-align: top;
}

.vertical-middle {
    vertical-align: middle;
}

.overflow {
    overflow: visible !important;
}

.no-overflow {
    overflow: hidden !important;
}

.no-overflow-x {
    overflow-x: hidden !important;
}

.no-overflow-y {
    overflow-y: hidden !important;
}

.bordo-top,
.border-top {
    border-top: 1px solid #eaeaea;
}

.bordo-bottom,
.border-bottom {
    border-bottom: 1px solid #eaeaea;
}

.bordo-destra,
.border-right {
    border-right: 1px solid #eaeaea;
}

.bordo-sinistra,
.border-left {
    border-left: 1px solid #eaeaea;
}

.bordo,
.border {
    border: 1px solid #eaeaea;
}

.tondo {
    border-radius: 100% !important;
}

.border-center-before:before {
    content: "";
    position: absolute;
    background: #8D909330;
    width: 1px;
    height: 100%;
    right: 50%;
    transform: translateX(-50%);
}

.background-color {
    background-color: var(--grey);
}

/*----------------liste----------------*/


#site-navigation ul {
    list-style: none;
    padding-left: 0;
    margin-left: 0;
    margin-bottom: 0;
}


main ul,
main ol {
    /*list-style: none;*/
    padding: 0;
    margin: 0.5em 0 1.5em 2em;
}

main ol {
    counter-reset: my-awesome-counter;
    margin-top: 5px;
}

main ol li {
    counter-increment: my-awesome-counter;
    vertical-align: middle;
    clear: both;
    display: block;
    align-items: center;
    margin-bottom: 10px;
    font-family: var(--font-principale);
    min-height: 1em;
    vertical-align: middle;
}

main ol li::before {
    content: counter(my-awesome-counter);
    color: #fff;
    font-weight: 600;
    display: block;
    width: 1.3em;
    height: 1.3em;
    font-size: 1em;
    line-height: 1.25em;
    text-align: center;
    display: inline-block;
    float: left;
    margin-left: -1em;
    margin-right: 5px;
    border-radius: 100%;
    background: var(--accent-color);
}

main ol li ol li::before {
    display: block;
    width: 1.3em;
    height: 1.3em;
    font-size: 0.9em;
    line-height: 1.2em;
    margin: 0 7px 0 20px;
}

main ul li::before {
    /*content: "";*/
    color: var(--text-color);
    font-weight: bold;
    display: inline-block;
    width: 1em;
    margin-left: -2em;
    margin-bottom: 10px;
    margin-right: 0;
    font-size: 10px;
    padding-right: 2em;
}

ul.clean,
ol.clean,
ul.clean li,
ol.clean li {
    padding: 0;
    margin: 0;
    list-style: none;
}

ul.clean li:before,
ol.clean li:before {
    content: none;
}

/*----------------stili generici----------------*/
.box-shadow {
    box-shadow: var(--shadow);
}

.border-radius {
    border-radius: var(--radius);
}

.border-radius-small {
    border-radius: var(--radius-small);
}

.circle {
    border-radius: 100%;
}

.figure-radius {
    overflow: hidden;
    display: flex;
    border-radius: var(--radius-small);
}

.figure-radius img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

/*----------------position----------------*/
.absolute {
    position: absolute;
}

.fixed {
    position: fixed;
}

.overlay,
.relative {
    position: relative;
}

.top0 {
    top: 0;
}

.bottom0 {
    bottom: 0;
}

.left0 {
    left: 0;
}

.right0 {
    right: 0;
}

/*----------------overlay----------------*/
.pop-up-overlay * {
    z-index: 10;
}

.pop-up-overlay:before {
    content: "";
    top: 0;
    background: #00000055;
    width: 100%;
    height: 100%;
    display: block;
    position: absolute;
    z-index: 2;
}

.pop-up-overlay.blur:before {
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
    background: #0000001a;
}

/*----------------colori variabili----------------*/
.testo-normale {
    color: var(--text-color) !important;
}

.testo-alternativo {
    color: var(--text-color-alt) !important;
}

.testo-evidenza {
    color: var(--accent-color) !important;
}

/*colori custom*/
.testo-custom-1,
.testo-custom-1 p {
    color: var(--custom-color-1) !important;
}

.testo-custom-2,
.testo-custom-2 p {
    color: var(--custom-color-2) !important;
}

.testo-custom-3,
.testo-custom-3 p {
    color: var(--custom-color-3) !important;
}

.testo-custom-4,
.testo-custom-4 p {
    color: var(--custom-color-4) !important;
}

/*colori fissi*/
.negativo,
.bianco,
.bianco p,
.white,
.white p {
    color: var(--white) !important;
}

.nero,
.nero p,
.black,
.black p {
    color: var(--black) !important;
}

.grey,
.grey p {
    color: var(--grey);
}

.darkgrey,
.darkgrey p {
    color: var(--darkgrey);
}

.darkgrey2,
.darkgrey2 p {
    color: var(--darkgrey2);
}

.darkgrey3,
.darkgrey3 p {
    color: var(--darkgrey3);
}

.darkergrey,
.darkergrey p {
    color: var(--darkergrey);
}

.darkergrey2,
.darkergrey2 p {
    color: var(--darkergrey2);
}

/*colori background*/
.bg-main {
    background-color: var(--background-color);
}

.bg-alt {
    background-color: var(--background-color-alt);
}

.bg-evidenza {
    background-color: var(--accent-color);
}

/*colori custom*/
.bg-custom-1 {
    background-color: var(--custom-color-1);
}

.bg-custom-2 {
    background-color: var(--custom-color-2);
}

.bg-custom-3 {
    background-color: var(--custom-color-3);
}

.bg-custom-4 {
    background-color: var(--custom-color-4);
}

/*colori fissi*/
.bg-black {
    background: var(--black);
}

.bg-white {
    background: var(--white);
}

.bg-grey {
    background: var(--grey);
}

.bg-darkgrey {
    background: var(--darkgrey);
}

.bg-darkgrey2 {
    background: var(--darkgrey2);
}

.bg-darkgrey3 {
    background: var(--darkgrey3);
}

.bg-darkergrey {
    background: var(--darkergrey);
}

.bg-darkergrey2 {
    background: var(--darkergrey2);
}

/*svg*/
.stroke-accent,
.stroke-accent * {
    stroke: var(--accent-color);
}

.fill-accent,
.fill-accent * {
    fill: var(--accent-color);
}

.bg-size-cover {
    background-size: cover;
}

.bg-position-center {
    background-position: center center;
}

/*testo con sfumatura*/

.color-clip,
.color-clip-hover:hover {
    background: rgb(26, 63, 244);
    background: -moz-linear-gradient(90deg,
            rgba(26, 63, 244, 1) 0%,
            rgba(1, 164, 255, 1) 42%,
            rgba(206, 255, 0, 1) 100%);
    background: -webkit-linear-gradient(90deg,
            rgba(26, 63, 244, 1) 0%,
            rgba(1, 164, 255, 1) 42%,
            rgba(206, 255, 0, 1) 100%);
    background: linear-gradient(90deg,
            rgba(26, 63, 244, 1) 0%,
            rgba(1, 164, 255, 1) 42%,
            rgba(206, 255, 0, 1) 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
}

/*opacity*/
.opacity70 {
    opacity: 0.7;
}

.opacity50 {
    opacity: 0.5;
}

.opacity30 {
    opacity: 0.3;
}

/*----------------fine colori----------------*/

/*----------------font----------------*/

.font-principale {
    font-family: var(--font-principale) !important;
}

.font-secondario,
.font-secondario p {
    font-family: var(--font-secondario) !important;
}

.breadcrumb {
    font-size: var(--size-p);
}

.breadcrumb a {
    text-decoration: none;
    color: var(--text-color);
}

/*----------------line-height-generiche----------------*/

.line-height-1 {
    line-height: 1;
}

.line-height-1-2 {
    line-height: 1.2;
}

.line-height-1-4 {
    line-height: 1.4;
}

.line-height-1-6 {
    line-height: 1.6;
}

.line-height-1-8 {
    line-height: 1.8;
}

.line-height-2 {
    line-height: 2;
}

/*stili*/
.italic {
    font-style: italic !important;
}

.maiuscolo,
.uppercase {
    text-transform: uppercase !important;
}

.minuscolo,
.lowercase {
    text-transform: lowercase !important;
}

.iniziali-maiuscole,
.capitalize {
    text-transform: capitalize !important;
}

/*pesi*/
.thin {
    font-weight: 100 !important;
}

.extralight,
.extralight p {
    font-weight: 200 !important;
}

.light,
.light p {
    font-weight: 300 !important;
}

.regular {
    font-weight: 400 !important;
}

.medium {
    font-weight: 500 !important;
}

.semibold {
    font-weight: 600 !important;
}

b,
strong,
.bold,
.grassetto {
    font-weight: 700 !important;
}

.extrabold {
    font-weight: 800 !important;
}

.black {
    font-weight: 900 !important;
}

a,
a:visited,
a:focus {
    color: var(--accent-color);
    text-decoration: none !important;
}

a.clean {
    color: unset;
}

a:hover {
    color: var(--accent-color);
}




body,
p,
li,
.p-base,
span.action-txt {
    font-family: var(--family-p);
    font-weight: var(--weight-p);
    font-size: var(--size-p);
    line-height: var(--lineH-p);
    color: var(--text-color);
}

.testo-alternativo p,
.testo-alternativo p li {
    color: var(--text-color-alt);
}

.p-big,
.p-big p {
    font-family: var(--family-p-big);
    font-weight: var(--weight-p-big);
    font-size: var(--size-p-big);
    line-height: var(--lineH-p-big);
}

.p-small,
.p-small p {
    font-family: var(--family-p-small);
    font-weight: var(--weight-p-small);
    font-size: var(--size-p-small);
    line-height: var(--lineH-p-small);
}

.title-h1-big {
    font-family: var(--family-h1-big);
    font-size: var(--size-h1-big);
    line-height: var(--lineH-h1-big);
    font-weight: var(--weight-h1-big);
    letter-spacing: var(--spacing-h1-big);
}
h1,
.title-h1 {
    font-family: var(--family-h1);
    font-size: var(--size-h1);
    line-height: var(--lineH-h1);
    font-weight: var(--weight-h1);
    letter-spacing: var(--spacing-h1);
}

h2,
.title-h2 {
    font-family: var(--family-h1);
    font-size: var(--size-h2);
    line-height: var(--lineH-h2);
    font-weight: var(--weight-h2);
    letter-spacing: var(--spacing-h2);
}

h3,
.title-h3 {
    font-family: var(--family-h1);
    font-size: var(--size-h3);
    line-height: var(--lineH-h3);
    font-weight: var(--weight-h3);
    letter-spacing: var(--spacing-h3);
}

h4,
.title-h4,
.title-h4 p {
    font-family: var(--family-h4);
    font-size: var(--size-h4);
    line-height: var(--lineH-h4);
    font-weight: var(--weight-h4);
    letter-spacing: var(--spacing-h4);
}

h5,
.title-h5,
.title-h5 p {
    font-family: var(--family-h5);
    font-size: var(--size-h5);
    line-height: var(--lineH-h5);
    font-weight: var(--weight-h5);
    letter-spacing: var(--spacing-h5);
}

h6,
.title-h6,
.title-h6 p {
    font-family: var(--family-h6);
    font-size: var(--size-h6);
    line-height: var(--lineH-h6);
    font-weight: var(--weight-h6);
    letter-spacing: var(--spacing-h6);
}

h1,
h2,
h3,
h4,
h5,
h6,
.title-h1-big,
.title-h1,
.title-h2,
.title-h3,
.title-h4,
.title-h5,
.title-h6 {
    color: var(--text-color);
}

h1.margin,
h2.margin,
h3.margin,
h4.margin,
h5.margin,
h6.margin,
.title-h1-big.margin,
.title-h1.margin,
.title-h2.margin,
.title-h3.margin,
.title-h4.margin,
.title-h5.margin,
.title-h6.margin {
    margin: 1em 0;
}

/*----------------Fine font----------------*/

/*----------------Bottoni----------------*/
.btn,
button.btn,
input[type="submit"].btn {
    font-family: var(--family-btn-s1);
    letter-spacing: var(--spacing-btn-s1);
    font-weight: var(--weight-btn-s1);
    text-transform: var(--transform-btn-s1);
    font-size: var(--size-btn-s1);
    line-height: var(--lineH-btn-s1);
    padding: var(--padding-btn-s1);
    margin: var(--margin-btn-s1);
    border-radius: var(--radius-btn-s1);
    border: var(--border-btn-s1) solid;
    /*global*/
    text-decoration: none;
    display: inline-block;
    text-align: center;
    overflow: hidden;
    transition: all 0.35s;
}

.btn:hover {
    transition: all 0.35s;
}

.btn:link,
.btn:visited {
    position: relative;
    top: 0;
    left: 0;
    display: inline-block;
}

button::after {
    display: none;
}

/*dimensioni bottoni*/
.btn.btn-big,
button.btn.btn-big,
input[type="submit"].btn.btn-big {
    font-family: var(--family-btn-s2);
    letter-spacing: var(--spacing-btn-s2);
    font-weight: var(--weight-btn-s2);
    text-transform: var(--transform-btn-s2);
    font-size: var(--size-btn-s2);
    line-height: var(--lineH-btn-s2);
    padding: var(--padding-btn-s2);
    margin: var(--margin-btn-s2);
    border-radius: var(--radius-btn-s2);
    border: var(--border-btn-s2) solid;
}

.btn.btn-small,
button.btn.btn-small,
input[type="submit"].btn.btn-small {
    font-family: var(--family-btn-s3);
    letter-spacing: var(--spacing-btn-s3);
    font-weight: var(--weight-btn-s3);
    text-transform: var(--transform-btn-s3);
    font-size: var(--size-btn-s3);
    line-height: var(--lineH-btn-s3);
    padding: var(--padding-btn-s3);
    margin: var(--margin-btn-s3);
    border-radius: var(--radius-btn-s3);
    border: var(--border-btn-s3) solid;
}

/*tipologia bottone*/

/*Stile 1*/
a.btn,
button.btn,
input[type="submit"].btn,
.btn.btn-style-1,
button.btn-style-1,
input[type="submit"].btn.btn-style-1 {
    color: var(--color-btn-type-1);
    border-color: var(--border-btn-type-1);
    background-color: var(--bg-top-btn-type-1);
    background-image: linear-gradient(180deg,
            var(--bg-top-btn-type-1) 0%,
            var(--bg-bottom-btn-type-1) 100%);
}

a.btn:hover,
button.btn:hover,
.btn.btn-style-1:hover,
button.btn-style-1:hover {
    color: var(--color-btn-type-1-h);
    border-color: var(--border-btn-type-1-h);
}

/*input*/
input[type="submit"].btn:hover,
input[type="submit"].btn.btn-style-1:hover {
    color: var(--color-btn-type-1-h);
    background-color: var(--bg-top-btn-type-1-h);
    background-image: linear-gradient(180deg,
            var(--bg-top-btn-type-1-h) 0%,
            var(--bg-bottom-btn-type-1-h) 100%);
    border-color: var(--border-btn-type-1-h);
}

a.btn:before,
a.btn:hover,
button.btn:before,
button.btn:hover,
.btn.btn-style-1:before,
.btn.btn-style-1:hover,
button.btn-style-1:before,
button.btn-style-1:hover{
    background-color: var(--bg-top-btn-type-1-h);
    background-image: linear-gradient(180deg,
            var(--bg-top-btn-type-1-h) 0%,
            var(--bg-bottom-btn-type-1-h) 100%);
}

/*Stile 2*/
.btn.btn-style-2,
button.btn.btn-style-2,
input[type="submit"].btn.btn-style-2 {
    color: var(--color-btn-type-2);
    border-color: var(--border-btn-type-2);
    background-color: var(--bg-top-btn-type-2);
    background-image: linear-gradient(180deg,
            var(--bg-top-btn-type-2) 0%,
            var(--bg-bottom-btn-type-2) 100%);
}

/*input*/
.btn.btn-style-2:hover,
button.btn.btn-style-2:hover {
    color: var(--color-btn-type-2-h);
    border-color: var(--border-btn-type-2-h);
}

/*input hover*/
input[type="submit"].btn.btn-style-2:hover {
    color: var(--color-btn-type-2-h);
    background-color: var(--bg-top-btn-type-2-h);
    background-image: linear-gradient(180deg,
            var(--bg-top-btn-type-2-h) 0%,
            var(--bg-bottom-btn-type-2-h) 100%);
    border-color: var(--border-btn-type-2-h);
}

/*before*/
.btn.btn-style-2:before,
button.btn.btn-style-2:before,
.btn.btn-style-2:hover,
button.btn.btn-style-2:hover{
    background-color: var(--bg-top-btn-type-2-h);
    background-image: linear-gradient(180deg,
            var(--bg-top-btn-type-2-h) 0%,
            var(--bg-bottom-btn-type-2-h) 100%);
}

/*Stile 3*/
.btn.btn-style-3,
button.btn.btn-style-3,
input[type="submit"].btn.btn-style-3 {
    color: var(--color-btn-type-3);
    border-color: var(--border-btn-type-3);
    background-color: var(--bg-top-btn-type-3);
    background-image: linear-gradient(180deg,
            var(--bg-top-btn-type-3) 0%,
            var(--bg-bottom-btn-type-3) 100%);
}

/*hover*/
.btn.btn-style-3:hover,
button.btn.btn-style-3:hover {
    color: var(--color-btn-type-3-h);
    border-color: var(--border-btn-type-3-h);
}

/*input hover*/
input[type="submit"].btn.btn-style-3:hover {
    color: var(--color-btn-type-3-h);
    background-color: var(--bg-top-btn-type-3-h);
    background-image: linear-gradient(180deg,
            var(--bg-top-btn-type-3-h) 0%,
            var(--bg-bottom-btn-type-3-h) 100%);
    border-color: var(--border-btn-type-3-h);
}

/*before*/
.btn.btn-style-3:before,
button.btn.btn-style-3:before,
.btn.btn-style-3:hover,
button.btn.btn-style-3:hover{
    background-color: var(--bg-top-btn-type-3-h);
    background-image: linear-gradient(180deg,
            var(--bg-top-btn-type-3-h) 0%,
            var(--bg-bottom-btn-type-3-h) 100%);
}

/*Stile 4*/
.btn.btn-style-4,
button.btn.btn-style-4,
input[type="submit"].btn.btn-style-4 {
    color: var(--color-btn-type-4);
    border-color: var(--border-btn-type-4);
    background-color: var(--bg-top-btn-type-4);
    background-image: linear-gradient(180deg,
            var(--bg-top-btn-type-4) 0%,
            var(--bg-bottom-btn-type-4) 100%);
}

/*hover*/
.btn.btn-style-4:hover,
button.btn.btn-style-4:hover {
    color: var(--color-btn-type-4-h);
    border-color: var(--border-btn-type-4-h);
}

/*input hover*/
input[type="submit"].btn.btn-style-4:hover {
    color: var(--color-btn-type-4-h);
    background-color: var(--bg-top-btn-type-4-h);
    background-image: linear-gradient(180deg,
            var(--bg-top-btn-type-4-h) 0%,
            var(--bg-bottom-btn-type-4-h) 100%);
    border-color: var(--border-btn-type-4-h);
}

/*before*/
.btn.btn-style-4:before,
button.btn.btn-style-4:before,
.btn.btn-style-4:hover,
button.btn.btn-style-4:hover {
    background-color: var(--bg-top-btn-type-4-h);
    background-image: linear-gradient(180deg,
            var(--bg-top-btn-type-4-h) 0%,
            var(--bg-bottom-btn-type-4-h) 100%);
}

/*Stile 5*/
.btn.btn-style-5,
button.btn.btn-style-5,
input[type="submit"].btn.btn-style-5 {
    color: var(--color-btn-type-5);
    border-color: var(--border-btn-type-5);
    background-color: var(--bg-top-btn-type-5);
    background-image: linear-gradient(180deg,
            var(--bg-top-btn-type-5) 0%,
            var(--bg-bottom-btn-type-5) 100%);
}

/*hover*/
.btn.btn-style-5:hover,
button.btn.btn-style-5:hover {
    color: var(--color-btn-type-5-h);
    border-color: var(--border-btn-type-5-h);
}

/*input hover*/
input[type="submit"].btn.btn-style-5:hover {
    color: var(--color-btn-type-5-h);
    background-color: var(--bg-top-btn-type-5-h);
    background-image: linear-gradient(180deg,
            var(--bg-top-btn-type-5-h) 0%,
            var(--bg-bottom-btn-type-5-h) 100%);
    border-color: var(--border-btn-type-5-h);
}

/*before*/
.btn.btn-style-5:before,
button.btn.btn-style-5:before,
.btn.btn-style-5:hover,
button.btn.btn-style-5:hover {
    background-color: var(--bg-top-btn-type-5-h);
    background-image: linear-gradient(180deg,
            var(--bg-top-btn-type-5-h) 0%,
            var(--bg-bottom-btn-type-5-h) 100%);
}

/*icone*/
.btn i {
    position: relative;
    padding-left: 5px;
    display: inline-block;
    z-index: 1;
}

.btn i,
button.btn i {
    font-size: calc(var(--size-btn-s1) + 0px);
}

.btn.btn-big i,
button.btn.btn-big i {
    font-size: calc(var(--size-btn-s1) + 0px);
}

.btn.btn-small i,
button.btn.btn-small i {
    font-size: calc(var(--size-btn-s1) + 0px);
}

/*effetto hover*/
.btn {
    position: relative;
}

.btn span {
    position: relative;
    z-index: 1;
    text-align: center;
    width: auto;
    display: inline-block;
}

.btn:not(input):before {
    content: "";
    position: absolute;
    transition: all 0.35s;
    z-index: 1;
}

/*standard*/
.animation-standard .btn:not(input):before {
    bottom: 0;
    left: 0;
    width: 100%;
    height: 100%;
    opacity: 0;
}

.animation-standard .btn:hover:before {
    width: 100%;
    opacity: 1;
}

/*rise*/
.animation-rise .btn:not(input):before {
    bottom: 0;
    left: 0;
    width: 100%;
    height: 100%;
    opacity: 0;
}

.animation-rise .btn:hover:before {
    width: 100%;
    opacity: 1;
}

.animation-rise .btn:hover {
    box-shadow: 0 0.5em 0.5em -0.4em #00000080;
    transform: translateY(-0.35em);
}

/*slide*/
.animation-fill-slide .btn:not(input):before {
    bottom: 0;
    left: 0;
    width: 0%;
    height: 100%;
}

.animation-fill-slide .btn:hover:before {
    width: 100%;
}

/*fil-down*/
.animation-fill-down .btn:not(input):before {
    bottom: 0;
    left: 0;
    width: 100%;
    height: 0%;
}

.animation-fill-down .btn:hover:before {
    height: 100%;
}

/*fil-up*/
.animation-fill-up .btn:not(input):before {
    top: 0;
    left: 0;
    width: 100%;
    height: 0%;
}

.animation-fill-up .btn:hover:before {
    height: 100%;
}

/*grow-box*/
.animation-grow-box .btn:not(input):before {
    bottom: 50%;
    left: 50%;
    width: 0%;
    height: 0%;
}

.animation-grow-box .btn:hover:before {
    width: 100%;
    height: 100%;
    bottom: 0%;
    left: 0%;
}

/*ellipse*/
.animation-grow-ellipse .btn:not(input):before {
    bottom: 50%;
    left: 50%;
    width: 0%;
    height: 0%;
    border-radius: 50%;
}

.animation-grow-ellipse .btn:hover:before {
    width: 200%;
    height: 500%;
    bottom: -200%;
    left: -50%;
}

/*bottoni disabilitati*/
.btn:disabled,
button:disabled,
.wpcf7 input[type="submit"]:disabled,
.btn:disabled:hover,
button:disabled:hover,
.wpcf7 input[type="submit"]:disabled:hover {
    opacity: 0.4;
    cursor: not-allowed;
    pointer-events: none;
}

/*----------------Fine Bottoni----------------*/

/*form*/
.wpcf7 {
    width: 100%;
}

.wpcf7 input[type="text"],
.wpcf7 input[type="email"],
.wpcf7 input[type="tel"],
.wpcf7 textarea,
.wpcf7 select {
    width: 100%;
    background: transparent;
}

.wpcf7 input[type="checkbox"] {
    display: inline-block;
    margin: 0 5px 0 0;
    padding: 0px;
    width: auto;
}

.wpcf7 textarea {
    height: 150px;
}

.wpcf7 input,
.wpcf7 select,
.wpcf7 textarea {
    border-radius: 3px;
    font-size: var(--size-p-small);
    font-family: var(--font-secondario);
    color: var(--text-color);
    font-weight: 400;
    line-height: 1.6;
    transition: 0.3s;
    padding: 10px 20px;
    border: 1px solid #a4a4a4;
    outline: 1px solid transparent;
}

.wpcf7 input:focus:not([type="submit"]),
.wpcf7 select:focus,
.wpcf7 textarea:focus {
    padding: 10px 30px;
    border-color: var(--accent-color);
    outline: 1px solid var(--accent-color);
    color: var(--text-color);
}

.wpcf7 input::placeholder,
.wpcf7 select::placeholder,
.wpcf7 textarea::placeholder {
    color: var(--text-color);
    opacity: 0.4;
}

.wpcf7 .negativo select {
    background-image: url(data:image/svg+xml;charset=US-ASCII,%3Csvg%20width%3D%2220%22%20height%3D%2220%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cpath%20d%3D%22M5%206l5%205%205-5%202%201-7%207-7-7%202-1z%22%20fill%3D%22%23999%22%2F%3E%3C%2Fsvg%3E);
}

/*Change text in autofill textbox*/
.wpcf7 input:-webkit-autofill {
    -webkit-text-fill-color: var(--text-color);
    padding: 10px 0px;
}

.wpcf7 .ajax-loader {
    filter: brightness(500%) contrast(80%);
    width: 15px;
    height: 15px;
    background-size: cover;
}

/* FORM SPUNTE */
.wpcf7 .info-privacy,
.info-privacy * {
    font-size: var(--size-p-small);
    line-height: var(--lineH-p-smaller);
    color: var(--text-color) !important;
}

.wpcf7 .info-privacy span.wpcf7-list-item {
    margin: 0;
}

.wpcf7 .wpcf7-list-item:first-child {
    margin: 0 0 0 0em;
}

.wpcf7 .info-privacy p a {
    text-decoration: underline;
}

.wpcf7 small {
    display: inline;
}

.wpcf7 span.wpcf7-form-control-wrap.radio {
    width: auto;
}

.wpcf7 input::-webkit-calendar-picker-indicator {
    color: transparent !important;
    background: transparent url(data:image/svg+xml;charset=US-ASCII,%3Csvg%20width%3D%2220%22%20height%3D%2220%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cpath%20d%3D%22M5%206l5%205%205-5%202%201-7%207-7-7%202-1z%22%20fill%3D%22%23555%22%2F%3E%3C%2Fsvg%3E) no-repeat right 5px top 55% !important;
}

.wpcf7 input.wpcf7-file {
    width: 100%;
}

.wpcf7 input[type="radio"] {
    margin: 5px !important;
}

.wpcf7 input:disabled {
    cursor: not-allowed;
}

/*response*/
.wpcf7 form .wpcf7-response-output {
    border: none;
    float: left;
    width: 100%;
    padding: 0px;
    margin: 20px 0px 0px 0px;
    font-size: var(--size-p);
    font-weight: bold;
}

.wpcf7 form .wpcf7-response-output:before {
    font-family: "Material Icons";
    display: inline-block;
    font-weight: normal;
    font-style: normal;
    font-size: 20px;
    line-height: 30px;
    width: 30px;
    height: 30px;
    border-radius: 15px;
    text-align: center;
    margin: -2px 10px 0px 0px;
    color: #fff;
    vertical-align: middle;
}

/*sent*/
.wpcf7 form.sent .wpcf7-response-output {
    color: #46b450;
}

.wpcf7 form.sent .wpcf7-response-output:before {
    content: "\e876";
    background: #46b450;
}

/*invalid*/
.wpcf7 form.invalid .wpcf7-response-output {
    color: #eaad2f;
}

.wpcf7 form.invalid .wpcf7-response-output:before {
    content: "\e002";
    background: #eaad2f;
}

/*aborted*/
.wpcf7 form.aborted .wpcf7-response-output,
.wpcf7 form.failed .wpcf7-response-output {
    color: #dc3232 !important;
}

.wpcf7 form.aborted .wpcf7-response-output:before,
.wpcf7 form.failed .wpcf7-response-output:before {
    content: "\e5cd";
    background: #dc3232;
}

/*fine response*/

/*not-valid-tip*/
body:not(.cf7p-message) .wpcf7-not-valid-tip {
    position: absolute;
    width: auto;
    margin-top: 3px;
    padding: 2px 8px;
    border-radius: 3px;
    background-color: #dc3232;
    border: none;
    float: left;
    z-index: 999;
}

body:not(.cf7p-message) .wpcf7-not-valid-tip {
    color: #fff;
    font-size: 14px;
    line-height: 1.6;
    font-weight: 500;
    display: flex;
    justify-content: center;
    align-items: center;
}

body:not(.cf7p-message) .wpcf7-not-valid-tip:after {
    content: "";
    position: absolute;
    left: 10px;
    top: -5px;
    background-color: #dc3232;
    width: 11px;
    height: 11px;
    transform: rotate(45deg);
    z-index: 1;
}

body:not(.cf7p-message) .wpcf7-not-valid-tip:before {
    content: "\e5c9";
    font-family: "Material Icons";
    display: inline-block;
    color: #fff;
    font-weight: normal;
    font-style: normal;
    position: relative;
    font-size: 20px;
    line-height: 1;
    left: -2px;
    top: -1px;
    z-index: 2;
}

/*fine not-valid-tip*/

/* FINE FORM SPUNTE */

/*----------------fine form----------------*/

/*----------------owl carousel----------------fine*/
.owl-dots * {
    transition: 0.5s all ease-in-out;
}

.owl-dots {
    margin-top: 0px;
    text-align: center;
}

.owl-carousel .owl-dots .owl-dot {
    height: 5px;
    margin: 0px 5px;
    background: var(--accent-color);
    box-shadow: none;
    opacity: 0.4;
    border-radius: 0px;
}

.owl-carousel .owl-dots .owl-dot span {
    display: none;
}

.owl-carousel .owl-dots .owl-dot.active {
    opacity: 1;
    width: 25px;
}

.owl-img-auto.owl-carousel .owl-item img {
    display: block !important;
    width: auto !important;
}

.owl-dot {
    background: #ebebeb;
    border: none;
    padding: 3.5px;
    border-radius: 0;
    width: 10px;
    height: 10px;
    border-radius: 10px;
    margin-right: 5px;
    border: 1px solid #ebebeb;
}

.owl-dot.active,
.owl-dot:hover {
    background: #fff;
    border: 1px solid #000;
}

.owl-dot:not(.active) {
    cursor: pointer;
}

/*owl carousel*/

/*----------------Footer----------------*/
footer {
    padding: var(--footer-padding);
}

footer,
footer section#widget-area {
    background-color: var(--background-widget);
}

/*----------------widget----------------*/
footer section#widget-area {
    margin: 0;
    padding-top: var(--widget-padding-top);
    padding-bottom: var(--widget-padding-bottom);
}

footer section#widget-area p,
footer section#widget-area b,
footer section#widget-area span,
footer section#widget-area strong,
footer section#widget-area ul,
footer section#widget-area ol,
footer section#widget-area li,
footer section#widget-area li * {
    margin: 0;
    color: var(--widget-color);
    font-family: var(--family-widget-text);
    font-size: var(--size-widget-text);
    font-weight: var(--weight-widget-text);
    line-height: var(--lineH-widget-text);
}

footer section#widget-area a {
    color: var(--widget-link-color);
}

footer section#widget-area .widget-row .widget-column .widget:last-child {
    margin: 0;
}

footer section#widget-area .widget-row .widget-column .widget-title {
    color: var(--widget-color);
    font-family: var(--family-widget-title);
    font-size: var(--size-widget-title);
    font-weight: var(--weight-widget-title);
    line-height: var(--lineH-widget-title);
    text-transform: uppercase;
    padding-bottom: 10px;
    margin: 0;
}

html.desktop footer section#widget-area .widget-row.widget-separator .widget-column:not(:first-child):before {
    content: "";
    display: block;
    position: absolute;
    height: 100%;
    width: 1px;
    top: 0;
    left: calc(var(--widget-separator-gap) / -2);
    border-right: var(--widget-separator);
}

html.desktop footer section#widget-area .widget-row.widget-separator.widget_4c .widget-column:nth-child(2):before,
html.desktop footer section#widget-area .widget-row.widget-separator.widget_5b .widget-column:nth-child(2):before {
    content: none;
}

/*menu footer*/
footer section#widget-area .widget ul.menu {
    margin: 0px;
    padding: 0px;
    list-style: none;
}

footer section#widget-area .widget ul.menu li {
    padding-bottom: 8px;
}

footer section#widget-area .widget ul.menu li ul.sub-menu {
    display: none;
}

/*----------------Socket Copyright-----------------*/
footer section#copyright-area {
    background: var(--background-socket);
    color: var(--socket-color);
    font-size: var(--size-socket-text) !important;
}

footer section#copyright-area .contenuto {
    padding-top: var(--socket-padding-top);
    padding-bottom: var(--socket-padding-bottom);
}

footer section#copyright-area p,
footer section#copyright-area b,
footer section#copyright-area span,
footer section#copyright-area strong,
footer section#copyright-area ul,
footer section#copyright-area ol,
footer section#copyright-area li {
    margin: 0;
    color: var(--socket-color);
    font-family: var(--family-socket-text);
    font-size: var(--size-socket-text) !important;
    font-weight: var(--weight-socket-text);
    line-height: var(--lineH-socket-text);
}

footer section#copyright-area a {
    color: var(--socket-link-color);
}

/*----------------header----------------*/

/*----------------action bar----------------*/
header #action-bar {
    width: 100%;
    background: var(--bg-actionbar);
}
header.transparent #action-bar {
    color: #ffffff;
    border-bottom: 1px solid #000000;
}
header .action-bar-content {
    padding-top: var(--padding-actionbar-top);
    padding-bottom: var(--padding-actionbar-top);
    margin: 0 auto;
}

header .action-bar-content>*,
header .action-bar-content p,
header .action-bar-content ul li,
header .action-bar-content ol li,
header .action-bar-content i {
    color: var(--color-actionbar);
    margin-bottom: 0;
}
header #action-bar ul {
    list-style: none;
    padding-left: 0;
    margin-left: 0;
    display: flex;
    gap: 20px;
    margin-bottom: 0;
}
header .action-bar-content a {
    color: var(--link-actionbar);
}
header .action-bar-content ul.sub-menu {
    background: transparent !important;
}
header #action-bar ul li{
    display: flex;
    align-items: center;
}
header #action-bar ul li > a,
header #action-bar p{
    font-size: 12px;
}

/*----------------menu----------------*/

/*pre-footer*/
pre-footer#prefooter {
    display: block;
}

/*personalizzazioni header*/
header.transparent #navigation-bar .site-branding figure.logo-container svg#logo g#testo_1 path {
    fill: #fff;
    transition: fill ease-out 500ms;
}

header.transparent #navigation-bar.sticky .site-branding figure.logo-container svg#logo g#testo_1 path {
    fill: #2d2d2d;
    transition: fill ease-out 500ms;
}

header {
    position: relative;
    width: 100%;
    z-index: 99;
}

header.transparent {
    position: absolute;
    z-index: 9999;
}

/*generic*/
header #navigation-bar {
    padding: 0;
    background: var(--background-color-header);
    position: relative;
    width: 100%;
    transition: all ease-out 250ms;
}

header #navigation-bar .navigation-content {
    padding: var(--padding-header);
}

header #navigation-bar.sticky {
    position: fixed;
    top: 0px;
    z-index: 9999;
    transition: all ease-out 250ms;
}

header #navigation-bar.sticky .navigation-content {
    padding: var(--padding-header-sticky);
}

header #navigation-bar .site-menu nav ul:not(.sub-menu)>li>a {
    color: var(--text-color-header);
}

header #navigation-bar .navigation-content {
    margin: 0 auto;
}


/*trasparent*/
header.transparent #navigation-bar {
    background: var(--background-color-transparent);
}

header.transparent #navigation-bar .site-menu nav ul:not(.sub-menu)>li>a {
    color: var(--text-color-header-transparent);
}

header.transparent #navigation-bar.sticky {
    background: var(--background-color-header);
}

header.transparent #navigation-bar.sticky .site-menu nav ul:not(.sub-menu)>li>a {
    color: var(--text-color-header);
}

.main-navigation ul ul {
    display: block !important;
    border-radius: 10px;
}
header.transparent #navigation-bar .woocommerce-icons-header-container > a, header.transparent #navigation-bar .woocommerce-icons-header-container button {
    color: #ffffff;
}
header.transparent .navigation-content .site-menu nav#site-navigation ul.menu li.menu-item-has-children > span {
    color: #ffffff;
}
/*----------------font-size----------------*/
header #navigation-bar .site-menu nav ul:not(.sub-menu)>li>a {
    font-family: var(--family-menu);
    font-size: var(--size-menu);
    line-height: var(--lineH-menu);
    font-weight: var(--weight-menu);
    letter-spacing: var(--spacing-menu);
    padding: var(--padding-menu);
    position: relative;
    z-index: 99999999;
}

header #navigation-bar .site-menu nav ul ul.sub-menu>li>a {
    font-family: var(--family-menu_2);
    font-size: var(--size-menu_2);
    line-height: var(--lineH-menu_2);
    font-weight: var(--weight-menu_2);
    letter-spacing: var(--spacing-menu_2);
}

/*----------------site-branding----------------*/
header #navigation-bar .navigation-content .site-branding,
header #navigation-bar .navigation-content .site-menu {
    display: flex;
    flex-direction: row;
    align-items: center;
}

header #navigation-bar .navigation-content .site-branding {
    /*width: 30%;*/
    justify-content: flex-start;
    min-width: 190px;
}

.header-contacts {
    width: 30%;
    justify-content: flex-end;
    align-items: center;
}

.header-contacts .material-icons {
    font-size: 24px;
}

.material-symbols-rounded {
    font-variation-settings: "FILL" 0, "wght" 500, "GRAD" 200, "opsz" 48;
}

.material-symbols-rounded.fill {
    font-variation-settings: "FILL" 1;
}

header #navigation-bar .navigation-content .site-branding .logo-container {
    padding: 0;
    margin: 0;
    position: relative;
    z-index: 99999999999999;
}

header #navigation-bar .navigation-content .site-branding .logo-container #logo {
    display: block;
    fill: var(--text-color);
}

header #navigation-bar .site-menu nav ul:not(.sub-menu)>li {
    padding: 10px 5px;
}


/* Sidenav */

.sidenav.hamburguer {
    display: none;
}



/*type_menu_1*/

header #navigation-bar .navigation-content.type_menu_1,
header #navigation-bar .navigation-content.type_menu_7 {
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    justify-content: space-between;
    align-items: stretch;
}

header #navigation-bar .navigation-content.type_menu_1 .menu ul,
header #navigation-bar .navigation-content.type_menu_7 ul.menu {
    display: flex;
    align-items: center;
    gap: 16px;
    list-style-type: none;
    padding: 0;
    margin: 0;
}




/*type_menu_2*/

header #navigation-bar .navigation-content.type_menu_2 .menu-toggle {
    display: none;
}


header #navigation-bar .navigation-content.type_menu_2 {
    display: flex;
    flex-direction: column;
    align-items: center;
    border-bottom: 1px solid var(--gray-border);
}

header #navigation-bar .navigation-content.type_menu_2 .site-branding {
    width: 100%;
    justify-content: center;
}


header #navigation-bar .navigation-content.type_menu_2 .site-menu .menu-toggle {
    display: none;
}

header #navigation-bar .navigation-content.type_menu_2 .site-menu ul {
    display: flex;
    align-items: center;
    padding: 0;
    margin: 0;
}



/*type_menu_3*/



header #navigation-bar .navigation-content.type_menu_3 .navbar-left .menu-menu-left-container ul,
header #navigation-bar .navigation-content.type_menu_3 .navbar-right .menu-menu-right-container ul {
	display: flex;
	align-items: center;
	margin: 0;
	width: 100%;
	list-style-type: none;
	padding: 0;
	gap: 16px;
}

header #navigation-bar .navigation-content.type_menu_3 .menu-mobile .menu {
    margin: 0;
}

header #navigation-bar .navigation-content.type_menu_3 .menu-desktop .site-branding {
    flex: 0 0 20%;
    justify-content: center;
}

header #navigation-bar .navigation-content.type_menu_3 ul.menu {
    display: flex;
    align-items: center;
    justify-content: center;
}

header #navigation-bar .navigation-content.type_menu_3 .menu-primary-container {
    width: 100%;
}

header #navigation-bar .navigation-content.type_menu_3.mobile .site-branding {
    flex: auto;
    width: 100%;
    justify-content: center;
}

header #navigation-bar .navigation-content.type_menu_3.mobile #site-navigation {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
}


header #navigation-bar .navigation-content.type_menu_3 .site-menu {
    width: 100%;
}

header #navigation-bar .navigation-content.type_menu_3 .site-menu #site-navigation {
    display: flex;
    align-items: center;
    width: 100%;
}


/*type_menu_4*/

.navigation-content.type_menu_4 .menu-toggle {
    display: none;
}

header #navigation-bar .navigation-content.type_menu_4 .site-menu #site-navigation {
    width: 100%;
}

header #navigation-bar .navigation-content.type_menu_4 .site-menu #site-navigation .menu {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    padding: 0;
    margin: 0;
}

header #navigation-bar .navigation-content.type_menu_4 .banner_wrapper p {
    margin-bottom: 0;
}

header #navigation-bar .navigation-content.type_menu_5 .menu-toggle {
    right: 0;
}

header #navigation-bar .navigation-content.type_menu_5 .site-branding,
header #navigation-bar .navigation-content.type_menu_6 .site-branding {
    width: auto;
}

/*type_menu_7*/

.menu-toggle,
#navigation-bar button {
    display: flex;
    align-items: center;
    gap: 6px;
    background: none;
    border: none;
    padding: 0;
    font-weight: 500;
    color: var(--text-color);
}

/**************************custom************************/

.material-icons {
    font-family: "Material Icons";
    font-weight: normal;
    font-style: normal;
    font-size: 24px;
    /* Preferred icon size */
    display: inline-block;
    line-height: 1;
    text-transform: none;
    letter-spacing: normal;
    word-wrap: normal;
    white-space: nowrap;
    direction: ltr;
    transition: all 0.3s linear;

    /* Support for all WebKit browsers. */
    -webkit-font-smoothing: antialiased;
    /* Support for Safari and Chrome. */
    text-rendering: optimizeLegibility;

    /* Support for Firefox. */
    -moz-osx-font-smoothing: grayscale;

    /* Support for IE. */
    font-feature-settings: "liga";
}

.padding-12col-left {
    padding-left: calc(var(--w-container) / 12);
}

.padding-12col-right {
    padding-right: calc(var(--w-container) / 12);
}

.padding-6col-left {
    padding-left: calc(var(--w-container) / 6);
}

.padding-6col-right {
    padding-right: calc(var(--w-container) / 6);
}

.padding-8col-left {
    padding-left: calc(var(--w-container) / 8);
}

.padding-8col-right {
    padding-right: calc(var(--w-container) / 8);
}

.fit-cover {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.cursor-pointer {
    cursor: pointer;
}

.owl-item {
    display: inline-block;
    vertical-align: top;
}

.owl-nav.disabled,
.owl-dots.disabled {
    display: none;
}

.container-allineato-dx>.col-50:first-child {
    padding-left: var(--single-padding-esterno);
}

.container-allineato-sx>.col-50:last-child {
    padding-right: var(--single-padding-esterno);
}


html.desktop.megamenu-aperto {
    overflow: hidden !important;
}

.text-stroke-100 {
    -webkit-text-stroke: 1px;
    text-stroke: 1px;
}

.text-stroke-050 {
    -webkit-text-stroke: 0.5px;
    text-stroke: 0.5px;
}

.text-stroke-025 {
    -webkit-text-stroke: 0.25px;
    text-stroke: 0.25px;
}

.text-stroke-015 {
    -webkit-text-stroke: 0.15px;
    text-stroke: 0.15px;
}

.blurred {
    /* Note: currently only Safari supports backdrop-filter */
    backdrop-filter: blur(30px);
    --webkit-backdrop-filter: blur(30px);
    background-color: rgba(255, 255, 255, 0.15);
}

.opacity-09 {
    opacity: 0.9;
}

.opacity-08 {
    opacity: 0.8;
}

.opacity-07 {
    opacity: 0.7;
}

.opacity-06 {
    opacity: 0.6;
}

.opacity-05 {
    opacity: 0.5;
}

.opacity-04 {
    opacity: 0.4;
}

.opacity-03 {
    opacity: 0.3;
}

.opacity-02 {
    opacity: 0.2;
}

.opacity-01 {
    opacity: 0.1;
}

.opacity-00 {
    opacity: 0;
}

.letter-spacing-010 {
    letter-spacing: 0.1em;
}

.letter-spacing-015 {
    letter-spacing: 0.15em;
}

.letter-spacing-025 {
    letter-spacing: 0.25em;
}

.letter-spacing-035 {
    letter-spacing: 0.35em;
}

.letter-spacing-045 {
    letter-spacing: 0.45em;
}

.letter-spacing-055 {
    letter-spacing: 0.55em;
}

.border-radius-05 {
    border-radius: 5px;
}

.border-radius-10 {
    border-radius: 10px;
}

.border-radius-15 {
    border-radius: 15px;
}

.border-radius-20 {
    border-radius: 20px;
}

.ratio-1-1,
.aspect-ratio-1 {
    aspect-ratio: 1 / 1;
}

.ratio-3-2 {
    aspect-ratio: 3 / 2;
}

.ratio-4-3 {
    aspect-ratio: 4 / 3;
}

.ratio-16-9 {
    aspect-ratio: 16 / 9;
}

/* CUSTOM CSS */

/* SINGLE STYLES */

.site-branding>.logo-container>a>svg {
    max-height: 60px;
    width: 100%;
    height: auto;
}

.no-overflow {
    overflow: hidden;
}


/* font */
.font-36,
.font-36 p {
    font: normal normal normal 15px/21px var(--font-principale);
}

.font-15,
.font-15 p {
    font: normal normal normal 15px/21px var(--font-principale);
}

.font-14,
.font-14 p {
    font: normal normal bold 14px/17px var(--font-secondario);
}

.font-12,
.font-12 p {
    font: normal normal normal 12px/15px var(--font-principale);
}

.font-11,
.font-11 p {
    font: normal normal normal 11px/25px var(--font-principale);
}

/*addtoany_shortcode*/
.addtoany_shortcode>.a2a_kit {
    /*display: flex;
    flex-direction: row;
    gap: 8px;*/
	text-align: center;
    align-items: center;
}

.addtoany_shortcode>.addtoany_list a {
    width: 32px;
    height: 32px;
    border-radius: 32px;
    border: 1px solid #333333;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: background 0.25s ease;
	margin:0 10px;
}

.addtoany_shortcode>.addtoany_list>a:hover,
.addtoany_shortcode>.addtoany_list>a:focus {
    background: black !important;
    border: 2px solid black !important;
}

.addtoany_shortcode>.addtoany_list>a * {
    transition: all 0.25s ease;
}

.addtoany_shortcode>.addtoany_list>a:hover *,
.addtoany_shortcode>.addtoany_list>a:focus * {
    fill: #fff !important;
    opacity: 1 !important;
}

.addtoany_shortcode>.addtoany_list>a>span {
    display: block !important;
    line-height: 1 !important;
    height: auto !important;
}

/* border */
.border2bottom-black {
    border-bottom: 2px solid black;
}

.border2top-black {
    border-top: 2px solid black;
}

.border2sx-black {
    border-left: 2px solid black;
}

.border2-black {
    border: 2px solid black;
}

.border1top-white-semi {
    border-top: 1px solid rgba(255, 255, 255, 0.5);
}

.flex.flex-column.padding20.border2-black {
    border-left: 0px !important;
}

.border1bottom-gray {
    border-bottom: 1px solid var(--gray-border);
}

.border2bottom-gray {
    border-bottom: 2px solid var(--gray-border);
}


body.single section#visore>.contenuto>.col-100 {
    padding: var(--padding-header);
    padding-top: calc(var(--navbar-height) + 30px);
    padding-bottom: calc(45px + 30px);
    max-width: 2560px;
    margin: 0 auto;
}

/* Side nav */


.disable-scroll {
    overflow: hidden;
    position: fixed;
    width: 100%;
}

#page {
    overflow: hidden;
}

#sideNav .search-container .search-form > label {
    display: block;
    width: 100%;
    margin-top: 10px;
}
#sideNav .search-container .search-form > label .search-field {
    width: 100%;
    min-height: 40px;
    border: 1px solid #00000060;
    border-radius: 10px !important;
    padding: 0 40px 0 10px;
}
#sideNav .search-container .search-form > .search-submit {
    position: absolute;
    right: 10px;
}
header #action-bar ul li.menu-item-has-children {
    display: flex;
    align-items: center;
}
.navigation-content .site-menu nav#site-navigation ul.menu li.menu-item-has-children {
    display: flex;
    align-items: center;
    gap: 8px;
    position: relative;
    cursor: pointer;
}

.navigation-content .site-menu nav#site-navigation ul.menu li.menu-item-has-children ul.sub-menu,
header #action-bar ul li.menu-item-has-children ul.sub-menu{
    display: none;
}

.navigation-content .site-menu nav#site-navigation ul.menu li.menu-item-has-children ul.sub-menu.active,
header #action-bar ul li.menu-item-has-children ul.sub-menu.active {
    display: flex;
    flex-direction: column;
    position: absolute;
    top: calc(var(--navbar-height) / 2);
    padding: 0;
    margin: 0;
}
.menu-toggle {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    background-color: transparent;
    padding: 0;
    border: 0;
    height: 48px;
    width: 48px;
}

.menu-toggle .material-symbols-outlined {
    font-size: 32px;
}


.closeSidenav {
    position: absolute;
    right: 0;
    top: 0;
    width: 48px;
    height: 48px;
}


.sideNav ul {
    list-style-type: none;
    margin: 0;
    padding: 0;
}

.sideNav .menu li {
    padding: 8px 0;
}


.sideNav-container div#sideNav {
    -webkit-box-shadow: 2px 0px 10px -1px rgba(120, 120, 120, 0.29);
    box-shadow: 2px 0px 10px -1px rgba(120, 120, 120, 0.29);
}


.sideNav-container div#sideNav,
.sideNav .menu-item-has-children .sub-menu {
    transform: translateX(150%);
    position: absolute;
    top: 0;
    right: 0;
    width: var(--sideNav-width);
    margin-left: 0;
    z-index: 100;
    background-color: white;
    transition: transform 0.3s ease;
    display: flex;
    flex-direction: column;
}

.sideNav .menu-item-has-children .sub-menu .menu-item {
    padding: calc(var(--sideNav-paddingY) - 5px) var(--sideNav-paddingX);

}

.sideNav .menu-item-has-children .sub-menu,
.sideNav-container div#sideNav {
    height: var(--viewportHeight);
}


.sideNav-container.active div#sideNav,
.sideNav .menu-item-has-children .sub-menu.active {
    transform: translateX(0);
}


.menu-item-wrapper {
    display: flex;
    align-items: center;
}

.menu-item-wrapper a {
    flex: 1;
}

.sideNav .menu-centro {
    flex: 1;
    min-height: 0;
}


.sideNav .menu-centro,
.sideNav #form-cerca,
.sideNav .site-branding {
    border-bottom: solid 1px var(--gray-border);
    padding: var(--sideNav-paddingY) var(--sideNav-paddingX);
}

.sideNav .menu-bottom {
    padding: var(--sideNav-paddingY) var(--sideNav-paddingX);
}


.backBtn {
    display: flex;
    justify-content: end;
    border-bottom: 1px solid var(--gray-border);
    padding: var(--sideNav-paddingY) var(--sideNav-paddingX);
    margin-bottom: var(--sideNav-paddingY);
}

/* SEARCH */


.action-txt {
    font-family: var(--family-p);
}

.search-submit,
.btn-search {
    display: flex;
    align-items: center;
    gap: 8px;
    border: none;
    background-color: transparent;
    margin: 0;
    padding: 0;
}

.visore .search {
    padding-top: calc(var(--navbar-height) + var(--spacing-2));
}

#navigation-bar .search-container .search-form {
    min-width: 250px
}

#navigation-bar .search-container {
    position: absolute;
    right: 0;
    top: 26px;
    transform: translateY(50%);
}

#navigation-bar .search-container .search-form .search-field {
    width: 100%;
    padding: 8px 40px 8px 20px;
    border: 1px solid #00000060;
    border-radius: 10px;
}

#navigation-bar .search-container .search-form .search-submit {
    color: #000;
    position: absolute;
    right: 10px;
    top: 50%;
    transform: translateY(-50%)
}

/* INPUT SEARCH */

/* Remove bg default color from autofill in input search */

input[type="search"]:-webkit-autofill {
    -webkit-box-shadow: 0 0 0 1000px var(--background-color) inset;
    box-shadow: 0 0 0 1000px var(--background-color) inset;
    background-color: var(--background-color) !important;

}

/* Para Firefox */
input[type="search"]:-moz-autofill {
    background-color: var(--background-color) !important;
    -moz-box-shadow: 0 0 0 1000px var(--background-color) inset;
    box-shadow: 0 0 0 1000px var(--background-color) inset;
}


/* Hides the default clear button in search input fields across different browsers */

input[type="search"]::-webkit-search-cancel-button,
input[type="search"]::-webkit-search-results-button,
input[type="search"]::-webkit-search-clear-button {
    -webkit-appearance: none;
    appearance: none;
    display: none;
}

input[type="search"]::-moz-search-clear-button {
    display: none;
}

input[type="search"]::-ms-clear {
    display: none;
}


#clear-button {
    padding: 0;
    background-color: transparent;
    border: none;
    margin: 0;
}

.truncate-multiline {
	display: -webkit-box !important;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}


.truncate-multiline3 {
	display: -webkit-box !important;
	-webkit-line-clamp: 3;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

/* Responsive */

.visible-xs {
    display: none !important;
    visibility: hidden !important;
}

@media screen and (max-width: 767px) {
    .hidden-xs {
        display: none;
        visibility: hidden;
    }

    .visible-xs {
        display: block !important;
        visibility: visible !important;
    }

    .flex-xs {
        display: flex !important;
        visibility: visible !important;
    }

    .col-100-flex-xs {
        flex-basis: 94%;
    }

    .col-100-xs {
        width: 100%;
    }

    .align-center-xs {
        text-align: center;
    }

    .align-left-xs {
        text-align: left;
    }

    .flex-row-rev-xs {
        flex-direction: row-reverse;
    }

    .flex-col-rev-xs {
        flex-direction: column-reverse;
    }

    .flex-column-xs {
        flex-direction: column;
    }

    .align-items-start-xs {
        align-items: flex-start;
    }

    .gap-5px-xs {
        gap: 5px;
    }

    .grid-col-45-30-25,
    .grid-col-30-45-25,
    .grid-col-33-33-33 {
        grid-template-columns: 100%;
    }

    .padding0-xs {
        padding: 0;
    }

    .padding0-xs-important {
        padding: 0 !important;
    }

    .padding0bottom-xs {
        padding-bottom: 0;
    }

    .margin0-xs {
        margin: 0;
    }

    .margin-25sx-xs {
        margin-left: -25px !important;
    }

    .margin-25dx-xs {
        margin-right: -25px !important;
    }

    .padding20top-xs {
        padding-top: 20px;
    }

    .padding20bottom-xs {
        padding-bottom: 20px;
    }

    .padding25side-xs {
        padding-right: 25px;
        padding-left: 25px;
    }

    .padding25side-xs-important,
    .title-h6.padding25side-xs-important {
        padding-right: 25px !important;
        padding-left: 25px !important;
    }

    .padding60bottom-xs {
        padding-bottom: 60px;
    }

    .ticker-heading {
        padding: 10px 25px;
    }

    .modal-content {
        width: auto;
        flex-direction: column-reverse;
    }

    .font13-xs {
        font-size: 13px;
    }

    .font-30-xs {
        font: normal normal bold 30px/36px var(--font-secondario);
    }

    img.full-width-xs {
        width: calc(100% + 50px);
        max-width: none;
    }

    .ratio-1-1-xs {
        aspect-ratio: 1 / 1;
    }

    .w100-xs {
        width: 100px;
    }

    .col-100-115px-xs {
        width: calc(100% - 115px);
    }

    .line-clamp-2-xs,
    .line-clamp-2-xs p {
        display: -webkit-box;
        -webkit-line-clamp: 2;
        -webkit-box-orient: vertical;
        overflow: hidden;
    }

    /*header xs*/


    /* .site-branding{
    margin-left: 60px;
  } */


    .site-branding svg {
        max-height: 30px;
        max-width: 110px;
    }


    #site-navigation {
        position: absolute;
        top: 15px;
        left: 25px;
    }

    .navigation-content.type_menu_2 .site-branding,
    .navigation-content.type_menu_3 .site-branding {
        margin-left: 0;
    }

    .navigation-content.type_menu_2 {
        position: relative;
    }

    .navigation-content.type_menu_2 .menu-toggle {
        position: absolute;
        top: 50%;
        transform: translateY(-50%);
        left: 25px;
    }


    .navigation-content.type_menu_2 #site-navigation {
        position: unset;
    }



    /* SIDE NAV */


    .sideNav .site-branding {
        margin-left: 0;
    }


    .img-copertina-xs {
        object-fit: contain;
        /* max-height:350px !important; */
    }



    /* SEARCH PAGE */
    .search .title-h2,
    .navigation.pagination {
        padding: 0 0px !important;
    }


    div.search-results {
        padding: 25px;
        row-gap: 16px;
    }

    .visore .search {
        padding-top: 0;
    }




}



@media screen and (max-width: 600px) {

    :root {
        --sideNav-width: 100%;
    }

}











/* CUSTOM FILE */

/* SINGLE STYLES */

.site-branding>.logo-container>a>svg {
    max-height: 60px;
    width: 100%;
    height: auto;
}

.no-overflow {
    overflow: hidden;
}

/* GAP */

.gap-5px {
    gap: 5px;
}

/* font */
.font-36,
.font-36 p {
    font: normal normal normal 15px/21px var(--font-principale);
}

.font-15,
.font-15 p {
    font: normal normal normal 15px/21px var(--font-principale);
}

.font-14,
.font-14 p {
    font: normal normal bold 14px/17px var(--font-secondario);
}

.font-12,
.font-12 p {
    font: normal normal normal 12px/15px var(--font-principale);
}

.font-11,
.font-11 p {
    font: normal normal normal 11px/25px var(--font-principale);
}

/*addtoany_shortcode*/
.addtoany_shortcode>.a2a_kit {
    /*display: flex;
    flex-direction: row;
    gap: 8px;*/
}

.addtoany_shortcode>.addtoany_list a {
    width: 32px;
    height: 32px;
    border-radius: 32px;
    border: 1px solid #333333;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: background 0.25s ease;
	padding: 0;
}

.addtoany_shortcode>.addtoany_list>a:hover,
.addtoany_shortcode>.addtoany_list>a:focus {
    background: #333333 !important;
    border: 1px solid #333333 !important;
}

.addtoany_shortcode>.addtoany_list>a * {
    transition: all 0.25s ease;
}

.addtoany_shortcode>.addtoany_list>a:hover *,
.addtoany_shortcode>.addtoany_list>a:focus * {
    fill: #fff !important;
    opacity: 1 !important;
}

.addtoany_shortcode>.addtoany_list>a>span {
    display: block !important;
    line-height: 1 !important;
    height: auto !important;
}

/* border */
.border2bottom-black {
    border-bottom: 2px solid black;
}

.border2top-black {
    border-top: 2px solid black;
}

.border2sx-black {
    border-left: 2px solid black;
}

.border2-black {
    border: 2px solid black;
}

.border1top-white-semi {
    border-top: 1px solid rgba(255, 255, 255, 0.5);
}

.flex.flex-column.padding20.border2-black {
    border-left: 0px !important;
}

.border1bottom-gray {
    border-bottom: 1px solid var(--gray-border);
}

.border2bottom-gray {
    border-bottom: 2px solid var(--gray-border);
}


body.single section#visore>.contenuto>.col-100 {
    padding: var(--padding-header);
    padding-top: calc(var(--navbar-height) + 30px);
    padding-bottom: calc(45px + 30px);
    max-width: 2560px;
    margin: 0 auto;
}

/* Side nav */


.disable-scroll {
    overflow: hidden;
    position: fixed;
    width: 100%;
}

#page {
    overflow: hidden;
}

.navigation-content .site-menu nav#site-navigation ul.menu li.menu-item-has-children ul.sub-menu {
    display: none;
}

.menu-toggle {
    position: relative;
    top: 0;
    transform: translateY(0%);
    background-color: transparent;
    padding: 0;
    border: 0;
    height: 48px;
    width: 48px;
}

.menu-toggle .material-symbols-outlined {
    font-size: 32px;
}


.closeSidenav {
    position: absolute;
    right: 0;
    top: 0;
    width: 48px;
    height: 48px;
}


.sideNav ul {
    list-style-type: none;
    margin: 0;
    padding: 0;
}

.sideNav .menu li {
    padding: 8px 0;
}


.sideNav-container div#sideNav {
    -webkit-box-shadow: 2px 0px 10px -1px rgba(120, 120, 120, 0.29);
    box-shadow: 2px 0px 10px -1px rgba(120, 120, 120, 0.29);
}

.sideNav-container div#sideNav,
.sideNav .menu-item-has-children .sub-menu {
    transform: translateX(150%);
    position: fixed;
    top: 0;
    right: 0;
    width: var(--sideNav-width);
    margin-left: 0;
    z-index: 100;
    background-color: white;
    transition: transform 0.3s ease;
    display: flex;
    flex-direction: column;
}



.sideNav .menu-item-has-children .sub-menu .menu-item {
    padding: calc(var(--sideNav-paddingY) - 5px) var(--sideNav-paddingX);

}

.sideNav .menu-item-has-children .sub-menu,
.sideNav-container div#sideNav {
    height: var(--viewportHeight);
}


.sideNav-container.active div#sideNav,
.sideNav .menu-item-has-children .sub-menu.active {
    transform: translateX(0);
}


.menu-item-wrapper {
    display: flex;
    align-items: center;
}

.menu-item-wrapper a {
    flex: 1;
}

.sideNav .menu-centro {
    flex: 1;
    min-height: 0;
}


.sideNav .menu-centro,
.sideNav #form-cerca,
.sideNav .site-branding {
    border-bottom: solid 1px var(--gray-border);
    padding: var(--sideNav-paddingY) var(--sideNav-paddingX);
}

.sideNav .menu-bottom {
    padding: var(--sideNav-paddingY) var(--sideNav-paddingX);
}


.backBtn {
    display: flex;
    justify-content: end;
    border-bottom: 1px solid var(--gray-border);
    padding: var(--sideNav-paddingY) var(--sideNav-paddingX);
    margin-bottom: var(--sideNav-paddingY);
}


/* Pagination */
.pagination {
    display: flex;
    gap: 10px;
    position: relative;
   /* border: 0 !important;*/
}

.pagination .page-numbers {
    width: 30px;
    height: 30px;
    font-size: 18px;
    line-height: 22px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    border: 1.5px solid var(--accent-color);
    color: var(--accent-color);
    font-weight: 500;
}

.pagination .page-numbers.current,
.pagination .page-numbers:hover {
    color: white;
    background: var(--accent-color);
}

.nav-links {
    display: flex;
    align-items: center;
    gap: 8px;
    width: 100%;
    justify-content: end;
}

/* SEARCH */


.action-txt {
    font-family: var(--family-p);
}

.search-submit,
.btn-search {
    display: flex;
    align-items: center;
    gap: 8px;
    border: none;
    background-color: transparent;
    margin: 0;
    padding: 0;
}

.search-submit {
    top: 50%;
    transform: translateY(-50%);
    right: 5%;

}


.visore .search {
    padding-top: calc(var(--navbar-height) + var(--spacing-2));
}

.owl-dots {
    margin-top: 20px;
}

/* INPUT SEARCH */

/* Remove bg default color from autofill in input search */

input[type="search"]:-webkit-autofill {
    -webkit-box-shadow: 0 0 0 1000px var(--background-color) inset;
    box-shadow: 0 0 0 1000px var(--background-color) inset;
    background-color: var(--background-color) !important;

}

/* Para Firefox */
input[type="search"]:-moz-autofill {
    background-color: var(--background-color) !important;
    -moz-box-shadow: 0 0 0 1000px var(--background-color) inset;
    box-shadow: 0 0 0 1000px var(--background-color) inset;
}


/* Hides the default clear button in search input fields across different browsers */

input[type="search"]::-webkit-search-cancel-button,
input[type="search"]::-webkit-search-results-button,
input[type="search"]::-webkit-search-clear-button {
    -webkit-appearance: none;
    appearance: none;
    display: none;
}

input[type="search"]::-moz-search-clear-button {
    display: none;
}

input[type="search"]::-ms-clear {
    display: none;
}


#clear-button {
    padding: 0;
    background-color: transparent;
    border: none;
    margin: 0;
}

/* SEARCH PAGE */

/* ARCHIVE PROD */
.container-content-sidebar,
.container-sidebar-content {
    display: flex;
    gap: 50px;
}

.container-sidebar-content {
    flex-direction: row-reverse;
}

.container-content-sidebar .content,
.container-sidebar-content .content {
    width: calc(100% - 400px);
}

.container-content-sidebar .sidebar,
.container-sidebar-content .sidebar {
    width: 100%;
    flex-basis: 100%;
    max-width: 350px;
    display: flex;
    flex-direction: column;
    flex-wrap: wrap;
    gap: 60px;
}

/* PRODUCT PAGE */
.woocommerce-page div.product div.images {
    width: 100%;
}

.woocommerce div.product form.cart div.quantity {
    float: none;
    margin-bottom: 20px;
}

.product_meta {
    display: flex;
    flex-direction: column;
    gap: 10px;
    margin-bottom: 15px;
}

.woocommerce div.product .woocommerce-tabs ul.tabs {
    padding-left: 0;
}

.woocommerce div.product .woocommerce-tabs ul.tabs li {
    margin: 0;
    background: #ffffff;
}

.woocommerce div.product .woocommerce-tabs ul.tabs li::before {
    content: none;
}

span.onsale,
.woocommerce span.onsale {
    position: absolute;
    left: 10px;
    top: 10px;
    line-height: 1;
    font-size: 12px;
    padding: 10px 20px;
    color: #ffffff;
    background: var(--accent-color);
    border-radius: 15px;
    min-height: 0;
    display: flex;
    align-items: center;
    justify-content: center;
}

.woocommerce:where(body:not(.woocommerce-uses-block-theme)) div.product p.price,
.woocommerce:where(body:not(.woocommerce-uses-block-theme)) div.product span.price {
    color: var(--accent-color);
}

html .owl-carousel .owl-nav button.owl-next,
html .owl-carousel .owl-nav button.owl-prev {
    position: absolute;
    bottom: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    line-height: 0 !important;
    background: var(--accent-color) !important;
    color: #ffffff !important;
    padding: 5px !important;
    border-radius: 50%;
}

.owl-carousel .owl-nav button.owl-next {
    right: 0;
}

html .centered-arrows-vertical {
    position: relative;
}

html .centered-arrows-vertical.owl-carousel .owl-nav {
    top: 50%;
    position: absolute;
    transform: translateY(-50%);
    width: 100%;
}
.woocommerce div.product div.images .woocommerce-product-gallery__image:nth-child(n+2){
    max-width: 100px;
}

html .woocommerce-product-gallery__wrapper.owl-carousel .owl-nav button.owl-next,
html .woocommerce-product-gallery__wrapper.owl-carousel .owl-nav button.owl-prev {
    background: #FFFFFF !important;
    border: 2px solid var(--accent-color);
    color: var(--accent-color) !important;
    font-size: 22px;
    aspect-ratio: 1;
    padding: 10px 10px 8px 10px !important;
    font-weight: 500;
}

html .owl-carousel .owl-nav button.owl-next>span>i,
html .owl-carousel .owl-nav button.owl-prev>span>i {
    font-size: 20px;
}

.woocommerce-product-gallery__wrapper .owl-dots {
    display: flex;
    justify-content: center;
    width: 100%;
    gap: 5px;
}

.woocommerce-product-gallery__wrapper .owl-dots .owl-dot {
    width: 100px !important;
    position: relative;
    height: 100px;
    border: none;
    padding: 0;
    background: transparent;
    overflow: hidden;
    opacity: 1 !important;
    margin: 0;
    display: block;
}

.woocommerce-product-gallery__wrapper .owl-dots .owl-dot.active {
    border-color: #5E351A;
}

.woocommerce-product-gallery__wrapper .owl-dots .owl-dot>button {
    height: 100%;
    width: 100%;
    background: transparent;
    position: relative;
    z-index: 2;
    cursor: pointer;
    border: none !important;
}

.woocommerce-product-gallery__wrapper .owl-dots .owl-dot>img {
    position: absolute;
    top: 0;
    z-index: 1;
}

.woocommerce-product-gallery__wrapper .owl-dots .owl-dot.active>button {
    pointer-events: none;
}

.woocommerce-product-gallery__wrapper .owl-item {
    padding: 70px 90px 110px 90px;
    background: #ffffff;
    border-radius: 10px;
}

.carosello-product-cont-right-nav,
.carosello-product-cont-left-nav {
    width: calc(100% - 115px);
}

.carosello-product-cont-left-nav{
    display: flex;
    justify-self: right;
}

.carosello-product-cont-right-nav .right-nav .owl-dots,
.carosello-product-cont-left-nav .left-nav .owl-dots {
    position: absolute;
    top: 0;
    display: flex;
    flex-direction: column;
    width: auto;
    margin-top: 0;
}

.carosello-product-cont-right-nav .right-nav .owl-dots{
    right: -15px;
    transform: translateX(100%);
}

.carosello-product-cont-left-nav .left-nav .owl-dots{
    left: -15px;
    transform: translateX(-100%);
}

.tinv-wishlist.tinvwl-after-add-to-cart .tinvwl_add_to_wishlist_button,
.tinv-wishlist.tinvwl-before-add-to-cart .tinvwl_add_to_wishlist_button {
    margin-bottom: 0;
    margin-top: 0;
}

.prod-card-content .add-to-cart-btn,
.tinv-wishlist.tinvwl-before-add-to-cart .tinvwl_add_to_wishlist_button {
    aspect-ratio: 1;
    display: flex !important;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    padding: 0;
}

.summary-prod-container .tinvwl-shortcode-add-to-cart{
    position: absolute;
    right: 0;
    z-index: 2;
    top: 10px;
}

.summary-prod-container .tinvwl-shortcode-add-to-cart > a{
    width: 30px !important;
    height: 30px !important;
}

.summary-prod-container .tinvwl-shortcode-add-to-cart > a:before {
    font-size: 30px !important;
    display: block !important;
    margin-left: 0 !important;
    margin-top: 0 !important;
    top: 0 !important;
    left: 0 !important;
}

mark,
ins,
.woocommerce div.product p.price ins,
.woocommerce div.product span.price ins {
    background: var(--accent-color);
    color: #ffffff;
    padding: 0 5px;
}

.star-rating {
    display: flex;
    align-items: center;
}

.rating_stelle {
    display: inline-block;
    font-size: 18px;
    line-height: 0;
    letter-spacing: -2px;
}

.rating_stelle::before {
    --rating-percent: calc(var(--rating-value) / var(--rating-max) * 100%);
    content: var(--rating-content);
    background: linear-gradient(90deg, var(--rating-background) var(--rating-percent), var(--rating-inactive-color) var(--rating-percent));
    background-clip: text;
    -webkit-background-clip: text;
    color: transparent;
    transition: all cubic-bezier(0.68, -0.55, 0.27, 1.55) 1.2s;
    transition-delay: 2s, 4ms;
    font-family: 'Material Icons';
}

.addtoany_header {
    margin: 10px 0 0 0;
}

.tinvwl-woocommerce_after_add_to_cart_button {
    display: flex;
    align-items: center;
}

.woocommerce.single div.product .woocommerce-tabs ul.tabs li.active {
    background: var(--accent-color);
    color: #ffffff;
}

.woocommerce.single div.product .woocommerce-tabs ul.tabs li::after {
    content: none;
}

.woocommerce div.product .woocommerce-tabs ul.tabs li a {
    display: block;
}

.woocommerce div.product .woocommerce-tabs .single-faq h2 {
    font-size: var(--size-h4);
    line-height: var(--lineH-h4);
    font-weight: var(--weight-h4);
    letter-spacing: var(--spacing-h4);
}

.woocommerce div.product .woocommerce-product-rating {
    margin-bottom: 0;
}

.woocommerce .star-rating::before {
    content: none;
}

.banner-bottom{
    position: fixed;
    bottom: 0;
    left: 0;
    z-index: 1;
    background: #ffffff;
    width: 100%;
}

.product-summary-ras .block-ras{
    width: 100% !important;
}

.product-summary-ras .block-ras > div{
    justify-content: start !important;
}

.block-ras-icon {
    height: 58px;
    width: 58px;
    aspect-ratio: 1;
    border: 2px solid;
    border-radius: 50%;
    display: flex;
    justify-content: center;
    align-items: center;
}

.block-ras-icon>span {
    font-size: 25px;
}

.h1-hidden {
    position: absolute;
    clip: rect(1px, 1px, 1px, 1px);
    -webkit-clip-path: inset(0px 0px 99.9% 99.9%);
    clip-path: inset(0px 0px 99.9% 99.9%);
    overflow: hidden;
    height: 1px;
    width: 1px;
    padding: 0;
    border: 0;
}

.sr-only {
    position: absolute !important;
    width: 1px !important;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
    color: #ffffff !important;
    background: #000000 !important;
}
/* Responsive */

.visible-xs {
    display: none !important;
    visibility: hidden !important;
}

@media screen and (max-width: 767px) {
    .hidden-xs {
        display: none;
        visibility: hidden;
    }

    .visible-xs {
        display: block !important;
        visibility: visible !important;
    }

    .flex-xs {
        display: flex !important;
        visibility: visible !important;
    }

    .col-100-flex-xs {
        flex-basis: 94%;
    }

    .col-100-xs {
        width: 100%;
    }

    .align-center-xs {
        text-align: center;
    }

    .align-left-xs {
        text-align: left;
    }

    .flex-row-rev-xs {
        flex-direction: row-reverse;
    }

    .flex-col-rev-xs {
        flex-direction: column-reverse;
    }

    .flex-column-xs {
        flex-direction: column;
    }

    .align-items-start-xs {
        align-items: flex-start;
    }

    .gap-5px-xs {
        gap: 5px;
    }

    .grid-col-45-30-25,
    .grid-col-30-45-25,
    .grid-col-33-33-33 {
        grid-template-columns: 100%;
    }

    .padding0-xs {
        padding: 0;
    }

    .padding0-xs-important {
        padding: 0 !important;
    }

    .padding0bottom-xs {
        padding-bottom: 0;
    }

    .margin0-xs {
        margin: 0;
    }

    .margin-25sx-xs {
        margin-left: -25px !important;
    }

    .margin-25dx-xs {
        margin-right: -25px !important;
    }

    .padding20top-xs {
        padding-top: 20px;
    }

    .padding20bottom-xs {
        padding-bottom: 20px;
    }

    .padding25side-xs {
        padding-right: 25px;
        padding-left: 25px;
    }

    .padding25side-xs-important,
    .title-h6.padding25side-xs-important {
        padding-right: 25px !important;
        padding-left: 25px !important;
    }

    .padding60bottom-xs {
        padding-bottom: 60px;
    }

    .ticker-heading {
        padding: 10px 25px;
    }

    .modal-content {
        width: auto;
        flex-direction: column-reverse;
    }

    .font13-xs {
        font-size: 13px;
    }

    .font-30-xs {
        font: normal normal bold 30px/36px var(--font-secondario);
    }

    img.full-width-xs {
        width: calc(100% + 50px);
        max-width: none;
    }

    .ratio-1-1-xs {
        aspect-ratio: 1 / 1;
    }

    .w100-xs {
        width: 100px;
    }

    .col-100-115px-xs {
        width: calc(100% - 115px);
    }

    .line-clamp-2-xs,
    .line-clamp-2-xs p {
        display: -webkit-box;
        -webkit-line-clamp: 2;
        -webkit-box-orient: vertical;
        overflow: hidden;
    }

    /*header xs*/


    /* .site-branding{
	  margin-left: 60px;
	} */


    .site-branding svg {
        max-height: 30px;
        max-width: 110px;
    }


    #site-navigation {
        position: absolute;
        top: 15px;
        left: 25px;
    }

    .navigation-content.type_menu_2 .site-branding,
    .navigation-content.type_menu_3 .site-branding {
        margin-left: 0;
    }

    .navigation-content.type_menu_2 {
        position: relative;
    }

    .navigation-content.type_menu_2 .menu-toggle {
        position: absolute;
        top: 50%;
        transform: translateY(-50%);
        left: 25px;
    }


    .navigation-content.type_menu_2 #site-navigation {
        position: unset;
    }

    /* SIDE NAV */


    .sideNav .site-branding {
        margin-left: 0;
    }


    .img-copertina-xs {
        object-fit: contain;
        /* max-height:350px !important; */
    }



    /* SEARCH PAGE */
    .search .title-h2,
    .navigation.pagination {
        padding: 0 0px !important;
    }


    div.search-results {
        padding: 25px;
        row-gap: 16px;
    }

    .visore .search {
        padding-top: 0;
    }
}

@media screen and (max-width: 600px) {
    :root {
        --sideNav-width: 100%;
    }
}