@charset "UTF-8";
/* Stili per l'header */
header {
  color: #FFFFFF;
}

.site-header {
  background-color: #004990;
  padding: 10px 0;
  color: #fff;
}
.site-header .logo a {
  display: inline-block;
}
.site-header .logo a img {
  max-width: 100%;
  height: auto;
}
.site-header .site-title h1 {
  margin: 0;
  font-size: 1.5rem;
  color: #fff;
}
.site-header .site-title .site-description {
  font-size: 1rem;
  color: #dcdcdc;
}
.site-header .navbar-toggler {
  background-color: #fff;
  border: none;
  padding: 8px 12px;
  border-radius: 4px;
}
.site-header .navbar-toggler .navbar-toggler-icon {
  background-color: #004990;
  display: block;
  width: 30px;
  height: 3px;
  margin: 5px 0;
}

/* Stili responsive per l'header */
@media (max-width: 768px) {
  .site-header .site-title h1 {
    font-size: 1.2rem;
  }
  .site-header .site-description {
    font-size: 0.9rem;
  }
}
/* Admin Toolbar */
.toolbar-horizontal.toolbar-tray-open header {
  top: 80px !important;
}

.toolbar-horizontal header,
.toolbar-vertical header {
  top: 40px !important;
}

/* Gestione del main rispoetto all'header variabile */
.user-login-form .form-control {
  padding: 10px 15px;
}

/* Admin attivo con toolbar attiva */
.toolbar-horizontal.toolbar-tray-open main {
  padding-top: 169px;
  flex: 1;
}

.toolbar-horizontal {
  flex: 1;
}

.toolbar-horizontal .dialog-off-canvas-main-canvas {
  min-height: 100vh; /* Altezza minima pari all'altezza della viewport */
}

/* Admin attivo con toolbar chiusa */
.toolbar-horizontal main,
.toolbar-vertical main {
  padding-top: 169px;
}

/* Admin NON attivo  */
main {
  padding-top: 169px;
}

/* Stili per il menu principale */
.main-menu {
  display: flex;
  justify-content: center;
}
.main-menu ul {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex; /* Dispone gli elementi del menu orizzontalmente */
}
.main-menu li {
  margin-right: 20px;
}
.main-menu li:last-child {
  margin-right: 0; /* Rimuovi l'ultimo margine destro */
}
.main-menu a {
  text-decoration: none;
  color: #fff;
  font-weight: bold;
  padding: 5px 10px;
  transition: background-color 0.3s ease;
}
.main-menu a:hover {
  background-color: #003366; /* Effetto hover */
}

/* Stili per il menu mobile */
#mobile-menu {
  background-color: #003366;
  padding: 15px;
}
#mobile-menu ul {
  list-style: none;
  padding: 0;
  margin: 0;
}
#mobile-menu ul li {
  margin-bottom: 10px;
}
#mobile-menu ul li a {
  text-decoration: none;
  color: #fff;
}

/* Stili responsive per il menu */
@media (max-width: 768px) {
  .main-menu {
    display: none; /* Nasconde il menu principale su mobile */
  }
  .header-bottom {
    display: none !important;
  }
  #mobile-menu {
    display: block;
  }
}
/* Titillium+Web:300,400,600,700 */
/* titillium-web-300 - latin-ext_latin */
@font-face {
  font-family: "Titillium Web";
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url("../fonts/Titillium_Web/titillium-web-v10-latin-ext_latin-300.eot"); /* IE9 Compat Modes */
  src: local(""), url("../fonts/Titillium_Web/titillium-web-v10-latin-ext_latin-300.eot?#iefix") format("embedded-opentype"), url("../fonts/Titillium_Web/titillium-web-v10-latin-ext_latin-300.woff2") format("woff2"), url("../fonts/Titillium_Web/titillium-web-v10-latin-ext_latin-300.woff") format("woff"), url("../fonts/Titillium_Web/titillium-web-v10-latin-ext_latin-300.ttf") format("truetype"), url("../fonts/Titillium_Web/titillium-web-v10-latin-ext_latin-300.svg#TitilliumWeb") format("svg"); /* Legacy iOS */
}
/* titillium-web-300italic - latin-ext_latin */
@font-face {
  font-family: "Titillium Web";
  font-style: italic;
  font-weight: 300;
  font-display: swap;
  src: url("../fonts/Titillium_Web/titillium-web-v10-latin-ext_latin-300italic.eot"); /* IE9 Compat Modes */
  src: local(""), url("../fonts/Titillium_Web/titillium-web-v10-latin-ext_latin-300italic.eot?#iefix") format("embedded-opentype"), url("../fonts/Titillium_Web/titillium-web-v10-latin-ext_latin-300italic.woff2") format("woff2"), url("../fonts/Titillium_Web/titillium-web-v10-latin-ext_latin-300italic.woff") format("woff"), url("../fonts/Titillium_Web/titillium-web-v10-latin-ext_latin-300italic.ttf") format("truetype"), url("../fonts/Titillium_Web/titillium-web-v10-latin-ext_latin-300italic.svg#TitilliumWeb") format("svg"); /* Legacy iOS */
}
/* titillium-web-regular - latin-ext_latin */
@font-face {
  font-family: "Titillium Web";
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/Titillium_Web/titillium-web-v10-latin-ext_latin-regular.eot"); /* IE9 Compat Modes */
  src: local(""), url("../fonts/Titillium_Web/titillium-web-v10-latin-ext_latin-regular.eot?#iefix") format("embedded-opentype"), url("../fonts/Titillium_Web/titillium-web-v10-latin-ext_latin-regular.woff2") format("woff2"), url("../fonts/Titillium_Web/titillium-web-v10-latin-ext_latin-regular.woff") format("woff"), url("../fonts/Titillium_Web/titillium-web-v10-latin-ext_latin-regular.ttf") format("truetype"), url("../fonts/Titillium_Web/titillium-web-v10-latin-ext_latin-regular.svg#TitilliumWeb") format("svg"); /* Legacy iOS */
}
/* titillium-web-italic - latin-ext_latin */
@font-face {
  font-family: "Titillium Web";
  font-style: italic;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/Titillium_Web/titillium-web-v10-latin-ext_latin-italic.eot"); /* IE9 Compat Modes */
  src: local(""), url("../fonts/Titillium_Web/titillium-web-v10-latin-ext_latin-italic.eot?#iefix") format("embedded-opentype"), url("../fonts/Titillium_Web/titillium-web-v10-latin-ext_latin-italic.woff2") format("woff2"), url("../fonts/Titillium_Web/titillium-web-v10-latin-ext_latin-italic.woff") format("woff"), url("../fonts/Titillium_Web/titillium-web-v10-latin-ext_latin-italic.ttf") format("truetype"), url("../fonts/Titillium_Web/titillium-web-v10-latin-ext_latin-italic.svg#TitilliumWeb") format("svg"); /* Legacy iOS */
}
/* titillium-web-700 - latin-ext_latin */
@font-face {
  font-family: "Titillium Web";
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("../fonts/Titillium_Web/titillium-web-v10-latin-ext_latin-700.eot"); /* IE9 Compat Modes */
  src: local(""), url("../fonts/Titillium_Web/titillium-web-v10-latin-ext_latin-700.eot?#iefix") format("embedded-opentype"), url("../fonts/Titillium_Web/titillium-web-v10-latin-ext_latin-700.woff2") format("woff2"), url("../fonts/Titillium_Web/titillium-web-v10-latin-ext_latin-700.woff") format("woff"), url("../fonts/Titillium_Web/titillium-web-v10-latin-ext_latin-700.ttf") format("truetype"), url("../fonts/Titillium_Web/titillium-web-v10-latin-ext_latin-700.svg#TitilliumWeb") format("svg"); /* Legacy iOS */
}
/* titillium-web-700italic - latin-ext_latin */
@font-face {
  font-family: "Titillium Web";
  font-style: italic;
  font-weight: 700;
  font-display: swap;
  src: url("../fonts/Titillium_Web/titillium-web-v10-latin-ext_latin-700italic.eot"); /* IE9 Compat Modes */
  src: local(""), url("../fonts/Titillium_Web/titillium-web-v10-latin-ext_latin-700italic.eot?#iefix") format("embedded-opentype"), url("../fonts/Titillium_Web/titillium-web-v10-latin-ext_latin-700italic.woff2") format("woff2"), url("../fonts/Titillium_Web/titillium-web-v10-latin-ext_latin-700italic.woff") format("woff"), url("../fonts/Titillium_Web/titillium-web-v10-latin-ext_latin-700italic.ttf") format("truetype"), url("../fonts/Titillium_Web/titillium-web-v10-latin-ext_latin-700italic.svg#TitilliumWeb") format("svg"); /* Legacy iOS */
}
/* titillium-web-600 - latin-ext_latin */
@font-face {
  font-family: "Titillium Web";
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("../fonts/Titillium_Web/titillium-web-v10-latin-ext_latin-600.eot"); /* IE9 Compat Modes */
  src: local(""), url("../fonts/Titillium_Web/titillium-web-v10-latin-ext_latin-600.eot?#iefix") format("embedded-opentype"), url("../fonts/Titillium_Web/titillium-web-v10-latin-ext_latin-600.woff2") format("woff2"), url("../fonts/Titillium_Web/titillium-web-v10-latin-ext_latin-600.woff") format("woff"), url("../fonts/Titillium_Web/titillium-web-v10-latin-ext_latin-600.ttf") format("truetype"), url("../fonts/Titillium_Web/titillium-web-v10-latin-ext_latin-600.svg#TitilliumWeb") format("svg"); /* Legacy iOS */
}
/* titillium-web-600italic - latin-ext_latin */
@font-face {
  font-family: "Titillium Web";
  font-style: italic;
  font-weight: 600;
  font-display: swap;
  src: url("../fonts/Titillium_Web/titillium-web-v10-latin-ext_latin-600italic.eot"); /* IE9 Compat Modes */
  src: local(""), url("../fonts/Titillium_Web/titillium-web-v10-latin-ext_latin-600italic.eot?#iefix") format("embedded-opentype"), url("../fonts/Titillium_Web/titillium-web-v10-latin-ext_latin-600italic.woff2") format("woff2"), url("../fonts/Titillium_Web/titillium-web-v10-latin-ext_latin-600italic.woff") format("woff"), url("../fonts/Titillium_Web/titillium-web-v10-latin-ext_latin-600italic.ttf") format("truetype"), url("../fonts/Titillium_Web/titillium-web-v10-latin-ext_latin-600italic.svg#TitilliumWeb") format("svg"); /* Legacy iOS */
}
/* Lora:400,700 */
/* lora-regular - latin-ext_latin */
@font-face {
  font-family: "Lora";
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/Lora/lora-v20-latin-ext_latin-regular.eot"); /* IE9 Compat Modes */
  src: local(""), url("../fonts/Lora/lora-v20-latin-ext_latin-regular.eot?#iefix") format("embedded-opentype"), url("../fonts/Lora/lora-v20-latin-ext_latin-regular.woff2") format("woff2"), url("../fonts/Lora/lora-v20-latin-ext_latin-regular.woff") format("woff"), url("../fonts/Lora/lora-v20-latin-ext_latin-regular.ttf") format("truetype"), url("../fonts/Lora/lora-v20-latin-ext_latin-regular.svg#Lora") format("svg"); /* Legacy iOS */
}
/* lora-700 - latin-ext_latin */
@font-face {
  font-family: "Lora";
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("../fonts/Lora/lora-v20-latin-ext_latin-700.eot"); /* IE9 Compat Modes */
  src: local(""), url("../fonts/Lora/lora-v20-latin-ext_latin-700.eot?#iefix") format("embedded-opentype"), url("../fonts/Lora/lora-v20-latin-ext_latin-700.woff2") format("woff2"), url("../fonts/Lora/lora-v20-latin-ext_latin-700.woff") format("woff"), url("../fonts/Lora/lora-v20-latin-ext_latin-700.ttf") format("truetype"), url("../fonts/Lora/lora-v20-latin-ext_latin-700.svg#Lora") format("svg"); /* Legacy iOS */
}
/* lora-italic - latin-ext_latin */
@font-face {
  font-family: "Lora";
  font-style: italic;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/Lora/lora-v20-latin-ext_latin-italic.eot"); /* IE9 Compat Modes */
  src: local(""), url("../fonts/Lora/lora-v20-latin-ext_latin-italic.eot?#iefix") format("embedded-opentype"), url("../fonts/Lora/lora-v20-latin-ext_latin-italic.woff2") format("woff2"), url("../fonts/Lora/lora-v20-latin-ext_latin-italic.woff") format("woff"), url("../fonts/Lora/lora-v20-latin-ext_latin-italic.ttf") format("truetype"), url("../fonts/Lora/lora-v20-latin-ext_latin-italic.svg#Lora") format("svg"); /* Legacy iOS */
}
/* lora-700italic - latin-ext_latin */
@font-face {
  font-family: "Lora";
  font-style: italic;
  font-weight: 700;
  font-display: swap;
  src: url("../fonts/Lora/lora-v20-latin-ext_latin-700italic.eot"); /* IE9 Compat Modes */
  src: local(""), url("../fonts/Lora/lora-v20-latin-ext_latin-700italic.eot?#iefix") format("embedded-opentype"), url("../fonts/Lora/lora-v20-latin-ext_latin-700italic.woff2") format("woff2"), url("../fonts/Lora/lora-v20-latin-ext_latin-700italic.woff") format("woff"), url("../fonts/Lora/lora-v20-latin-ext_latin-700italic.ttf") format("truetype"), url("../fonts/Lora/lora-v20-latin-ext_latin-700italic.svg#Lora") format("svg"); /* Legacy iOS */
}
/* Roboto+Mono:400,700 */
/* roboto-mono-regular - latin-ext_latin */
@font-face {
  font-family: "Roboto Mono";
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/Roboto_Mono/roboto-mono-v13-latin-ext_latin-regular.eot"); /* IE9 Compat Modes */
  src: local(""), url("../fonts/Roboto_Mono/roboto-mono-v13-latin-ext_latin-regular.eot?#iefix") format("embedded-opentype"), url("../fonts/Roboto_Mono/roboto-mono-v13-latin-ext_latin-regular.woff2") format("woff2"), url("../fonts/Roboto_Mono/roboto-mono-v13-latin-ext_latin-regular.woff") format("woff"), url("../fonts/Roboto_Mono/roboto-mono-v13-latin-ext_latin-regular.ttf") format("truetype"), url("../fonts/Roboto_Mono/roboto-mono-v13-latin-ext_latin-regular.svg#RobotoMono") format("svg"); /* Legacy iOS */
}
/* roboto-mono-700 - latin-ext_latin */
@font-face {
  font-family: "Roboto Mono";
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("../fonts/Roboto_Mono/roboto-mono-v13-latin-ext_latin-700.eot"); /* IE9 Compat Modes */
  src: local(""), url("../fonts/Roboto_Mono/roboto-mono-v13-latin-ext_latin-700.eot?#iefix") format("embedded-opentype"), url("../fonts/Roboto_Mono/roboto-mono-v13-latin-ext_latin-700.woff2") format("woff2"), url("../fonts/Roboto_Mono/roboto-mono-v13-latin-ext_latin-700.woff") format("woff"), url("../fonts/Roboto_Mono/roboto-mono-v13-latin-ext_latin-700.ttf") format("truetype"), url("../fonts/Roboto_Mono/roboto-mono-v13-latin-ext_latin-700.svg#RobotoMono") format("svg"); /* Legacy iOS */
}
/* roboto-mono-italic - latin-ext_latin */
@font-face {
  font-family: "Roboto Mono";
  font-style: italic;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/Roboto_Mono/roboto-mono-v13-latin-ext_latin-italic.eot"); /* IE9 Compat Modes */
  src: local(""), url("../fonts/Roboto_Mono/roboto-mono-v13-latin-ext_latin-italic.eot?#iefix") format("embedded-opentype"), url("../fonts/Roboto_Mono/roboto-mono-v13-latin-ext_latin-italic.woff2") format("woff2"), url("../fonts/Roboto_Mono/roboto-mono-v13-latin-ext_latin-italic.woff") format("woff"), url("../fonts/Roboto_Mono/roboto-mono-v13-latin-ext_latin-italic.ttf") format("truetype"), url("../fonts/Roboto_Mono/roboto-mono-v13-latin-ext_latin-italic.svg#RobotoMono") format("svg"); /* Legacy iOS */
}
/* roboto-mono-700italic - latin-ext_latin */
@font-face {
  font-family: "Roboto Mono";
  font-style: italic;
  font-weight: 700;
  font-display: swap;
  src: url("../fonts/Roboto_Mono/roboto-mono-v13-latin-ext_latin-700italic.eot"); /* IE9 Compat Modes */
  src: local(""), url("../fonts/Roboto_Mono/roboto-mono-v13-latin-ext_latin-700italic.eot?#iefix") format("embedded-opentype"), url("../fonts/Roboto_Mono/roboto-mono-v13-latin-ext_latin-700italic.woff2") format("woff2"), url("../fonts/Roboto_Mono/roboto-mono-v13-latin-ext_latin-700italic.woff") format("woff"), url("../fonts/Roboto_Mono/roboto-mono-v13-latin-ext_latin-700italic.ttf") format("truetype"), url("../fonts/Roboto_Mono/roboto-mono-v13-latin-ext_latin-700italic.svg#RobotoMono") format("svg"); /* Legacy iOS */
}
/**
 * Form
*/
/* Button */
.btn {
  height: 48px;
  display: inline-flex;
  flex-wrap: nowrap;
  flex-direction: row;
  align-items: center;
  justify-content: center;
  white-space: nowrap;
}

.btn.btn-lg {
  height: 60px;
}

.btn.btn-sm {
  height: 40px;
}

.btn > span + .icon,
.btn > .icon + .avatar,
.btn > .avatar + span,
.btn > .icon + .icon,
.btn > .icon + span {
  margin-left: 8px;
}

/* Button - Icon */
.btn .icon {
  --bs-icon-fill:var(--bs-btn-color);
}

.btn:not(:disabled):hover .icon {
  --bs-icon-fill:var(--bs-btn-hover-color);
}

.btn:not(:disabled):active .icon {
  --bs-icon-fill:var(--bs-btn-active-color);
}

.btn.btn-icon-solo {
  padding-left: var(--bs-btn-padding-y);
  padding-right: var(--bs-btn-padding-y);
}

/* Button - Primary */
.btn.btn-primary {
  --bs-btn-hover-bg:var(--bs-primary40);
  --bs-btn-hover-border-color:var(--bs-primary40);
  --bs-btn-active-bg:var(--bs-primary70);
  --bs-btn-hover-active-color:var(--bs-primary70);
}

/* Button - Outline Primary */
.btn.btn-outline-primary {
  --bs-btn-color:var(--bs-primary);
  --bs-btn-hover-color:var(--bs-primary40);
  --bs-btn-hover-bg:var(--bs-white);
  --bs-btn-hover-border-color:var(--bs-primary40);
  --bs-btn-active-color:var(--bs-primary70);
  --bs-btn-active-bg:var(--bs-white);
  --bs-btn-active-border-color:var(--bs-primary70);
}

/* Button - Danger */
.btn.btn-danger {
  --bs-btn-hover-bg:var(--bs-danger70);
  --bs-btn-hover-border-color:var(--bs-danger70);
  --bs-btn-active-bg:var(--bs-danger90);
  --bs-btn-active-border-color:var(--bs-danger90);
}

/* Button - Danger */
.btn.btn-success {
  --bs-btn-hover-bg:var(--bs-success70);
  --bs-btn-hover-border-color:var(--bs-success70);
  --bs-btn-active-bg:var(--bs-success90);
  --bs-btn-active-border-color:var(--bs-success90);
}

/* Button - Link */
.btn.btn-link {
  --bs-btn-font-weight:600;
  --bs-btn-color:var(--bs-primary);
  --bs-btn-bg:var(--bs-primary02);
  --bs-btn-border-color:var(--bs-primary02);
  --bs-btn-hover-color:var(--bs-primary40);
  --bs-btn-hover-bg:var(--bs-primary10);
  --bs-btn-hover-border-color:var(--bs-primary10);
  --bs-btn-active-color:var(--bs-primary70);
  --bs-btn-active-bg:var(--bs-primary20);
  --bs-btn-active-border-color:var(--bs-primary20);
}

/* Button - Bare */
.btn.btn-bare {
  --bs-btn-font-weight:600;
  --bs-btn-padding-x:0;
  text-decoration: underline;
  --bs-btn-color:var(--bs-primary);
  --bs-btn-bg:transparent;
  --bs-btn-border-color:transparent;
  --bs-btn-hover-color:var(--bs-primary40);
  --bs-btn-hover-bg:transparent;
  --bs-btn-hover-border-color:transparent;
  --bs-btn-active-color:var(--bs-primary70);
  --bs-btn-active-bg:transparent;
  --bs-btn-active-border-color:transparent;
}

/* Button - Disabled */
.btn.disabled,
.btn:disabled {
  cursor: not-allowed;
  --bs-btn-disabled-color:var(--bs-gray-700);
  --bs-btn-disabled-bg:var(--bs-gray-300);
  --bs-btn-disabled-border-color:var(--bs-gray-300);
}

.btn[class*=-outline-].disabled,
.btn[class*=-outline-]:disabled {
  --bs-btn-disabled-bg:var(--bs-white);
}

.btn.btn-bare.disabled,
.btn.btn-bare:disabled {
  --bs-btn-disabled-bg:transparent;
  --bs-btn-disabled-border-color:transparent;
}

.btn.disabled .icon,
.btn:disabled .icon {
  fill: var(--bs-btn-disabled-color);
}

/* Button - Close */
.btn-close {
  --bs-btn-box-shadow:none;
  background: none;
  width: auto;
  height: auto;
  margin: 0;
  padding: 0;
  opacity: 1;
}

/* Button - Toolbar */
.btn-toolbar {
  display: flex;
  align-items: center;
  padding-top: 32px;
}

.btn-toolbar .btn + .btn {
  margin-left: 16px;
}

.btn-toolbar .btn-group-left {
  flex: 1 0 0%;
  width: 100%;
  max-width: 100%;
  text-align: left;
}

.btn-toolbar .btn-group-right {
  flex: 1 0 0%;
  width: 100%;
  max-width: 100%;
  text-align: right;
}

/* Form Group */
.form-group {
  --bs-field-bg:var(--bs-white);
  --bs-field-color:var(--bs-dark);
  --bs-field-icon-fill:var(--bs-dark);
  --bs-field-border:var(--bs-gray-300);
  --bs-field-ps:12px;
  --bs-field-pe:12px;
  --bs-field-py:10px;
  --bs-field-bg-icon:none;
  --bs-border-radius:4px;
  --bs-focus-bs:0 0 0 .25rem rgba(33,86,171,.25);
}

.form-group > label {
  font-weight: 600;
  padding: 6px 8px;
}

.form-group .form-control,
.form-group .form-select {
  color: var(--bs-field-color);
  border-color: var(--bs-field-border);
  background-color: var(--bs-field-bg);
  background-repeat: no-repeat;
}

/* Form Control */
.form-control {
  font-size: 18px;
  padding: var(--bs-field-py) var(--bs-field-pe) var(--bs-field-py) var(--bs-field-ps);
  background-size: 36px 20px;
  background-position: right center;
  background-image: var(--bs-field-bg-icon);
}

/* Form Select */
.form-select {
  font-size: 18px;
  padding: var(--bs-field-py) calc(var(--bs-field-pe) + 30px) var(--bs-field-py) var(--bs-field-ps);
  background-size: 36px 20px, 24px 24px;
  background-position: right 32px center, right 12px center;
  background-image: var(--bs-field-bg-icon), var(--bs-form-select-bg-img);
  --bs-form-select-bg-img:url("../imgs/icon/form/select-arrow.svg");
  text-align: left;
}

/* Input Group */
.input-group {
  flex-wrap: nowrap;
}

.input-group .input-group-text {
  background-color: var(--bs-field-bg);
  border-color: var(--bs-field-border);
  padding: var(--bs-field-py) 8px;
  z-index: 1;
  transition: border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
}

.input-group > .icon,
.input-group > :not(.dropdown-menu) .icon {
  fill: var(--bs-field-icon-fill);
}

.input-group .input-group-text:first-child {
  border-right: none;
}

.input-group .input-group-text:first-child + .form-select,
.input-group .input-group-text:first-child + .form-control {
  border-left: none;
  --bs-field-ps:2px;
}

.input-group .form-control:not(:last-child) {
  border-right: none;
  --bs-field-pe:2px;
}

.input-group .form-select:not(:last-child) {
  border-right: none;
}

.input-group .form-control + .input-group-text,
.input-group .form-select + .input-group-text,
.input-group .input-group-text + .input-group-text {
  border-left: none;
}

/* Input Select - Dropdown */
.form-group.dropdown .input-group.show .form-select {
  --bs-form-select-bg-img:url("../imgs/icon/form/select-arrow-open.svg");
}

.form-group.dropdown .btn.dropdown-toggle {
  padding: 0;
  border: none;
  align-items: unset;
  height: auto;
}

.form-group .select-placeholder {
  color: var(--bs-gray-600);
}

.form-group .select-value {
  color: var(--bs-field-color);
  display: none;
  align-items: center;
  flex-wrap: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.form-group .form-select.select-filled .select-value {
  display: flex;
}

.form-group .form-select.select-filled .select-placeholder {
  display: none;
}

.form-group .select-value .multi-value {
  border-radius: 4px;
  padding: 2.5px 8px;
  font-size: 14px;
  font-weight: 600;
  background-color: var(--bs-primary05);
  color: var(--bs-primary);
}

.form-group .select-value .multi-value + .multi-value {
  margin-left: 8px;
}

/* Date picker */
.datepicker {
  --bs-date-select-bg: var(--bs-white);
  --bs-date-select-color: var(--bs-dark);
  --bs-date-day-color: var(--bs-dark);
  --bs-date-day-bg: var(--bs-white);
  --bs-date-icon-fill:var(--bs-gray-600);
}

.datepicker .input-group .dropdown-menu {
  top: 100%;
  border-radius: 4px;
  box-shadow: 0 0 15px rgba(0, 0, 0, 0.1);
}

.datepicker .input-group > .dropdown-menu.show {
  width: 290px;
}

.datepicker .input-group > .dropdown-menu .icon {
  fill: var(--bs-date-icon-fill);
}

.datepicker .date-header {
  display: flex;
  align-items: center;
  flex-wrap: nowrap;
  justify-content: space-between;
  padding: 8px 0;
  border-bottom: 1px solid var(--bs-gray-100);
}

.datepicker .selector-month {
  display: flex;
  align-items: center;
  flex-wrap: nowrap;
}

.datepicker .selector-year {
  border: none;
}

.datepicker .date-body {
  padding: 8px 0;
}

.datepicker .date-footer {
  text-align: right;
  padding-top: 8px;
}

/* */
.datepicker .dropdown > .dropdown-toggle {
  display: inline-flex;
  align-items: center;
  border: none;
  border-radius: 4px;
  background-color: var(--bs-date-select-bg);
  color: var(--bs-date-select-color);
  padding: 4px 12px;
  text-align: center;
  transition: all 0.3s;
}

.datepicker .dropdown > .dropdown-toggle:hover,
.datepicker .dropdown > .dropdown-toggle.show {
  --bs-date-select-bg:var(--bs-primary40);
  --bs-date-select-color:var(--bs-white);
  --bs-date-icon-fill:var(--bs-white);
}

.datepicker .dropdown > .dropdown-toggle > .dropdown-icon {
  margin-left: 8px;
}

.datepicker .dropdown > .dropdown-toggle.show > .dropdown-icon {
  transform: rotate(180deg);
}

.datepicker .dropdown .dropdown-menu {
  overflow: hidden;
  overflow-y: auto;
  max-height: 250px;
}

.datepicker .dropdown.year-select .dropdown-menu {
  right: 0;
}

/* */
.datepicker .month-group {
  display: flex;
  align-items: center;
  flex-wrap: nowrap;
}

.datepicker .month-head,
.datepicker .month-days {
  display: flex;
  align-items: start;
  flex-wrap: wrap;
}

.datepicker .day {
  flex: 0 1 100%;
  max-width: 14.28571%;
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 8px 0;
  border-radius: 4px;
  background-color: var(--bs-date-day-bg);
  color: var(--bs-date-day-color);
  transition: all 0.3s;
}

.datepicker .month-days .day:not(.empty):not(.active) {
  cursor: pointer;
}

.datepicker .month-days .day:not(.empty):not(.active):hover {
  --bs-date-day-color:var(--bs-white);
  --bs-date-day-bg:var(--bs-primary40);
}

.datepicker .month-days .day.active {
  --bs-date-day-color:var(--bs-white);
  --bs-date-day-bg:var(--bs-primary70);
}

.datepicker .month-head .day {
  font-size: 16px;
  font-weight: 600;
  color: var(--bs-gray-600);
}

.datepicker .month-days .day {
  font-size: 14px;
}

.datepicker .date-footer .btn + .btn {
  margin-left: 16px;
}

/* Form Field - Disabled  */
.form-group.disabled {
  --bs-field-bg:var(--bs-gray-300);
  --bs-field-border:var(--bs-gray-300);
  --bs-field-color:var(--bs-gray-700);
  --bs-field-icon-fill:var(--bs-gray-700);
}

.form-group.disabled > label {
  color: var(--bs-gray-500);
}

.form-group.disabled a,
.form-group.disabled button {
  pointer-events: none;
  cursor: default;
}

.form-group.dropdown.disabled .input-group {
  pointer-events: none;
  cursor: default;
}

/* Form Field - Readonly  */
.form-group.readonly {
  --bs-field-bg:var(--bs-gray-50);
  --bs-field-border:var(--bs-gray-200);
  --bs-field-color:var(--bs-gray-600);
  --bs-field-icon-fill:var(--bs-gray-600);
}

.form-group.readonly a,
.form-group.readonly button {
  pointer-events: none;
  cursor: default;
}

.form-group.dropdown.readonly .input-group {
  pointer-events: none;
  cursor: default;
}

/* Form field - Feedback */
.form-group .invalid-feedback,
.form-group .valid-feedback {
  display: none;
  color: var(--bs-dark);
}

/* Form field - Feedback is invalid */
.form-group.is-invalid {
  --bs-field-border:var(--bs-danger50);
  --bs-field-color:var(--bs-danger50);
  --bs-field-icon-fill:var(--bs-danger50);
  --bs-field-bg-icon:url("../imgs/icon/form/feedback-invalid.svg");
}

.form-group.is-invalid .form-select {
  padding-right: 64px;
  --bs-form-select-bg-img:url("../imgs/icon/form/select-arrow-danger.svg");
}

.form-group.is-invalid .form-control {
  padding-right: 38px;
}

.form-group.is-invalid .invalid-feedback {
  display: block;
}

.form-group.is-invalid .multi-value {
  background-color: var(--bs-field-color);
  color: var(--bs-white);
}

/* Form field - Feedback is valid */
.form-group.is-valid {
  --bs-field-border:var(--bs-success60);
  --bs-field-color:var(--bs-success60);
  --bs-field-icon-fill:var(--bs-success60);
  --bs-field-bg-icon:url("../imgs/icon/form/feedback-valid.svg");
}

.form-group.is-valid .form-select {
  padding-right: 64px;
  --bs-form-select-bg-img:url("../imgs/icon/form/select-arrow-success.svg");
}

.form-group.is-valid .form-control {
  padding-right: 38px;
}

.form-group.is-valid .valid-feedback {
  display: block;
}

.form-group.is-valid .multi-value {
  background-color: var(--bs-field-color);
  color: var(--bs-white);
}

/* Form field - Hover */
.form-group.hover {
  --bs-field-border:var(--bs-primary40);
  --bs-field-icon-fill:var(--bs-primary40);
}

.form-group.hover .form-select {
  --bs-form-select-bg-img:url("../imgs/icon/form/select-arrow-hover.svg");
}

/* Form field - Active */
.form-group.active {
  --bs-field-border:var(--bs-primary70);
  --bs-field-color:var(--bs-primary70);
  --bs-field-icon-fill:var(--bs-primary70);
}

/* Form field Helper */
.field-helper {
  padding: 0 4px;
  font-size: 0.8rem;
}

.form-group.disabled .field-helper {
  color: var(--bs-gray-500);
}

/* Form Field Mandatory */
.field-mandatory {
  display: inline-block;
  font-weight: 500;
}

.field-mandatory-nb {
  padding: 1rem 0;
  font-size: 0.8rem;
}

/* Group inline */
.group-inline {
  display: flex;
  flex-flow: row wrap;
  margin-right: -16px;
}

.group-inline .form-group {
  padding-right: 16px;
  margin-bottom: 24px;
}

.group-inline .form-group.group-btn-inline {
  display: flex;
  align-items: end;
  max-height: 84px;
}

/* Form - Checkbox+Radio */
.form-toggle,
.form-radio,
.form-checkbox {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  margin-left: -8px;
  margin-right: -8px;
}

.toggle,
.radio,
.checkbox {
  flex: 0 1 auto;
  margin: 0;
  padding: 8px 8px 4px 8px;
}

.toggle > input[type=checkbox],
.radio > input[type=radio],
.checkbox > input[type=checkbox] {
  position: absolute !important;
  opacity: 0;
  width: 1px !important;
  height: 1px !important;
  left: -1000px;
}

.toggle > label,
.radio > label,
.checkbox > label {
  cursor: pointer;
  display: flex;
  align-items: start;
  justify-content: flex-start;
  padding-right: 16px;
  color: var(--bs-field-color);
}

.toggle > label::after,
.toggle > label::before,
.radio > label::after,
.checkbox > label::after,
.radio > label::before,
.checkbox > label::before {
  flex: 0 0 24px;
  width: 24px;
  height: 24px;
  stroke: var(--bs-shade6);
  margin-top: 1px;
  background-size: 24px 24px;
  background-repeat: no-repeat;
  background-position: center;
}

.form-radio:not(.right) .radio label::before,
.form-checkbox:not(.right) .checkbox label::before {
  content: "";
  margin-right: 14px;
}

.form-radio.right .radio label::after,
.form-checkbox.right .checkbox label::after {
  content: "";
  margin-left: 14px;
}

.radio > label::after,
.radio > label::before {
  background-image: url("../imgs/icon/sprite.svg#radio-bg");
}

.radio > input:checked + label::after,
.radio > input:checked + label::before {
  background-image: url("../imgs/icon/sprite.svg#radio-check-bg");
}

.checkbox > label::after,
.checkbox > label::before {
  background-image: url("../imgs/icon/sprite.svg#checkbox-bg");
}

.checkbox > input:checked + label::after,
.checkbox > input:checked + label::before {
  background-image: url("../imgs/icon/sprite.svg#checkbox-check-bg");
}

.radio > input + label,
.checkbox > input + label {
  cursor: pointer;
}

/* Form - Checkbox+Radio Disable Readonly */
.form-group.readonly input + label,
.form-group.disabled input + label,
.toggle > input[disabled] + label,
.toggle > input[readonly] + label,
.radio > input[disabled] + label,
.radio > input[readonly] + label,
.checkbox > input[disabled] + label,
.checkbox > input[readonly] + label {
  color: #8f8f94;
  cursor: default;
}

.checkbox > input[disabled] + label::after,
.checkbox > input[disabled] + label::after,
.checkbox > input[readonly] + label::before,
.checkbox > input[readonly] + label::before {
  background-image: url("../imgs/icon/sprite.svg#checkbox-disabled-bg");
}

.checkbox > input[disabled]:checked + label::after,
.checkbox > input[disabled]:checked + label::after,
.checkbox > input[readonly]:checked + label::before,
.checkbox > input[readonly]:checked + label::before {
  background-image: url("../imgs/icon/sprite.svg#checkbox-check-disabled-bg");
}

.radio > input[disabled] + label::after,
.radio > input[disabled] + label::after,
.radio > input[readonly] + label::before,
.radio > input[readonly] + label::before {
  background-image: url("../imgs/icon/sprite.svg#radio-disabled-bg");
}

.radio > input[disabled]:checked + label::after,
.radio > input[disabled]:checked + label::after,
.radio > input[readonly]:checked + label::before,
.radio > input[readonly]:checked + label::before {
  background-image: url("../imgs/icon/sprite.svg#radio-check-disabled-bg");
}

/* */
.form-group.is-invalid .checkbox > label::after,
.form-group.is-invalid .checkbox > label::before {
  background-image: url("../imgs/icon/sprite.svg#checkbox-invalid-bg");
}

.form-group.is-invalid .checkbox > input:checked + label::after,
.form-group.is-invalid .checkbox > input:checked + label::before {
  background-image: url("../imgs/icon/sprite.svg#checkbox-check-invalid-bg");
}

.form-group.is-invalid .radio > label::after,
.form-group.is-invalid .radio > label::before {
  background-image: url("../imgs/icon/sprite.svg#radio-invalid-bg");
}

.form-group.is-invalid .radio > input:checked + label::after,
.form-group.is-invalid .radio > input:checked + label::before {
  background-image: url("../imgs/icon/sprite.svg#radio-check-invalid-bg");
}

/* Switcher !!! */
.form-switcher {
  display: inline-flex;
  flex-wrap: nowrap;
  flex-direction: row;
  border: 1px solid var(--bs-gray-300);
  border-radius: 8px;
  padding: 8px;
}

.form-switcher .btn.btn-bare {
  --bs-btn-color:var(--bs-primary90);
  --bs-btn-hover-color:var(--bs-primary40);
  --bs-btn-active-bg:var(--bs-primary70);
  --bs-btn-active-color:var(--bs-white);
  --bs-btn-disabled-color:var(--bs-gray-500);
  --bs-btn-padding-x:16px;
  --bs-btn-font-size:1.25rem;
  text-decoration: none;
}

.form-switcher .icon {
  --bs-icon-size:24px;
}

.form-switcher .btn-check + .btn.btn-bare:hover:not(.disabled):not(:disabled) {
  --bs-btn-color:var(--bs-primary40);
}

.form-switcher .btn-check:checked + .btn.btn-bare:not(.disabled):not(:disabled) {
  --bs-btn-color:var(--bs-white);
}

.form-switcher .btn-check:checked + .btn.btn-bare:hover:not(.disabled):not(:disabled) {
  --bs-btn-hover-color:var(--bs-white) !important;
}

.form-switcher .btn.btn-bare:disabled,
.form-switcher .btn.btn-bare.disabled {
  --bs-btn-active-color:var(--bs-white);
  --bs-btn-active-bg:var(--bs-gray-500);
}

.form-switcher .btn-check:checked + .btn.btn-bare.disabled {
  --bs-btn-disabled-color:var(--bs-white);
}

/* File - Drag and Drop */
.form-file {
  --bs-file-bg: var(--bs-primary05);
  --bs-file-color:var(--bs-primary);
  --bs-icon:60px;
  --bs-loader:40px;
}

.form-file input[type=file] {
  opacity: 0;
  position: absolute;
  width: 1px;
  height: 1px;
}

.form-file .file-item {
  position: relative;
  display: flex;
  flex-wrap: nowrap;
  border-radius: 4px;
  padding: 8px;
  border: 1px solid var(--bs-primary20);
  margin-top: 8px;
}

.form-file .file-icon {
  flex: 0 1 auto;
  display: flex;
  align-items: center;
  justify-content: center;
  width: var(--bs-icon);
  height: var(--bs-icon);
  background-color: var(--bs-file-bg);
  border-radius: 4px;
}

.form-file .file-desc {
  flex: 1 1 auto;
  padding-left: 8px;
}

.form-file .file-title {
  font-size: 1.125rem;
  font-weight: 600;
  padding-bottom: 6px;
  padding-right: 24px;
}

.form-file .file-text {
  font-size: 0.875rem;
  padding-top: 6px;
  color: var(--bs-gray-600);
}

.form-file .btn-close {
  --bs-btn-close-bg:none;
  width: auto;
  height: auto;
  line-height: 0;
  position: absolute;
  right: 8px;
  top: 8px;
}

.form-file .btn-refresh {
  display: none;
  right: 32px;
}

.form-file .file-icon .loader {
  width: var(--bs-loader);
  height: var(--bs-loader);
}

.form-file .file-icon .loader-bg {
  fill: none;
  stroke: var(--bs-white);
  stroke-width: 8;
}

.form-file .file-icon .loader-circle {
  fill: none;
  stroke: var(--bs-primary50);
  stroke-width: 8;
  stroke-linecap: round;
}

.form-file .file-icon .icon {
  --bs-icon-fill:var(--bs-file-color);
}

.file-item.complete .progress {
  display: none;
}

.file-item.success {
  --bs-file-color:var(--bs-success60);
  --bs-file-bg:var(--bs-success05);
}

.file-item.success .progress {
  display: none;
}

.file-item.error {
  --bs-file-color:var(--bs-danger50);
  --bs-file-bg:var(--bs-danger05);
}

.file-item.error .btn-close,
.file-item.error .progress {
  --bs-progress-bar-bg:var(--bs-file-color);
}

.file-item.error .file-text {
  font-weight: 600;
  color: var(--bs-file-color);
}

.file-item.error .btn-refresh {
  display: block;
}

.file-item.error .btn-refresh .icon {
  --bs-icon-fill:var(--bs-file-color);
}

/* File - Drag and Drop */
.form-dragdrop {
  --bs-dragdrop-border:2px sold transparent;
  --bs-dragdrop-bg: var(--bs-primary05);
  --bs-dragdrop-color:var(--bs-primary70);
  --bs-dragdrop-icon:102px;
  border-radius: 8px;
  text-align: center;
  padding: 3rem;
  border: var(--bs-dragdrop-border);
  background-color: var(--bs-dragdrop-bg);
}

.form-dragdrop .dragdrop-icon {
  padding-bottom: 32px;
}

.form-dragdrop .dragdrop-text {
  color: var(--bs-gray-600);
}

.form-dragdrop .dragdrop-title {
  font-size: 1.5rem;
  font-weight: 600;
  color: var(--bs-dragdrop-color);
}

.form-dragdrop .dragdrop-option {
  font-size: 1.125rem;
}

.form-dragdrop .dragdrop-option + .dragdrop-option {
  padding-top: 24px;
}

.form-dragdrop .dragdrop-btn {
  padding-top: 24px;
}

.form-dragdrop .file-desc {
  padding-bottom: 24px;
}

.form-dragdrop input[type=file] {
  opacity: 0;
  position: absolute;
  width: 1px;
  height: 1px;
}

.form-dragdrop :is(.over, .loading, .uploading, .success, .error) {
  display: none;
}

.form-dragdrop .dragdrop-icon .loading,
.form-dragdrop .dragdrop-icon img {
  width: var(--bs-dragdrop-icon);
  height: var(--bs-dragdrop-icon);
}

.form-dragdrop .dragdrop-icon .disabled {
  display: none;
}

.form-dragdrop.over {
  --bs-dragdrop-border:2px dashed var(--bs-primary40);
  --bs-dragdrop-color:var(--bs-primary40);
}

.form-dragdrop.over .dragdrop-icon .default {
  display: none;
}

.form-dragdrop.over .dragdrop-icon .over {
  display: block;
}

.form-dragdrop.loading .default {
  display: none;
}

.form-dragdrop.loading .loading {
  display: block;
}

.form-dragdrop.success {
  --bs-dragdrop-color:var(--bs-success60);
  --bs-dragdrop-bg:var(--bs-success05);
}

.form-dragdrop.success .default {
  display: none;
}

.form-dragdrop.success .success {
  display: block;
}

.form-dragdrop.error {
  --bs-dragdrop-color:var(--bs-danger50);
  --bs-dragdrop-bg:var(--bs-danger05);
}

.form-dragdrop.error .default {
  display: none;
}

.form-dragdrop.error .error {
  display: block;
}

.form-dragdrop.loading .uploading,
.form-dragdrop.error .uploading,
.form-dragdrop.success .uploading {
  display: block;
}

.form-dragdrop .dragdrop-icon .loading {
  position: relative;
  margin: 0 auto;
}

.form-dragdrop .loader-bg {
  fill: none;
  stroke: var(--bs-white);
  stroke-width: 8;
}

.form-dragdrop .loader-circle {
  fill: none;
  stroke: var(--bs-primary50);
  stroke-width: 8;
  stroke-linecap: round;
}

.form-dragdrop .loader-pecent {
  position: absolute;
  right: 0;
  bottom: 40px;
  left: 0;
  z-index: 1;
  font-size: 1.125rem;
  font-weight: 600;
  color: var(--bs-primary50);
}

.form-dragdrop.disabled {
  --bs-dragdrop-color:var(--bs-gray-500);
  --bs-dragdrop-bg:var(--bs-gray-50);
}

.form-dragdrop.disabled .dragdrop-icon .default {
  display: none;
}

.form-dragdrop.disabled .dragdrop-icon .disabled {
  display: block;
}

/* Toggle */
.form-toggle {
  --bs-toggle-w:56px;
  --bs-toggle-p:16px;
  --bs-toggle-s:0px;
  --bs-toggle-h:28px;
  --bs-toggle-ps:3px;
  --bs-toggle-pe:31px;
  --bs-toggle-ph:22px;
  padding-left: 0;
}

.form-toggle .toggle label::before,
.form-toggle .toggle label::after {
  content: "";
}

.toggle {
  padding-top: 8px;
}

.toggle > label {
  --bs-toggle-bg:var(--bs-primary05);
  position: relative;
  padding-left: calc(var(--bs-toggle-w) + var(--bs-toggle-p));
  min-height: var(--bs-toggle-h);
}

.toggle > label::after {
  position: absolute;
  width: var(--bs-toggle-ph);
  height: var(--bs-toggle-ph);
  border-radius: 50%;
  top: 3px;
  left: var(--bs-toggle-ps);
  background-color: var(--bs-white);
}

.toggle > label::before {
  position: absolute;
  width: var(--bs-toggle-w);
  height: var(--bs-toggle-h);
  border-radius: calc(var(--bs-toggle-h) / 2);
  top: 0px;
  left: var(--bs-toggle-s);
  background-color: var(--bs-toggle-bg);
}

.toggle > label::after,
.toggle > label::before {
  transition: all 0.3s;
}

.toggle > input:checked + label::after {
  left: var(--bs-toggle-pe);
}

.toggle > input:checked + label {
  --bs-toggle-bg:var(--bs-primary70);
}

.toggle:hover > input:not([disabled]):checked + label {
  --bs-toggle-bg:var(--bs-primary80);
}

.toggle:hover > input:not([disabled]):not(:checked) + label {
  --bs-toggle-bg:var(--bs-gray-600);
}

.toggle > input[disabled] + label::before {
  --bs-toggle-bg:var(--bs-gray-300);
}

/* Toggle - Labelled */
.form-toggle.labelled {
  --bs-toggle-p:68px;
  --bs-toggle-s:30px;
  --bs-toggle-ps:calc( 3px + var(--bs-toggle-s) );
  --bs-toggle-pe:calc( 31px + var(--bs-toggle-s) );
}

.form-toggle.labelled .label-off,
.form-toggle.labelled .label-on {
  position: absolute;
  top: 2px;
  width: 30px;
  font-size: 16px;
  font-weight: 600;
  color: var(--bs-gray-600);
  transition: opacity 0.3s;
}

.form-toggle.labelled .label-off {
  left: 0;
  opacity: 1;
}

.form-toggle.labelled .label-on {
  left: 90px;
  opacity: 0;
}

.form-toggle.labelled .toggle > input:checked + label .label-off {
  opacity: 0;
}

.form-toggle.labelled .toggle > input:checked + label .label-on {
  opacity: 1;
}

/* Toggle - Right */
.form-toggle.right .toggle > label {
  padding-right: calc(var(--bs-toggle-w) + var(--bs-toggle-p));
  padding-left: 0;
}

.form-toggle.right .toggle > label::after {
  left: auto;
  right: var(--bs-toggle-pe);
}

.form-toggle.right .toggle > label::before {
  left: auto;
  right: var(--bs-toggle-s);
}

.form-toggle.right .toggle > input:checked + label::after {
  right: var(--bs-toggle-ps);
}

.form-toggle.labelled.right .label-off {
  left: auto;
  right: 90px;
  text-align: right;
}

.form-toggle.labelled.right .label-on {
  left: auto;
  right: 0px;
  text-align: right;
}

/* Focus */
.form-select:focus,
.form-control:focus {
  box-shadow: var(--bs-focus-bs);
}

.form-radio:not(.right) .radio input:focus + label::before,
.form-checkbox:not(.right) .checkbox input:focus + label::before {
  box-shadow: var(--bs-focus-bs);
}

.form-radio .radio input:focus + label::after,
.form-checkbox .checkbox input:focus + label::after {
  box-shadow: var(--bs-focus-bs);
}

.form-switcher input:focus + .btn.btn-bare {
  box-shadow: var(--bs-focus-bs);
}

.toggle > input:focus + label::before {
  box-shadow: var(--bs-focus-bs);
}

/* Form Field - Padding 24, size 9 */
.form-group {
  --bs-form-width:100%;
  flex: 0 0 auto;
  max-width: 100%;
}

.form-control {
  max-width: 100%;
  width: var(--bs-form-width) !important;
}

.form-select {
  max-width: 100%;
  width: var(--bs-form-width) !important;
}

/* Form Field - Padding 24, step di 2 */
.field-2 {
  --bs-form-width:42px;
}

.field-4 {
  --bs-form-width:60px;
}

.field-6 {
  --bs-form-width:78px;
}

.field-8 {
  --bs-form-width:95px;
}

.field-10 {
  --bs-form-width:113px;
}

.field-12 {
  --bs-form-width:131px;
}

.field-14 {
  --bs-form-width:148px;
}

.field-16 {
  --bs-form-width:165px;
}

.field-18 {
  --bs-form-width:183px;
}

.field-20 {
  --bs-form-width:200px;
}

.field-22 {
  --bs-form-width:217px;
}

.field-24 {
  --bs-form-width:234px;
}

.field-26 {
  --bs-form-width:251px;
}

.field-28 {
  --bs-form-width:268px;
}

.field-30 {
  --bs-form-width:285px;
}

.field-32 {
  --bs-form-width:302px;
}

.field-34 {
  --bs-form-width:318px;
}

.field-36 {
  --bs-form-width:335px;
}

.field-38 {
  --bs-form-width:352px;
}

.field-40 {
  --bs-form-width:368px;
}

/* Form Field - Padding 24, step di 10 */
.field-50 {
  --bs-form-width:449px;
}

.field-60 {
  --bs-form-width:528px;
}

.field-70 {
  --bs-form-width:605px;
}

.field-80 {
  --bs-form-width:680px;
}

/* Form Field - Special */
.form-group.field-wide {
  flex: 0 0 100%;
}

.form-group.field-grow {
  flex: 1 1 auto;
}

/* Form Field - Small */
.form-group.field-sm {
  --bs-field-py:7px;
}

.form-group.field-sm .form-control,
.form-group.field-sm .form-select {
  font-size: 16px;
  font-weight: 600;
}

.form-group.field-sm .form-control::placeholder,
.form-group.field-sm .form-select::placeholder {
  font-size: 16px;
  font-weight: 400;
}

/* Z-Index */
.datepicker .dropdown-menu {
  z-index: 1035;
}

/* LG */
@media (max-width: 991.9px) {
  /* Form Group */
  .form-group {
    --bs-field-ps:8px;
    --bs-field-pe:8px;
    --bs-field-py:8.5px;
  }
  /* */
  .form-control,
  .form-select {
    font-size: 16px;
  }
  /* Button - Toolbar (con queste impostazioni funziona anche con il flex column-reverse) */
  .btn-toolbar {
    padding-top: 24px;
    flex-direction: column;
  }
  .btn-toolbar > * {
    margin-top: 16px;
  }
  .btn-toolbar .btn-group-left,
  .btn-toolbar .btn-group-right {
    max-width: none;
    text-align: center;
  }
  /* Toggle */
  .form-toggle {
    --bs-toggle-h:24px;
    --bs-toggle-pe:34px;
    --bs-toggle-ph:18px;
  }
  /* File - Drag and Drop */
  .form-file {
    --bs-icon:48px;
    --bs-loader:32px;
  }
  .form-file .file-title {
    font-size: 0.875rem;
    padding-bottom: 2px;
  }
  .form-file .file-text {
    font-size: 0.875rem;
    padding-top: 2px;
  }
  .form-file .btn-close {
    top: 4px;
  }
  /* File - Drag and Drop */
  .form-dragdrop {
    --bs-dragdrop-icon:48px;
    padding: 1.5rem;
  }
  .form-dragdrop .dragdrop-icon {
    padding-bottom: 16px;
  }
  .form-dragdrop .dragdrop-option + .dragdrop-option {
    display: none;
  }
  .form-dragdrop .loader-pecent {
    font-size: 0.875rem;
    bottom: 10px;
  }
  .form-dragdrop .dragdrop-btn {
    padding-top: 8px;
  }
}
/* MD */
/* */
@media (max-width: 767.9px) {
  /* Button - Toolbar (con queste impostazioni funziona anche con il flex column-reverse) */
  .btn-toolbar > * {
    margin-top: 0;
  }
  .btn-toolbar .btn {
    width: 100%;
    margin-top: 16px;
  }
  .btn-toolbar .btn + .btn {
    margin-left: 0px;
  }
  /* */
  .form-group.group-btn-inline {
    flex: 1 0 100%;
    --bs-form-width:100%;
    margin-bottom: 0;
  }
  .form-group.group-btn-inline .btn {
    width: 100%;
  }
  /* Switcher */
  .form-switcher .btn.btn-bare {
    --bs-btn-padding-x:10px;
    --bs-btn-font-size:1rem;
  }
  .form-switcher .icon {
    --bs-icon-size:20px;
  }
}
/* SM */
@media (max-width: 575.9px) {
  /* */
  .form-group { /*flex:1 0 100%;*/
    --bs-form-width:100%;
  }
}
/**
 * Loading - Spinner 
*/
.loading-spinner {
  --bs-gray-100: #E6E6E7;
  --bs-gray-300: #C0C2C4;
  --bs-success: #1D7748;
  --bs-danger: #E32941;
  --bs-primary05: #E5EDFA;
  --bs-primary: #2156AB;
  --bs-spinner-size:32px;
  --bs-spinner-sw:6;
  margin: auto;
  padding: 8px;
  position: relative;
  text-align: center;
}

.loading-spinner svg {
  width: var(--bs-spinner-size);
  height: var(--bs-spinner-size);
}

.loading-spinner.spinner-lg {
  --bs-spinner-size:48px;
  --bs-spinner-sw:4;
}

.loading-spinner.spinner-sm {
  --bs-spinner-size:24px;
  --bs-spinner-sw:8;
}

.loading-spinner .spinner-bg {
  fill: none;
  stroke: var(--bs-primary05);
  stroke-width: var(--bs-spinner-sw);
}

.loading-spinner .spinner {
  fill: none;
  stroke: var(--bs-primary);
  stroke-width: var(--bs-spinner-sw);
  stroke-linecap: round;
  animation: circle-spinner 1s linear infinite;
  transform-origin: 45px 45px;
}

.loading-spinner .spinner-title {
  padding-top: 24px;
  color: #071122;
  font-size: 18px;
  font-weight: 700;
}

/* */
.loading-spinner.disabled .spinner-bg {
  stroke: var(--bs-gray-100);
}

.loading-spinner.disabled .spinner {
  stroke: var(--bs-gray-300);
}

/* */
.loading-spinner.success .spinner {
  stroke: var(--bs-success);
}

/* */
.loading-spinner.danger .spinner {
  stroke: var(--bs-danger);
}

/* Modal*/
.modal > .loading-spinner {
  height: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}

/* Animation */
@keyframes circle-spinner {
  0% {
    stroke-dasharray: 50 220;
    transform: rotate(-30deg);
  }
  60% {
    stroke-dasharray: 180 220;
    transform: rotate(10deg);
  }
  100% {
    stroke-dasharray: 50 220;
    transform: rotate(330deg);
  }
}
/**
 * Table. 
*/
.list-table {
  --bs-table-width:auto;
  background-color: var(--bs-white);
}

.list-table table {
  width: 100%;
  border-spacing: 0 1rem;
  border-collapse: collapse;
}

.list-table thead th {
  background-color: var(--bs-primary05);
  font-size: 1.125rem;
}

.list-table thead th {
  border-right-width: 1px;
  font-weight: 600;
}

.list-table thead tr > th:not(.not-last):last-child {
  border-right: none;
}

.list-table thead tr + tr th {
  border-top-width: 1px;
}

.list-table td,
.list-table th {
  width: var(--bs-table-width);
  max-width: var(--bs-table-width);
  border: none;
  padding: 16px 12px;
  vertical-align: middle;
}

.list-table tbody tr {
  border-bottom: 1px solid var(--bs-gray-100);
}

/* Table - Responsive */
.list-table.table-responsive {
  overflow: hidden;
  overflow-x: auto;
}

/* Table - Even High Light */
.list-table.table-even tbody tr:nth-child(even) > td {
  background-color: var(--bs-gray-50);
}

/* Table - Head */
.list-table thead.bg-white th {
  background-color: var(--bs-white);
  border-bottom: 1px solid var(--bs-gray-100);
}

.list-table thead.bg-gray th {
  background-color: var(--bs-gray-50);
}

.list-table thead.bg-blue th {
  background-color: var(--bs-primary50);
  color: var(--bs-white);
}

.list-table thead.bg-blue th .icon {
  --bs-icon-fill:var(--bs-white);
}

/* Table - Sortable */
.list-table thead .sortable {
  display: inline-flex;
  align-items: center;
  color: inherit;
}

.list-table thead .sortable span + .icon,
.list-table thead .sortable .icon + span {
  margin-left: 8px;
}

/* Table - Column Fixed */
.list-table .colf-form .form-group {
  width: 100%;
  padding-top: 0;
}

.list-table .colf-form .form-group,
.list-table .colf-form .form-checkbox,
.list-table .colf-form .radio,
.list-table .colf-form .checkbox {
  margin: 0;
  padding: 0;
}

.list-table .colf-form .radio > label,
.list-table .colf-form .checkbox > label {
  margin: 0;
  padding: 0;
  justify-content: center;
}

.list-table .colf-form .radio > label::before,
.list-table .colf-form .checkbox > label::before {
  background-position: center;
}

/* Table - Bar */
.list-table .bar-group {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

/* Table - Column Data  */
.list-table .cold-number {
  text-align: right;
  font-family: "Roboto Mono";
}

/* Table - Responsive */
.list-table tbody > tr > td[data-label] {
  grid-template-columns: 40% auto;
  grid-gap: 0.25rem 1rem;
}

.list-table tbody > tr > td[data-label]::before {
  text-align: right;
  overflow-wrap: break-word;
  font-weight: bold;
  font-style: normal;
  line-height: var(--bs-body-line-height);
  background-color: var(--bs-primary02);
}

/* */
.list-table tbody > tr.active > td {
  background-color: var(--bs-primary05) !important;
}

/* Pagination */
.pagination-wrapper {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-top: 12px;
}

/* Pagination - Numbers */
.pagination {
  margin: 0;
}

.pagination .page-item + .page-item {
  margin-left: 8px;
}

.pagination .page-link {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 40px;
  min-width: 40px;
  border-radius: 4px;
  padding: 0 8px;
  font-family: "Roboto Mono", monospace;
  font-weight: 600;
}

.pagination .page-item .icon {
  --bs-icon-fill:var(--bs-pagination-color);
}

.pagination .page-item.disabled .icon {
  --bs-icon-fill:var(--bs-pagination-disabled-color);
}

.pagination .page-item:hover:not(.disabled):not(.active) .icon {
  --bs-icon-fill:var(--bs-pagination-hover-color);
}

.pagination .page-item.active .icon {
  --bs-icon-fill:var(--bs-pagination-active-color);
}

/* Pagination - Skip */
.pagination-wrapper .skip-value {
  padding: 8px;
  margin-left: 8px;
  border-radius: 4px;
  background-color: var(--bs-primary70);
  color: var(--bs-white);
  font-weight: 600;
}

.pagination-wrapper .skip-value:empty {
  display: none;
}

.pagination-wrapper .pagination + .pagination-skip {
  margin-left: 40px;
}

.pagination-wrapper .pagination-skip .form-group {
  --bs-field-border:var(--bs-primary10);
  --bs-form-width:54px;
  display: flex;
  align-items: center;
}

.pagination-wrapper .pagination-skip .form-group:hover {
  --bs-field-border:var(--bs-primary20);
}

.pagination-wrapper .pagination-skip .form-group.filled {
  --bs-field-border:var(--bs-primary70);
}

.pagination-wrapper .pagination-skip .form-control {
  text-align: center;
  margin-left: 8px;
}

/* Pagination - info */
.pagination-info {
  font-family: "Roboto Mono", monospace;
  font-size: 0.875rem;
  color: var(--bs-gray-600);
}

/* LG */
@media (min-width: 992px) {
  /*      step 28 + 8 * n */
  .table-lg .colf-2 {
    --bs-table-width:44px;
  }
  .table-lg .colf-4 {
    --bs-table-width:60px;
  }
  .table-lg .colf-6 {
    --bs-table-width:76px;
  }
  .table-lg .colf-8 {
    --bs-table-width:92px;
  }
  .table-lg .colf-10 {
    --bs-table-width:108px;
  }
  .table-lg .colf-12 {
    --bs-table-width:124px;
  }
  .table-lg .colf-14 {
    --bs-table-width:140px;
  }
  .table-lg .colf-16 {
    --bs-table-width:156px;
  }
  .table-lg .colf-18 {
    --bs-table-width:172px;
  }
  .table-lg .colf-20 {
    --bs-table-width:188px;
  }
  .table-lg .colf-22 {
    --bs-table-width:204px;
  }
  .table-lg .colf-24 {
    --bs-table-width:220px;
  }
  .table-lg .colf-26 {
    --bs-table-width:236px;
  }
  .table-lg .colf-28 {
    --bs-table-width:252px;
  }
  .table-lg .colf-30 {
    --bs-table-width:270px;
  }
  .table-lg .colf-40 {
    --bs-table-width:348px;
  }
  .table-lg .colf-50 {
    --bs-table-width:428px;
  }
  .table-lg .colf-60 {
    --bs-table-width:508px;
  }
}
@media (max-width: 991.9px) {
  /* Table LG */
  .table-lg,
  .table-lg tbody,
  .table-lg tbody > tr,
  .table-lg tbody > tr > td,
  .table-lg tbody > tr > th,
  .table-lg caption {
    display: block;
  }
  .table-lg thead,
  .table-lg tfoot {
    display: none;
  }
  .table-lg tbody > tr {
    margin-top: 16px;
    border: 1px solid var(--bs-gray-100);
    border-radius: 4px;
  }
  .table-lg tbody tr > td {
    padding: 0;
    border: none;
  }
  .table-lg tbody tr > td:first-child {
    border-radius: 4px 4px 0 0;
  }
  .table-lg tbody tr > td:last-child {
    border-radius: 0 0 4px 4px;
  }
  .table-lg tbody tr > td > div,
  .table-lg tbody tr > td::before {
    padding: 12px;
  }
  .table-lg tbody > tr > td[data-label] {
    display: grid;
    grid-template-columns: 40% auto;
  }
  .table-lg tbody > tr > td[data-label]::before {
    content: attr(data-label);
    display: inline-block;
  }
  /* */
  .table-lg .colf-form .form-group {
    padding: 12px;
  }
  .table-lg .colf-cmd {
    text-align: right !important;
  }
  .table-lg .colf-cmd > div {
    justify-content: end;
  }
  .table-lg .colf-cmd .btn {
    width: 100%;
  }
}
@media (min-width: 768px) {
  /* step 28 + 8 * n */
  .table-md .colf-2 {
    --bs-table-width:44px;
  }
  .table-md .colf-4 {
    --bs-table-width:60px;
  }
  .table-md .colf-6 {
    --bs-table-width:76px;
  }
  .table-md .colf-8 {
    --bs-table-width:92px;
  }
  .table-md .colf-10 {
    --bs-table-width:108px;
  }
  .table-md .colf-12 {
    --bs-table-width:124px;
  }
  .table-md .colf-14 {
    --bs-table-width:140px;
  }
  .table-md .colf-16 {
    --bs-table-width:156px;
  }
  .table-md .colf-18 {
    --bs-table-width:172px;
  }
  .table-md .colf-20 {
    --bs-table-width:188px;
  }
  .table-md .colf-22 {
    --bs-table-width:204px;
  }
  .table-md .colf-24 {
    --bs-table-width:220px;
  }
  .table-md .colf-26 {
    --bs-table-width:236px;
  }
  .table-md .colf-28 {
    --bs-table-width:252px;
  }
  .table-md .colf-30 {
    --bs-table-width:270px;
  }
  .table-md .colf-40 {
    --bs-table-width:348px;
  }
  .table-md .colf-50 {
    --bs-table-width:428px;
  }
  .table-md .colf-60 {
    --bs-table-width:508px;
  }
}
@media (max-width: 767.9px) {
  /* Table MD */
  .table-md,
  .table-md tbody,
  .table-md tbody > tr,
  .table-md tbody > tr > td,
  .table-md tbody > tr > th,
  .table-md caption {
    display: block;
  }
  .table-md thead,
  .table-md tfoot {
    display: none;
  }
  .table-md tbody > tr {
    margin-top: 16px;
    border: 1px solid var(--bs-gray-100);
    border-radius: 4px;
  }
  .table-md tbody tr > td {
    padding: 0;
    border: none;
  }
  .table-md tbody tr > td:first-child {
    border-radius: 4px 4px 0 0;
  }
  .table-md tbody tr > td:last-child {
    border-radius: 0 0 4px 4px;
  }
  .table-md tbody > tr > td[data-label] {
    display: grid;
    grid-template-columns: 40% auto;
    grid-gap: 0.25rem 1rem;
  }
  .table-md tbody > tr > td[data-label]::before {
    content: attr(data-label);
    display: inline-block;
  }
  /* */
  .table-md .colf-form .form-group {
    padding: 12px;
  }
  .table-md .colf-cmd {
    text-align: right !important;
  }
  .table-md .colf-cmd > div {
    justify-content: end;
  }
  .table-md .colf-cmd .btn {
    width: 100%;
  }
  /* Pagination */
  .pagination-wrapper {
    flex-direction: column;
  }
  .pagination-wrapper .pagination-info + .pagination {
    padding-top: 12px;
  }
}
@media (min-width: 576px) {
  /* step 28 + 8 * n */
  .table-sm .colf-2 {
    --bs-table-width:44px;
  }
  .table-sm .colf-4 {
    --bs-table-width:60px;
  }
  .table-sm .colf-6 {
    --bs-table-width:76px;
  }
  .table-sm .colf-8 {
    --bs-table-width:92px;
  }
  .table-sm .colf-10 {
    --bs-table-width:108px;
  }
  .table-sm .colf-12 {
    --bs-table-width:124px;
  }
  .table-sm .colf-14 {
    --bs-table-width:140px;
  }
  .table-sm .colf-16 {
    --bs-table-width:156px;
  }
  .table-sm .colf-18 {
    --bs-table-width:172px;
  }
  .table-sm .colf-20 {
    --bs-table-width:188px;
  }
  .table-sm .colf-22 {
    --bs-table-width:204px;
  }
  .table-sm .colf-24 {
    --bs-table-width:220px;
  }
  .table-sm .colf-26 {
    --bs-table-width:236px;
  }
  .table-sm .colf-28 {
    --bs-table-width:252px;
  }
  .table-sm .colf-30 {
    --bs-table-width:270px;
  }
  .table-sm .colf-40 {
    --bs-table-width:348px;
  }
  .table-sm .colf-50 {
    --bs-table-width:428px;
  }
  .table-sm .colf-60 {
    --bs-table-width:508px;
  }
}
@media (max-width: 575.9px) {
  /* Table SM */
  .table-sm,
  .table-sm tbody,
  .table-sm tbody > tr,
  .table-sm tbody > tr > td,
  .table-sm tbody > tr > th,
  .table-sm caption {
    display: block;
  }
  .table-sm thead,
  .table-sm tfoot {
    display: none;
  }
  .table-sm tbody > tr {
    margin-top: 16px;
    border: 1px solid var(--bs-gray-100);
    border-radius: 4px;
  }
  .table-sm tbody tr > td {
    padding: 0;
    border: none;
  }
  .table-sm tbody tr > td:first-child {
    border-radius: 4px 4px 0 0;
  }
  .table-sm tbody tr > td:last-child {
    border-radius: 0 0 4px 4px;
  }
  .table-sm tbody > tr > td[data-label] {
    display: grid;
    grid-template-columns: 40% auto;
  }
  .table-sm tbody > tr > td[data-label]::before {
    content: attr(data-label);
    display: inline-block;
  }
  /* */
  .table-sm .colf-form .form-group {
    padding: 12px;
  }
  .table-sm .colf-cmd {
    text-align: right !important;
  }
  .table-sm .colf-cmd > div {
    justify-content: end;
  }
  .table-sm .colf-cmd .btn {
    width: 100%;
  }
}
/**
 * Theme.
*/
:root {
  --bs-shadow-s: 0 0 15px 0 rgba(0, 0, 0, .10);
  --bs-shadow-sb: 0 10px 15px 0 rgba(0, 0, 0, .10);
  --bs-shadow-m: 0 0 20px 0 rgba(0, 0, 0, .15);
  --bs-shadow-l: 0 0 30px 0 rgba(0, 0, 0, .20);
  --bs-primary70: #143467;
  --bs-primary95: #030911;
  --bs-primary90: #071122;
  --bs-primary80: #0D2244;
  --bs-primary60: #1A4589;
  --bs-primary50: #2156AB;
  --bs-primary40: #3271D7;
  --bs-primary30: #6595E1;
  --bs-primary20: #9AB8EB;
  --bs-primary10: #CCDCF5;
  --bs-primary05: #E5EDFA;
  --bs-primary02: #F6F9FD;
}

/* CSS - Accessibility */
button:focus,
a:not(:active):focus {
  box-shadow: inset 0 0 0 2px var(--bs-warning50) !important;
  outline: 1px solid var(--bs-secondary) !important;
}

.bg-gradient .nav-tabs .nav-link:not(:active):focus {
  box-shadow: inset 0 0 0 2px var(--bs-warning50) !important;
}

a.skip-to-content:focus-visible,
a.skip-to-content:focus {
  display: block;
  position: absolute;
  left: 16px;
  top: 16px;
  width: auto;
  height: auto;
  padding: 8px 16px;
  font-size: 16px;
  font-weight: 700;
  box-shadow: 0 0 0 3px var(--bs-secondary);
  background-color: var(--bs-white);
  border-radius: 8px;
  color: var(--bs-dark);
  clip: auto !important;
  -webkit-clip-path: none;
  clip-path: none;
}

/* */
.roboto {
  font-family: "Roboto Mono", monospace;
}

/* Text */
.body-sm {
  font-size: 14px;
}

.body-lg {
  font-size: 18px;
}

.caption {
  font-size: 12px;
}

.text-u {
  text-decoration: underline;
}

.text-w6 {
  font-weight: 600;
}

.text-w7 {
  font-weight: 600;
}

.date {
  font-size: 14px;
  font-family: "Roboto Mono", monospace;
}

/* Icon */
.icon {
  --bs-icon-fill: var(--bs-dark);
  width: var(--bs-icon-size);
  min-width: var(--bs-icon-size);
  height: var(--bs-icon-size);
  fill: var(--bs-icon-fill);
  transition: fill 0.3s, transform 0.3s;
}

.icon.icon-xxl {
  --bs-icon-size: 64px;
}

.icon.icon-xl {
  --bs-icon-size: 48px;
}

.icon.icon-lg {
  --bs-icon-size: 40px;
}

.icon {
  --bs-icon-size: 32px;
}

.icon.icon-sm {
  --bs-icon-size: 24px;
}

.icon.icon-xs {
  --bs-icon-size: 20px;
}

.icon.icon-xxs {
  --bs-icon-size: 16px;
}

.icon.icon-primary {
  --bs-icon-fill: var(--bs-primary);
}

.icon.icon-white {
  --bs-icon-fill: var(--bs-white);
}

.icon.icon-success {
  --bs-icon-fill: var(--bs-success);
}

.icon.icon-warning {
  --bs-icon-fill: var(--bs-warning);
}

.icon.icon-danger {
  --bs-icon-fill: var(--bs-danger);
}

.icon.icon-gray-400 {
  --bs-icon-fill: var(--bs-gray-400);
}

.icon.icon-gray-600 {
  --bs-icon-fill: var(--bs-gray-600);
}

/* */
.icon.icon-square {
  border-radius: 4px;
  background-color: var(--bs-primary05);
  padding: 8px;
  width: auto;
  min-width: auto;
  height: auto;
  line-height: 0;
}

/* Avatar */
.avatar {
  --bs-avatar-color: var(--bs-primary);
  --bs-avatar-bg: transparent;
  --bs-avatar-border: none;
  width: var(--bs-avatar-size);
  min-width: var(--bs-avatar-size);
  height: var(--bs-avatar-size);
  color: var(--bs-avatar-color);
  background-color: var(--bs-avatar-bg);
  border: var(--bs-avatar-border);
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  border-radius: 50%;
  line-height: 0;
  transition: fill 0.3s;
}

.avatar.avatar-xxl {
  --bs-avatar-size: 128px;
}

.avatar.avatar-xl {
  --bs-avatar-size: 80px;
}

.avatar.avatar-lg {
  --bs-avatar-size: 40px;
}

.avatar {
  --bs-avatar-size: 32px;
}

.avatar.avatar-sm {
  --bs-avatar-size: 24px;
}

/* Avatar - Disabled */
.avatar.disabled {
  --bs-avatar-color: var(--bs-gray-500);
}

/* Avatar - Image */
.avatar > img {
  width: var(--bs-avatar-size);
  height: var(--bs-avatar-size);
}

.avatar.disabled img,
.btn:disabled .avatar img {
  filter: none;
  -webkit-filter: grayscale(100%);
  -moz-filter: grayscale(100%);
  -ms-filter: grayscale(100%);
  -o-filter: grayscale(100%);
}

/* Avatar - Letters */
.avatar div {
  font-size: calc(var(--bs-avatar-size) * 0.5);
  margin-top: calc(var(--bs-avatar-size) * -0.1);
  color: var(--bs-avatar-color);
  font-weight: 700;
}

/* Avatar - Icon */
.avatar .icon {
  width: calc(var(--bs-avatar-size) * 0.5);
  min-width: calc(var(--bs-avatar-size) * 0.5);
  height: calc(var(--bs-avatar-size) * 0.5);
  fill: var(--bs-avatar-color) !important;
}

/* Avatar - Primary */
.avatar.primary {
  --bs-avatar-bg: var(--bs-primary);
  --bs-avatar-color: var(--bs-white);
}

.avatar.primary.disabled {
  --bs-avatar-bg: var(--bs-gray-300);
  --bs-avatar-color: var(--bs-gray-700);
}

/* Avatar - Outline */
.avatar.outline {
  --bs-avatar-bg: var(--bs-white);
  --bs-avatar-border: 2px solid var(--bs-primary);
}

.avatar.outline.disabled {
  --bs-avatar-border: 2px solid var(--bs-gray-300);
}

/* Avatar - Square */
.avatar.avatar-square {
  border-radius: 16px;
}

/* Avatar - Group*/
.avatar-group {
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
}

.avatar-group .avatar {
  margin-left: calc(var(--bs-avatar-size) * -0.3);
}

/* Link */
.link {
  --bs-link-color: var(--bs-primary90);
  color: var(--bs-link-color);
  display: inline-flex;
  align-items: center;
  text-decoration: underline;
  font-weight: 700;
  transition: color 0.3s;
}

.link span + .icon,
.link .icon + span {
  margin-left: 8px;
}

.link .icon {
  --bs-icon-fill: var(--bs-link-color);
}

.link:hover {
  --bs-link-color: var(--bs-primary40);
  --bs-link-color-rgb: var(--bs-primary40-rgb);
  text-decoration: underline;
}

.link.disabled {
  --bs-link-color: var(--bs-gray-500);
  cursor: default;
}

.link:active,
.link:focus {
  --bs-link-color: var(--bs-primary70);
}

/* Text icon */
.text-icon {
  display: flex;
  flex-wrap: nowrap;
  flex-direction: row;
  align-items: center;
}

a.text-icon,
span.text-icon {
  display: inline-flex;
}

.text-icon > span + .icon,
.text-icon > .icon + .icon,
.text-icon > .icon + span {
  margin-left: 8px;
}

.text-icon.icon-top {
  align-items: start;
}

.text-icon.icon-top .icon-xs {
  margin-top: 4px;
}

/* Title bar */
.title-bar {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.title-bar > :first-child {
  margin-right: 16px;
}

.title-bar .btn {
  white-space: nowrap;
}

.title-bar-mobile {
  display: none;
  padding-top: 1rem;
}

/* Lines */
.h-line,
.v-line {
  --bs-line-color: var(--bs-gray-100);
  --bs-line-padding: 16px;
}

.h-line {
  border-top: 1px solid var(--bs-line-color);
  height: 0;
  margin-top: var(--bs-line-padding);
  margin-bottom: var(--bs-line-padding);
}

.v-line {
  border-left: 1px solid var(--bs-line-color);
  width: 0;
  margin-left: var(--bs-line-padding);
  margin-right: var(--bs-line-padding);
}

/* Shadows */
.shadow-s {
  box-shadow: var(--bs-shadow-s) !important;
}

.shadow-sb {
  box-shadow: var(--bs-shadow-sb) !important;
}

.shadow-m {
  box-shadow: var(--bs-shadow-m) !important;
}

.shadow-l {
  box-shadow: var(--bs-shadow-l) !important;
}

/* Language */
.lang-wrapper .lang-toggle {
  display: inline-flex;
  align-items: center;
}

.lang-wrapper .lang-toggle:not(.btn) {
  padding: 8px 0;
}

.lang-wrapper .lang-toggle span {
  margin-top: -4px;
  padding-left: 8px;
}

.lang-wrapper .lang-toggle .icon {
  margin-left: 8px;
}

.lang-wrapper .lang-toggle.show .icon {
  transform: rotate(180deg);
}

.lang-wrapper .dropdown-item {
  justify-content: start;
}

.lang-wrapper .dropdown-item span {
  padding-left: 8px;
  margin-top: -2px;
}

.lang-wrapper .dropdown-menu li + li {
  border-top: 1px solid var(--bs-gray-100);
}

/* Body View */
.body-view {
  display: flex;
  flex-direction: column;
  min-height: 100vh;
}

.body-view .web-view {
  flex: 1 0 auto;
}

/* Header */
header.navbar {
  --bs-header-item-px: 12px;
  display: block;
  padding: 0;
}

header .container {
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  justify-content: space-between;
  align-items: center;
  padding: 0;
}

header .nav-menu .navbar-nav {
  flex-direction: row;
}

header .nav-menu .navbar-nav .nav-link {
  display: flex;
  flex-wrap: wrap;
  flex-direction: row;
  align-items: center;
  white-space: nowrap;
  font-size: 18px;
  font-weight: 700;
  padding-left: var(--bs-header-item-px);
  padding-right: var(--bs-header-item-px);
}

header .nav-menu .navbar-nav .nav-link > .icon {
  fill: #fff;
  margin-left: 8px;
}

/* Header - Top */
.header-top {
  background-color: var(--bs-primary70);
}

.header-top > .container {
  height: 55px;
  justify-content: end;
}

/* Header - Middle */
.header-middle {
  background-color: var(--bs-primary80);
}
.header-middle > .container {
  height: 80px;
}
.header-middle .nav-left {
  display: flex;
  flex-wrap: nowrap;
  flex: 1 1 100%;
  align-items: center;
}
.header-middle .nav-right {
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
  flex: 1 2 100%;
  justify-content: end;
}
.header-middle .nav-right .btn + .btn {
  margin-left: 16px;
}
.header-middle .navbar-brand {
  height: 42px;
  display: flex;
  padding: 0;
  line-height: 0;
  align-items: center;
}
.header-middle .navbar-brand .brand-logo, .header-middle .navbar-brand .brand-text {
  height: inherit;
  margin: 0 32px 0 0;
}
.header-middle .navbar-brand .text-logo .text-logo-subtitle {
  font-size: 14px;
}
.header-middle .lang-wrapper .dropdown-menu {
  position: absolute;
  --bs-dropdown-min-width: 0;
}
.header-middle .lang-wrapper .lang-toggle {
  margin-right: 16px;
  --bs-link-color-rgb: var(--bs-white-rgb);
  --bs-link-hover-color-rgb: var(--bs-white-rgb);
}

/* Header - Bottom */
.header-bottom {
  --bs-header-item-px: 24px;
  background-color: var(--bs-primary80);
  transition: opacity 0.5s ease, visibility 0.5s ease; /* Transizione su opacità e visibilità */
}

.header-bottom > .container {
  height: 88px;
}

.header-middle + .header-bottom > .container {
  border-top: 1px solid var(--bs-gray-600);
}

.header-bottom .nav-menu > .navbar-nav > .nav-item > .nav-link {
  position: relative;
  height: 100%;
}

.header-bottom .nav-menu > .navbar-nav > .nav-item > .nav-link.active {
  font-weight: 700;
}

.header-bottom .nav-menu > .navbar-nav > .nav-item.active > .nav-link::after {
  position: absolute;
  height: 2px;
  top: calc(50% + 16px);
  right: 24px;
  left: 24px;
  background-color: var(--bs-white);
  border-radius: 1px;
}

.header-bottom .nav-menu > .navbar-nav > .nav-item > .nav-link::after {
  content: "";
}

header .nav-menu .dropdown-icon.icon {
  fill: white;
  margin-left: 8px;
}

/* Header - Bottom Dropdown */
.header-bottom .nav-item.dropdown {
  position: static;
}

.header-bottom .nav-item.dropdown .navbar-nav {
  flex-direction: row;
  max-width: 1200px;
  margin: 0 auto;
  --bs-nav-link-color: var(--bs-dark);
  --bs-nav-link-hover-color: var(--bs-dark);
  --bs-navbar-active-color: var(--bs-dark);
}

.header-bottom .nav-item.dropdown .dd-menu .nav-link {
  text-decoration: underline;
}

.header-bottom .nav-item.dropdown > .dd-menu {
  position: absolute;
  top: -9000px;
  right: 0;
  left: 0;
  padding: 48px 24px;
  opacity: 0;
  transition: opacity 0.3s;
  background-color: var(--bs-primary05);
}

.header-bottom .nav-item.dropdown:hover > .dd-menu {
  opacity: 1;
  top: 100%;
}

.header-bottom .nav-item.dropdown:hover > .nav-link .dropdown-icon {
  transform: rotate(180deg);
}

/* Header - Mobile */
header .mobile-handle {
  margin-right: 8px;
}

header .mobile-handle .icon {
  --bs-icon-fill: var(--bs-white);
}

header .mobile-handle,
header .mobile-handle .menu-close,
header .nav-mobile,
.header-middle .nav-right.menu-mobile {
  display: none;
}

.header-middle .nav-right .v-line {
  height: 40px;
  --bs-line-color: var(--bs-gray-600);
}

.nav-mobile .mobile-wrapper {
  position: absolute;
  background-color: var(--bs-primary80);
  left: -1000px;
  width: 100%;
  border-top: 2px solid var(--bs-primary30);
}

.nav-mobile .mobile-inner {
  padding: 18px 16px;
  overflow: hidden;
  overflow-y: auto;
  color: var(--bs-white);
  height: calc(100vh - 56px);
}

.nav-mobile .mobile-inner .h-line {
  --bs-line-color: var(--bs-primary30);
}

.nav-mobile .mobile-inner .navbar-nav .icon {
  --bs-icon-fill: var(--bs-white);
  margin-left: 8px;
}

.nav-mobile .mobile-inner .nav-item.active > .nav-link {
  text-decoration: underline;
}

.nav-mobile .dropdown.nav-item > .nav-link {
  display: flex;
  justify-content: space-between;
}

.nav-mobile .dropdown.nav-item > .nav-link.show .dropdown-icon {
  transform: rotate(90deg);
}

.nav-mobile .nav.navbar-nav .dropdown-menu {
  --bs-dropdown-bg: transparent;
  --bs-dropdown-color: var(--bs-white);
}

.nav-mobile .nav.navbar-nav .dropdown-menu > ul {
  max-height: none;
}

/* Header - Middle Search Wrapper */
.menu-desk .search-wrapper {
  margin: 0 16px;
}

.menu-desk .search-wrapper .form-group {
  --bs-field-border: var(--bs-primary02);
  --bs-field-bg: var(--bs-primary02);
  --bs-field-py: 5.5px;
  --bs-border-radius: 4px;
  width: 40px;
  overflow: hidden;
  border-radius: 4px;
  transition: all 0.3s;
}

.menu-desk .search-wrapper .dropdown-menu {
  position: absolute;
  right: 0;
  top: calc(100% + 4px);
  left: 0;
}

.menu-desk .search-wrapper.show .form-group {
  width: 340px;
}

.menu-mobile .search-wrapper {
  margin: 0 8px;
  position: static;
}

.menu-mobile .search-wrapper .group-inline {
  padding: 0;
}

.menu-mobile .search-wrapper .form-group {
  margin-bottom: 0;
}

.menu-mobile .search-wrapper .search-close {
  display: none;
}

.menu-mobile .search-wrapper .dropdown-menu {
  right: 0;
  top: 100%;
  left: 0;
  --bs-dropdown-padding-y: 12px;
  --bs-dropdown-padding-x: 16px;
}

.menu-mobile .search-wrapper.show .dropdown-menu {
  display: block;
}

.menu-mobile .search-wrapper.show .search-close {
  display: inline-flex;
}

.menu-mobile .search-wrapper.show .search-open {
  display: none;
}

/* Footer */
footer .container {
  color: var(--bs-white);
}

footer .nav {
  --bs-nav-link-color: var(--bs-white);
  --bs-nav-link-hover-color: var(--bs-white);
}

footer .nav-link {
  text-decoration: underline;
  padding-top: 0;
  padding-bottom: 0;
}

footer .icon {
  --bs-icon-fill: var(--bs-white);
}

/* Footer - Top */
.footer-top {
  background-color: var(--bs-primary80);
}

.footer-top > .container {
  padding-top: 24px;
  padding-bottom: 24px;
}

/* Footer - Bottom */
.footer-bottom {
  background-color: var(--bs-primary70);
}

.footer-bottom > .container {
  padding-top: 20px;
  padding-bottom: 20px;
}

/* Page Header */
.page-hero {
  background-position: center;
  background-size: 1440px auto;
  background-repeat: no-repeat;
  background-color: var(--bs-primary90);
  color: var(--bs-white);
}

.page-hero > .container {
  position: relative;
}

.page-hero .hero-text {
  padding-top: 32px;
}

.page-hero.hero-l1 > .container,
.page-hero.hero-l2 > .container,
.page-hero.hero-l1 > .container-fluid,
.page-hero.hero-l2 > .container-fluid {
  display: flex;
  flex-direction: row;
  justify-content: center;
}

.page-hero .container-hero {
  flex: 0 1 40%;
  height: auto;
  padding: 48px 0;
  display: flex;
  justify-content: center;
  flex-direction: column;
}

.page-hero .container-image {
  flex: 0 1 60%;
  position: relative;
  padding: 0 1px;
}

.page-hero .container-image .image-mask1,
.page-hero .container-image .image-mask2 {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
}

.page-hero .container-image .image-mask2,
.page-hero .container-image .image-mask2 {
  background-size: 1440px auto;
  background-repeat: no-repeat;
}

.page-hero .container-logged {
  position: absolute;
  top: 0px;
  right: 60px;
  bottom: 0;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

/* */
.page-hero.hero-l1 .hero-text {
  font-size: 1.125rem;
}

.page-hero.hero-l1 .container-hero {
  padding-top: 56px;
}

.page-hero.hero-l1,
.page-hero.hero-l2 {
  background-image: url("../imgs/header/hero-mask-03.svg");
  background-position: left bottom;
}

.page-hero .container-image .image-mask1 {
  background-image: url("../imgs/header/hero-mask-01.svg");
  background-position: left top;
}

.page-hero .container-image .image-mask2 {
  background-image: url("../imgs/header/hero-mask-02.svg");
  background-position: right bottom;
}

.page-hero .container-image .image {
  height: 100%;
  background-color: var(--bs-primary);
  background-size: cover;
  background-position: center;
}

/* */
.page-hero.hero-l3 > .container,
.page-hero.hero-l3 > .container-fluid {
  padding: 48px calc(var(--bs-gutter-x) * 0.5);
}

/* */
.page-hero.hero-l3.hero-small .container {
  padding: 32px calc(var(--bs-gutter-x) * 0.5);
}

/* Alert */
.alert {
  --bs-alert-color: var(--bs-dark);
  display: flex;
  flex-direction: row;
  align-items: center;
  min-height: 80px;
  padding-left: 96px;
  background-position: 24px center;
  background-size: 44px 44px;
  background-image: var(--bs-alert-bg-img);
  background-color: var(--bs-alert-bg);
  background-repeat: no-repeat;
  border-top: none;
  border-right: none;
  border-bottom: none;
  border-radius: 4px;
  border-left: 8px solid var(--bs-alert-border-color);
}

.alert .alert-body {
  flex: 1 0 auto;
  max-width: 100%;
}

.alert .alert-heading + .alert-text {
  padding-top: 4px;
}

.alert .alert-text {
  margin: 0;
  font-size: 18px;
}

.alert .alert-link {
  display: flex;
  flex-direction: row;
  align-items: center;
}

.alert .alert-link .btn + .btn {
  margin-left: 24px;
}

.alert.alert-info {
  --bs-alert-bg: var(--bs-primary05);
  --bs-alert-border-color: var(--bs-info);
  --bs-alert-bg-img: url("../imgs/icon/alert/info-bg.svg");
}

.alert.alert-warning {
  --bs-alert-bg: var(--bs-warning02);
  --bs-alert-border-color: var(--bs-warning40);
  --bs-alert-bg-img: url("../imgs/icon/alert/warning-bg.svg");
}

.alert.alert-danger {
  --bs-alert-bg: var(--bs-danger05);
  --bs-alert-border-color: var(--bs-danger);
  --bs-alert-bg-img: url("../imgs/icon/alert/danger-bg.svg");
}

.alert.alert-success {
  --bs-alert-bg: var(--bs-success05);
  --bs-alert-border-color: var(--bs-success);
  --bs-alert-bg-img: url("../imgs/icon/alert/success-bg.svg");
}

.alert.alert-dismissible {
  padding-right: 32px;
}

.alert.alert-dismissible .btn-close {
  width: auto;
  height: auto;
  padding: 0;
}

.alert.alert-dismissible .btn-close .icon {
  fill: var(--bs-alert-border-color);
}

.alert .btn {
  --bs-btn-color: var(--bs-dark);
}

/* Breadcrumb */
.breadcrumb-container .link-mobile {
  display: none;
}

.breadcrumb-container .link-mobile .icon {
  --bs-icon-fill: var(--bs-primary);
}

.breadcrumb-container .link-mobile:hover .icon {
  --bs-icon-fill: var(--bs-primary40);
}

.breadcrumb-item {
  display: flex;
  align-items: center;
  font-weight: 600;
}

.breadcrumb-item .link:not(:hover) {
  --bs-link-color: var(--bs-primary70);
}

.breadcrumb-item + .breadcrumb-item::before {
  width: 28px;
  height: 18px;
  background-size: 16px 16px;
  background-position: center;
  background-repeat: no-repeat;
  background-image: url("../imgs/icon/breadcrumb/separator.svg");
}

/* Badge */
.badge {
  --bs-badge-border: var(--bs-badge-bg);
  --bs-badge-color: var(--bs-white);
  --bs-badge-icon: var(--bs-badge-color);
  display: inline-flex;
  align-items: center;
  border: 1px solid var(--bs-badge-border);
  background-color: var(--bs-badge-bg);
  min-height: 28px;
}

.badge .icon + span,
.badge span + .icon {
  margin-left: 8px;
}

.badge .icon {
  --bs-icon-fill: var(--bs-badge-icon);
  --bs-icon-size: 18px;
}

.badge.badge-lg {
  min-height: 32px;
  --bs-badge-padding-y: 5px;
  --bs-badge-font-size: 16px;
}

.badge.badge-lg .icon {
  --bs-icon-size: 20px;
}

.badge.badge-sm {
  min-height: 24px;
  --bs-badge-padding-y: 3px;
  --bs-badge-padding-x: 8px;
}

.badge.badge-sm .icon {
  --bs-icon-size: 16px;
}

.badge.bg-primary {
  --bs-badge-bg: var(--bs-primary05);
  --bs-badge-color: var(--bs-primary);
  background-color: var(--bs-badge-bg) !important;
}

.badge.bg-outline {
  --bs-badge-bg: var(--bs-white);
  --bs-badge-color: var(--bs-dark);
  --bs-badge-icon: var(--bs-primary);
  --bs-badge-border: var(--bs-gray-100);
}

/* Badge - Calendar */
.calendar-badge {
  display: flex;
  align-items: center;
}

.calendar-badge .v-line {
  height: 32px;
}

.calendar-badge .h5 {
  color: var(--bs-dark);
  font-size: 18px;
}

.calendar-badge .caption {
  color: var(--bs-gray-600);
}

.calendar-badge .roboto {
  color: var(--bs-gray-600);
  padding-top: 4px;
}

/* Chip */
.chip {
  --bs-chip-bg: var(--bs-white);
  --bs-chip-color: var(--bs-primary);
  --bs-chip-hover-bg: var(--bs-primary05);
  --bs-chip-hover-color: var(--bs-primary70);
  --bs-chip-active-bg: var(--bs-primary70);
  --bs-chip-active-color: var(--bs-white);
  --bs-chip-h: 28px;
  display: inline-flex;
  align-items: center;
  color: var(--bs-chip-color);
  font-size: 14px;
  font-weight: 600;
  height: var(--bs-chip-h);
  padding-left: calc(var(--bs-chip-h) * 0.5);
  padding-right: calc(var(--bs-chip-h) * 0.5);
  border-radius: calc(var(--bs-chip-h) * 0.5);
  border: 1px solid var(--bs-chip-color);
  background-color: var(--bs-chip-bg);
  transition: all 0.3s;
}

.chip .icon + span,
.chip span + .icon {
  margin-left: 8px;
}

.chip .icon {
  --bs-icon-fill: var(--bs-chip-color);
  --bs-icon-size: 18px;
}

.chip.chip-lg {
  --bs-chip-h: 32px;
  font-size: 16px;
}

.chip.chip-lg .icon {
  --bs-icon-size: 20px;
}

.chip.chip-sm {
  --bs-chip-h: 24px;
}

.chip.chip-sm .icon {
  --bs-icon-size: 16px;
}

a.chip:not(.disabled) {
  cursor: pointer;
}

a.chip:not(.disabled):hover {
  --bs-chip-color: var(--bs-chip-hover-color);
  --bs-chip-bg: var(--bs-chip-hover-bg);
}

a.chip:not(.disabled):active {
  --bs-chip-color: var(--bs-chip-active-color);
  --bs-chip-bg: var(--bs-chip-active-bg);
  border-color: var(--bs-chip-active-bg);
}

.chip.disabled {
  --bs-chip-color: var(--bs-gray-600);
  --bs-chip-bg: var(--bs-gray-50);
  border-color: var(--bs-gray-300);
}

a.chip.disabled {
  cursor: default;
}

.chip.chip-success:not(.disabled) {
  --bs-chip-color: var(--bs-success70);
  --bs-chip-hover-color: var(--bs-success80);
  --bs-chip-hover-bg: var(--bs-success05);
  --bs-chip-active-color: var(--bs-white);
  --bs-chip-active-bg: var(--bs-success90);
}

.chip.chip-warning:not(.disabled) {
  --bs-chip-color: var(--bs-warning70);
  --bs-chip-hover-color: var(--bs-warning80);
  --bs-chip-hover-bg: var(--bs-warning05);
  --bs-chip-active-color: var(--bs-white);
  --bs-chip-active-bg: var(--bs-warning90);
}

.chip.chip-danger:not(.disabled) {
  --bs-chip-color: var(--bs-danger60);
  --bs-chip-hover-color: var(--bs-danger70);
  --bs-chip-hover-bg: var(--bs-danger05);
  --bs-chip-active-color: var(--bs-white);
  --bs-chip-active-bg: var(--bs-danger90);
}

/* Accordion */
.accordion {
  --bs-accordion-btn-bt: 2px solid var(--bs-primary20) !important;
  --bs-accordion-btn-bb: 1px solid var(--bs-primary10) !important;
}

.accordion .accordion-button {
  flex-wrap: nowrap;
  justify-content: space-between;
  padding-right: calc(var(--bs-accordion-btn-padding-x) + 38px);
  font-size: 1.25rem;
  line-height: 1.5rem;
  font-weight: 600;
}

.accordion .accordion-button::after {
  position: absolute;
  height: auto;
  top: 0;
  right: var(--bs-accordion-btn-padding-x);
  bottom: 0;
  background-position: center;
}

.accordion .accordion-button .icon {
  --bs-icon-fill: var(--bs-accordion-btn-color);
}

.accordion .accordion-button > .text-icon .icon + span {
  margin-left: 16px;
}

.accordion .accordion-button[aria-expanded=true] {
  border-top: var(--bs-accordion-btn-bt);
}

.accordion .accordion-button[aria-expanded=true] .icon {
  --bs-icon-fill: var(--bs-accordion-active-color);
}

.accordion .accordion-button[aria-expanded=false].collapsed {
  border-bottom: var(--bs-accordion-btn-bb);
}

.accordion .accordion-collapse.collapsing,
.accordion .accordion-collapse.collapse.show {
  background-color: var(--bs-accordion-active-bg);
}

.accordion .accordion-button.button-calendar {
  padding-top: 8px;
  padding-bottom: 8px;
}

/* Progress */
.progress {
  --bs-progress-height: 8px;
  --bs-progress-border-radius: 4px;
  --bs-progress-bg: var(--bs-primary05);
}

.progress.progress-lg {
  --bs-progress-height: 12px;
  --bs-progress-border-radius: 6px;
}

.progress.progress-sm {
  --bs-progress-height: 4px;
  --bs-progress-border-radius: 2px;
}

.progress.disabled {
  --bs-progress-bar-bg: var(--bs-gray-300);
  --bs-progress-bg: var(--bs-gray-100);
}

.progress.success {
  --bs-progress-bar-bg: var(--bs-success);
}

.progress.danger {
  --bs-progress-bar-bg: var(--bs-danger);
}

/* Dropdown */
.dropdown {
  --bs-dropdown-item-border-radius: 4px;
  --bs-dropdown-toggle-color: var(--bs-dark);
}

.dropdown a.dropdown-toggle {
  color: var(--bs-dropdown-toggle-color);
}

.dropdown a.dropdown-toggle:hover {
  --bs-dropdown-toggle-color: var(--bs-primary40);
}

.dropdown a.dropdown-toggle.show {
  --bs-dropdown-toggle-color: var(--bs-primary70);
}

.dropdown a.dropdown-toggle .dropdown-icon {
  --bs-icon-fill: var(--bs-dropdown-toggle-color);
}

.dropdown a.dropdown-toggle.show .dropdown-icon {
  transform: rotate(180deg);
}

.dropdown-menu {
  box-shadow: var(--bs-dropdown-box-shadow);
}

.dropdown-menu > ul {
  list-style: none;
  padding: 0;
  margin: 0;
  overflow: hidden;
  max-height: 280px;
}

.dropdown-menu li + li {
  padding-top: 8px;
}

.dropdown-menu .search-wrapper {
  padding-bottom: 16px;
}

.dropdown .dropdown-toggle::after {
  display: none;
}

.dropdown-item {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: nowrap;
}

.dropdown-item > .icon {
  margin-left: 8px;
}

a.dropdown-item {
  transition: color 0.3s, background 0.3s;
  font-weight: 600;
}

a.dropdown-item:hover .icon {
  --bs-icon-fill: var(--bs-dropdown-link-hover-color);
}

a.dropdown-item.active .icon,
a.dropdown-item:active .icon {
  --bs-icon-fill: var(--bs-dropdown-link-active-color);
}

.dropdown-menu > .dropdown-link {
  display: block;
  text-align: center;
}

.dropdown-menu > .dropdown-link.link-up {
  padding-bottom: 8px;
}

.dropdown-menu > .dropdown-link.link-down {
  padding-top: 8px;
}

.dropdown-menu > .dropdown-link.link-all {
  padding-bottom: 16px;
  color: var(--bs-gray-600);
}

.dropdown-menu > .dropdown-title {
  padding-top: 16px;
  color: var(--bs-gray-600);
}

.dropdown-menu .dropdown-control {
  padding: 4px 8px;
}

.dropdown-menu .dropdown-control label {
  font-weight: 600;
}

/* Modal */
.modal .modal-content {
  padding: 32px 32px 16px 32px;
  box-shadow: 0 0 15px rgba(0, 0, 0, 0.15);
}

.modal .modal-header {
  align-items: start;
  justify-content: space-between;
}

.modal .modal-body {
  padding: 32px 0;
  overflow: hidden;
  overflow-y: auto;
  max-height: calc(100vh - 228px);
}

.modal .modal-footer {
  padding: 0;
  border-top: none;
}

.modal .modal-header .btn-close {
  width: auto;
  height: auto;
  margin: 8px 0 0 0;
  padding: 0;
}

.modal .modal-footer .btn {
  margin-bottom: 16px;
}

.modal .modal-footer .btn + .btn {
  margin-left: 24px;
}

.modal .modal-footer .btn-group-right {
  text-align: right;
}

/* Cards */
.card {
  --bs-card-spacer-iy: 16px;
  --bs-card-side-w: 200px;
  --bs-card-box-shadow: none;
  box-shadow: var(--bs-card-box-shadow);
}

.card:not(.border):not(.no-shadow) {
  --bs-card-box-shadow: 0 0 15px rgba(0, 0, 0, .15);
}

.card.card-sm {
  --bs-card-spacer-x: 16px;
  --bs-card-spacer-y: 16px;
}

.card > .card-date {
  padding: 12px var(--bs-card-spacer-x);
  background-color: var(--bs-primary05);
  font-family: "Roboto Mono", monospace;
  font-size: 18px;
  text-align: right;
}

a.card {
  outline: 1px solid transparent;
  transition: outline 0.3s;
}

a.card:hover {
  outline: 1px solid var(--bs-primary20);
}

.card-body .card-title {
  margin-bottom: 0;
}

.card-body .card-title.title-border {
  padding-bottom: var(--bs-card-spacer-iy);
}

.card-body .card-title.title-border + .card-text {
  border-top: 1px solid var(--bs-gray-200);
}

.card-body .card-title + .card-text {
  padding-top: var(--bs-card-spacer-iy);
}

.card-body .card-bar {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.card-body > .card-bar:not(:first-child) {
  padding-top: var(--bs-card-spacer-y);
}

.card-body > .card-bar:not(:last-child) {
  padding-bottom: var(--bs-card-spacer-y);
}

.card-body .card-bar .bar-group {
  display: flex;
  align-items: center;
}

.card-body .card-bar .bar-group > * + * {
  margin-left: 16px;
}

.card-body > .btn-toolbar {
  padding-top: var(--bs-card-spacer-y);
}

.card-body > .card-bar + .btn-toolbar {
  padding-top: 0;
}

/* */
.card.h-100 > .card-body {
  display: flex;
  flex-direction: column;
  justify-content: start;
}

.card.h-100 > .card-body > .btn-toolbar {
  margin-top: auto;
}

/* Card - Image side */
.card.card-img-side {
  display: flex;
  flex-wrap: nowrap;
  flex-direction: row;
}

.card.card-img-side .card-img {
  border-radius: var(--bs-card-border-radius) 0 0 var(--bs-card-border-radius);
  width: var(--bs-card-side-w);
  min-width: var(--bs-card-side-w);
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
}

.card.card-img-side .card-img.img-inner {
  --bs-card-side-w: 118px;
  background-color: var(--bs-primary05);
  display: flex;
  justify-content: center;
  align-items: center;
}

.card.card-img-side .card-img.img-fit {
  --bs-card-side-w: auto;
}

/* Card - Image All Background */
.card .card-img-bg {
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
}

.card .card-body.card-img-bg {
  border-radius: var(--bs-card-border-radius);
}

/* Card - Calendar */
.card-body .calendar-badge {
  border-radius: var(--bs-card-border-radius);
  background-color: var(--bs-primary05);
  padding: 8px var(--bs-card-spacer-x);
}

.card-body .calendar-badge .icon {
  --bs-icon-fill: var(--bs-primary);
  margin-right: var(--bs-card-spacer-x);
}

.card-body .calendar-badge + .card-title {
  padding-top: 16px;
}

/* Card - Search */
.form-search {
  --bs-field-space: 32px;
}

.form-search .card {
  background-color: var(--bs-primary02);
  box-shadow: none;
}

.form-search .card-search {
  margin-bottom: 8px;
}

.form-search .card-search .card-body {
  display: flex;
  flex-direction: row;
}

.form-search .card-search .v-line {
  --bs-line-padding: var(--bs-field-space);
  --bs-line-color: var(--bs-gray-300);
}

.form-search .card-search .form-group {
  margin-right: var(--bs-field-space);
}

.form-search .card-search .btn .icon {
  transition: transform 0.3s;
}

.form-search .card-search .btn[aria-expanded=true] .icon {
  transform: rotate(180deg);
}

.form-search .card-filter {
  display: none;
}

.form-search .card-filter .card-body {
  display: flex;
  flex-direction: row;
  justify-content: space-between;
}

.form-search .card-filter .h-line {
  display: none;
  --bs-line-padding: 0;
  margin: 0 var(--bs-card-spacer-x);
}

.form-search .card.collapse.show + .card-filter {
  border-top-left-radius: 0;
  border-top-right-radius: 0;
}

.form-search .card.collapse.show + .card-filter .h-line {
  display: block;
}

.form-search .card.collapse .card-body {
  padding-bottom: 0;
}

.form-search .filter-list {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
}

.form-search .filter-list .badge + .badge {
  margin-left: 16px;
}

.form-search.filter-show .card-filter {
  display: flex;
}

.form-search.filter-show .card.collapse {
  border-bottom-left-radius: 0;
  border-bottom-right-radius: 0;
}

/* Cotainer Frame */
.container-frame {
  --bs-frame-info: 336px;
  --bs-frame-nav: 336px;
  display: flex;
  flex-wrap: nowrap;
  flex-direction: row;
}

.container-frame > .frame-info {
  flex: 1 0 var(--bs-frame-info);
  order: 3;
  width: var(--bs-frame-nav);
  padding: 2rem 0 2rem 2rem;
}

.container-frame > .frame-nav {
  flex: 1 0 var(--bs-frame-nav);
  order: 1;
  width: var(--bs-frame-nav);
  padding: 2rem 0;
}

.container-frame > .frame-body {
  flex: 0 1 100%;
  order: 2;
  padding: 2rem 0 2rem 2rem;
}

/* max-width:calc(100% - var(--bs-frame-nav)); */
/* Sidebar */
.sidebar > .card {
  --bs-card-spacer-x: 16px;
  --bs-card-spacer-y: 16px;
  --bs-card-cap-padding-x: 16px;
  --bs-card-cap-padding-y: 16px;
  --bs-card-cap-bg: var(--bs-white);
  --bs-card-border-width: 1px;
  --bs-card-border-color: var(--bs-primary05);
  --bs-card-box-shadow: none;
}

.sidebar .card-header {
  color: var(--bs-primary);
  border-bottom: none;
}

.sidebar .sidebar-scroll {
  overflow: hidden;
  overflow-y: auto;
}

.sidebar .sidebar-scroll > .card-body {
  border-top: var(--bs-card-border-width) solid var(--bs-card-border-color);
}

.sidebar .sidebar-list {
  --bs-list-color: var(--bs-primary);
  --bs-list-bg: transparent;
  --bs-list-hover-color: var(--bs-primary40);
  --bs-list-hover-bg: var(--bs-primary02);
  --bs-list-active-color: var(--bs-primary70);
  --bs-list-active-bg: var(--bs-primary02);
  list-style: none;
  padding: 0;
  margin: 0;
}

.sidebar .sidebar-list .list-link {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: nowrap;
  position: relative;
  padding: var(--bs-card-spacer-y) var(--bs-card-spacer-x);
  color: var(--bs-list-color);
  font-size: 18px;
  font-weight: 600;
  transition: all 0.3s;
  background-color: var(--bs-list-bg);
}

.sidebar .sidebar-list .list-link .icon {
  --bs-icon-fill: var(--bs-list-color);
}

.sidebar .sidebar-list .list-link .dropdown-icon {
  transform: rotate(180deg);
  transition: all 0.3s;
}

.sidebar .sidebar-list .list-link.collapsed .dropdown-icon {
  transform: rotate(0deg);
}

.sidebar .sidebar-list .list-link:not(.active):hover {
  --bs-list-color: var(--bs-list-hover-color);
}

.sidebar .sidebar-list .list-link.active {
  --bs-list-color: var(--bs-primary70);
}

/* Sidebar - 1° livello */
.sidebar-scroll .list-link::before {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  transition: all 0.3s;
}

/* Sidebar - Mobile */
.sidebar .card-header-mobile {
  --bs-list-mobile-color: var(--bs-primary);
  display: none;
  flex-wrap: nowrap;
  justify-content: space-between;
  align-items: center;
  font-size: 1.25rem;
  font-weight: 600;
  color: var(--bs-list-mobile-color);
}

.sidebar .card-header-mobile .icon {
  transition: all 0.3s;
  --bs-icon-fill: var(--bs-list-mobile-color);
}

/* Sidebar Nav */
.frame-nav .sidebar-list .list-link:not(.active):hover {
  --bs-list-bg: var(--bs-list-hover-bg);
}

.frame-nav .sidebar-list .list-link.active {
  --bs-list-bg: var(--bs-primary02);
}

/* Sidebar Nav - 1° livello */
.frame-nav .sidebar-scroll > .sidebar-list > li {
  border-top: 1px solid var(--bs-primary05);
}

.frame-nav .sidebar-scroll > .sidebar-list > li > .list-link.active::before {
  content: "";
  width: 4px;
  background-color: var(--bs-primary70);
}

/* Sidebar Nav - 2° livello */
.frame-nav .sidebar-list .sidebar-list {
  --bs-card-spacer-x: 16px;
  --bs-card-spacer-y: 8px;
  --bs-list-hover-bg: var(--bs-primary05);
  background-color: var(--bs-primary02);
  padding: 8px var(--bs-card-spacer-x);
  margin-top: 4px;
}

.frame-nav .sidebar-list .sidebar-list > li + li {
  margin-top: 16px;
}

.frame-nav .sidebar-list .sidebar-list .list-link {
  border-radius: var(--bs-card-border-radius);
}

.frame-nav .sidebar-list .sidebar-list .list-link.active {
  --bs-list-color: var(--bs-primary70);
  --bs-list-bg: var(--bs-primary10);
}

.frame-nav .sidebar-list .sidebar-list > .list-dropdown > .list-link.active {
  --bs-list-bg: var(--bs-primary05);
  border-radius: var(--bs-card-border-radius) var(--bs-card-border-radius) 0 0;
}

/* Sidebar Nav - 3° livello */
.frame-nav .sidebar-list .sidebar-list .sidebar-list {
  --bs-list-hover-bg: var(--bs-primary10);
  --bs-list-active-bg: var(--bs-primary20);
  border-radius: 0 0 var(--bs-card-border-radius) var(--bs-card-border-radius);
  background-color: var(--bs-primary05);
  margin-top: 0px;
}

.frame-nav .sidebar-list .sidebar-list .sidebar-list .list-link.active {
  --bs-list-bg: var(--bs-primary20);
}

/* Sidebar Nav - Mobile */
.frame-nav .card-header-mobile {
  height: 62px;
  padding: 16px;
}

/* Sidebar Info */
.frame-info .sidebar > .card {
  --bs-card-border-width: 0;
  --bs-card-border-color: var(--bs-primary05);
}

.frame-info .sidebar-list {
  padding-top: var(--bs-card-spacer-y);
}

.frame-info .sidebar-list .list-link.active::before {
  background-color: var(--bs-list-active-color);
}

.frame-info .sidebar-scroll > .sidebar-list {
  border-top: 1px solid var(--bs-primary05);
}

/* Sidebar Info - 1° livello */
.frame-info .sidebar-scroll .list-link::before {
  content: "";
  width: 2px;
  background-color: var(--bs-gray-300);
}

.frame-info .sidebar-scroll .list-link:hover::before {
  background-color: var(--bs-list-hover-color);
}

/* Sidebar Info - 2° livello */
.frame-info .sidebar-list .sidebar-list {
  --bs-card-spacer-y: 8px;
  padding: 16px 0 12px 24px;
}

/* Sidebar Info - Mobile */
.frame-info .card-header-mobile {
  padding: 8px 16px;
}

/* Stepper */
.stepper-wrapper {
  --bs-step-color: var(--bs-gray-500);
  --bs-step-text: var(--bs-gray-500);
  --bs-step-bg: var(--bs-primary05);
  --bs-step-icon-size: 40px;
  padding-bottom: 16px;
}

.stepper-wrapper .stepper {
  display: flex;
  flex-direction: row;
}

.stepper-wrapper .step-item {
  position: relative;
  flex: 0 1 100%;
}

.stepper-wrapper .step-item::before {
  position: absolute;
  content: "";
  display: block;
  background-color: var(--bs-gray-300);
}

.stepper-wrapper .step-item + .step-item:last-child::before {
  display: none;
}

.stepper-wrapper .step-item.success {
  --bs-step-bg: var(--bs-success60);
  --bs-step-text: var(--bs-success60);
  --bs-step-color: var(--bs-white);
}

.stepper-wrapper .step-item.danger {
  --bs-step-bg: var(--bs-danger50);
  --bs-step-text: var(--bs-danger50);
  --bs-step-color: var(--bs-white);
}

.stepper-wrapper .step-item.active {
  --bs-step-bg: var(--bs-primary70);
  --bs-step-text: var(--bs-primary40);
  --bs-step-color: var(--bs-white);
}

.stepper-wrapper .step-item .icon {
  --bs-icon-fill: var(--bs-step-color);
}

.stepper-wrapper .step-icon {
  width: var(--bs-step-icon-size);
  min-width: var(--bs-step-icon-size);
  height: var(--bs-step-icon-size);
  display: flex;
  justify-content: center;
  align-items: center;
  border-radius: 50%;
  background-color: var(--bs-step-bg);
  font-family: "Roboto Mono", monospace;
  color: var(--bs-step-color);
}

.stepper-wrapper.step-lg {
  --bs-step-icon-size: 48px;
}

.stepper-wrapper.step-sm {
  --bs-step-icon-size: 32px;
}

.stepper-wrapper .step-label {
  color: var(--bs-gray-600);
  font-size: 0.875rem;
  font-weight: 600;
}

.stepper-wrapper .step-title {
  color: var(--bs-dark);
  font-size: 1rem;
  font-weight: 600;
}

.stepper-wrapper .step-label + .step-title {
  padding-top: 4px;
}

.stepper-wrapper .step-text {
  color: var(--bs-step-text);
  font-size: 0.875rem;
  font-weight: 600;
  padding-top: 4px;
}

/* Stepper - Mobile */
.stepper-wrapper .stepper-mobile {
  display: none;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: space-between;
}

.stepper-wrapper .stepper-mobile .step-item {
  flex: 1 0 calc(100% - 48px);
  padding-bottom: 0px;
}

.stepper-wrapper .stepper-mobile .step-item::before {
  display: none;
}

.stepper-wrapper .stepper-mobile .stepper-title {
  flex: 1 0 100%;
  display: none;
  padding-top: 24px;
}

.stepper-wrapper .stepper-mobile .stepper-progress {
  flex: 1 0 100%;
  text-align: right;
  font-size: 0.875rem;
}

.stepper-wrapper .stepper-mobile .stepper-btn {
  flex: 0 0 auto;
  margin-left: auto;
}

.stepper-wrapper .stepper-mobile .btn-close {
  width: auto;
  height: auto;
  padding: 0;
  line-height: 0;
}

.stepper-wrapper .stepper-progress .progress {
  --bs-progress-bar-bg: var(--bs-primary50);
  --bs-progress-height: 3px;
  margin-top: 4px;
}

.stepper-wrapper .stepper-progress.success .progress {
  --bs-progress-bar-bg: var(--bs-success60);
}

.stepper-wrapper .stepper-progress.danger .progress {
  --bs-progress-bar-bg: var(--bs-danger50);
}

/* Tab */
.nav.nav-tabs {
  --bs-tabs-bg: var(--bs-white);
  --bs-tabs-color: var(--bs-dark);
  --bs-tabs-hover-bg: var(--bs-primary40);
  --bs-tabs-hover-color: var(--bs-white);
  --bs-tabs-active-bg: var(--bs-primary02);
  --bs-tabs-active-color: var(--bs-primary70);
}

.nav.nav-tabs .nav-link {
  display: flex;
  flex-direction: row;
  background-color: var(--bs-tabs-bg);
  color: var(--bs-tabs-color);
  border-radius: 0;
  position: relative;
}

.nav.nav-tabs .nav-link .icon {
  --bs-icon-fill: var(--bs-tabs-color);
}

.nav.nav-tabs .nav-link span + .icon,
.nav.nav-tabs .nav-link .icon + span {
  margin-left: 8px;
}

.nav.nav-tabs .nav-item:first-child .nav-link {
  border-radius: var(--bs-nav-tabs-border-radius) 0 0 var(--bs-nav-tabs-border-radius);
}

.nav.nav-tabs .nav-item:last-child .nav-link {
  border-radius: 0 var(--bs-nav-tabs-border-radius) var(--bs-nav-tabs-border-radius) 0;
}

.nav.nav-tabs .nav-link::before {
  position: absolute;
  right: 0;
  bottom: 0;
  left: 0;
  height: 2px;
  border-radius: 2px;
  background-color: var(--bs-tabs-color);
}

.nav.nav-tabs .nav-link:hover {
  --bs-tabs-bg: var(--bs-tabs-hover-bg);
  --bs-tabs-color: var(--bs-tabs-hover-color);
}

.nav.nav-tabs .nav-link.active {
  --bs-tabs-bg: var(--bs-tabs-active-bg);
  --bs-tabs-color: var(--bs-tabs-active-color);
}

.nav.nav-tabs .nav-link.active::before {
  content: "";
}

.nav.nav-tabs.blue {
  --bs-tabs-bg: var(--bs-primary05);
  --bs-tabs-color: var(--bs-dark);
  --bs-tabs-hover-bg: var(--bs-primary40);
  --bs-tabs-hover-color: var(--bs-white);
  --bs-tabs-active-bg: var(--bs-primary70);
  --bs-tabs-active-color: var(--bs-white);
}

.nav.nav-tabs.dark {
  --bs-tabs-bg: var(--bs-primary80);
  --bs-tabs-color: var(--bs-white);
  --bs-tabs-hover-bg: var(--bs-primary50);
  --bs-tabs-hover-color: var(--bs-white);
  --bs-tabs-active-bg: var(--bs-primary80);
  --bs-tabs-active-color: var(--bs-white);
}

.nav.nav-tabs.blue .nav-link::before,
.nav.nav-tabs.dark .nav-link::before {
  right: 16px;
  bottom: 8px;
  left: 16px;
}

/* Popover */
.popover-body {
  padding-top: 0;
}

.popover-body a {
  display: block;
  margin-top: 16px;
  font-size: 16px;
  font-weight: 600;
  --bs-link-color-rgb: var(--bs-white);
  text-decoration: underline;
}

.popover-header {
  padding-right: 32px;
  background-repeat: no-repeat;
  background-size: 20px 20px;
  background-position: right 8px center;
  background-image: url("../imgs/icon/popover/close.svg");
}

/* Carousel */
.carousel {
  --bs-slider-indicatar-h: 44px;
  --bs-slider-inner-p: 140px;
  --bs-slider-item-p: 12px;
}

.carousel .carousel-control-prev,
.carousel .carousel-control-next {
  width: var(--bs-slider-inner-p);
  bottom: var(--bs-slider-indicatar-h);
  opacity: 1;
}

.carousel .carousel-control-prev .icon,
.carousel .carousel-control-next .icon {
  --bs-icon-fill: var(--bs-primary50);
}

.carousel .carousel-control-prev:disabled .icon,
.carousel .carousel-control-next:disabled .icon {
  --bs-icon-fill: var(--bs-gray-200);
}

.carousel .carousel-indicators {
  position: static;
  margin: 0;
  padding: 16px 0;
}

.carousel .carousel-indicators > button {
  background-color: var(--bs-gray-300);
  width: 12px;
  height: 12px;
  border-radius: 6px;
  padding: 0;
  margin: 0 6px;
  box-sizing: border-box;
  background-clip: unset;
  line-height: 0;
  border: none;
}

.carousel .carousel-indicators > button.active {
  background-color: var(--bs-primary40);
}

/* */
.carousel .slider-inner {
  display: flex;
  flex-wrap: nowrap;
  margin: 0 var(--bs-slider-inner-p);
  overflow: hidden;
  max-width: 100%;
}

.carousel .slider-inner .slider-item {
  flex: 1 0 100%;
  opacity: 0.7;
  transition: all 0.3s;
  padding: 16px var(--bs-slider-item-p);
}

.carousel .slider-inner .slider-item.active {
  opacity: 1;
}

/* KPI - Micro */
.card.kpi-micro {
  --bs-card-spacer-y: 16px;
  --bs-card-spacer-x: 16px;
  --bs-kpi-number-bg: var(--bs-secondary20);
}

.card.kpi-micro .kpi-content {
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  justify-content: center;
  align-items: center;
  overflow: none;
  overflow-x: auto;
}

.card.kpi-micro .kpi-item {
  font-size: 1rem;
  font-weight: 600;
  display: flex;
  flex-direction: row;
  align-items: center;
  flex-wrap: nowrap;
  padding: 0 16px;
}

.card.kpi-micro .kpi-item .number {
  font-size: 1.125rem;
  font-weight: 700;
  font-family: "Roboto Mono", monospace;
  display: inline-block;
  padding: 4px 8px;
  background-color: var(--bs-kpi-number-bg);
  border-radius: 4px;
}

.card.kpi-micro .kpi-item span {
  white-space: nowrap;
}

.card.kpi-micro .kpi-item + .kpi-item {
  margin-left: 16px;
}

.card.kpi-micro .kpi-item img + span,
.card.kpi-micro .kpi-item span + span,
.card.kpi-micro .kpi-item span + .icon {
  margin-left: 8px;
}

/* KPI */
.kpi {
  --bs-kpi-bg: var(--bs-primary05);
  --bs-kpi-item-bg: var(--bs-primary);
  --bs-kpi-item-color: var(--bs-white);
}

.kpi .nav-tabs .nav-item {
  flex: 1 0 auto;
}

.kpi .carousel {
  --bs-carousel-inner-p: 0;
  margin-top: 24px;
}

.kpi .card {
  --bs-card-bg: var(--bs-kpi-item-bg);
  --bs-card-color: var(--bs-kpi-item-color);
  --bs-heading-color: var(--bs-kpi-item-color);
}

.kpi .kpi-item {
  padding: 24px 172px 24px 24px;
  color: var(--bs-kpi-item-color);
  background-repeat: no-repeat;
  background-size: 156px auto;
  background-position: right 16px bottom;
}

.kpi .kpi-item .number {
  font-size: 2.5rem;
  font-weight: 700;
  color: var(--bs-kpi-item-color);
}

.kpi .card .kpi-item {
  height: 100%;
}

/* KPI  - Mobile */
.kpi .accordion {
  --bs-accordion-btn-bt: none !important;
  --bs-accordion-btn-bb: none !important;
  display: none;
}

.kpi .accordion-body {
  padding: 0;
}

.kpi .accordion-item {
  --bs-accordion-inner-border-radius: 4px;
  --bs-accordion-btn-bg: var(--bs-kpi-bg);
  --bs-accordion-active-bg: var(--bs-primary70);
  --bs-accordion-active-color: var(--bs-white);
  --bs-accordion-btn-active-icon: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='none' stroke='%23FFFFFF' stroke-linecap='round' stroke-linejoin='round'%3e%3cpath d='M2 5L8 11L14 5'/%3e%3c/svg%3e");
}

.kpi .accordion-item + .accordion-item {
  margin-top: 8px;
}

.kpi .accordion-collapse,
.kpi .accordion-collapse.collapse,
.kpi .accordion-collapse.collapse.show {
  background-color: var(--bs-white) !important;
}

.kpi .accordion .kpi-item {
  background-color: var(--bs-kpi-item-bg);
}

.kpi .accordion .kpi-item + .kpi-item {
  margin-top: 4px;
}

.kpi .accordion .kpi-item:last-child {
  border-radius: 0 0 var(--bs-accordion-inner-border-radius) var(--bs-accordion-inner-border-radius);
}

/* Cookie banner */
.cookie-banner {
  position: fixed;
  right: 8px;
  bottom: 16px;
  left: 8px;
}

.cookie-banner .btn-close {
  width: auto;
  height: auto;
  margin: 0;
  padding: 0;
}

.cookie-banner .cookie-content {
  max-width: 830px;
  border-radius: 8px;
  background-color: var(--bs-white);
  padding: 24px;
  margin: 0 auto;
  box-shadow: 0px 0px 20px rgba(0, 0, 0, 0.15);
}

.cookie-banner .cookie-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-bottom: 16px;
  color: var(--bs-primary);
  border-bottom: 1px solid var(--bs-gray-300);
}

.cookie-banner .cookie-body {
  padding-top: 16px; /*overflow:hidden; overflow-y:auto; max-height:calc(100vh - 400px);*/
}

.cookie-banner .cookie-body .form-group {
  padding: 16px 0;
}

.cookie-banner .cookie-body .form-group .toggle {
  padding-top: 0;
  padding-bottom: 0;
}

.cookie-banner .cookie-body .form-group + .form-group {
  border-top: 1px solid var(--bs-gray-300);
}

.cookie-banner .btn-toolbar {
  padding-top: 16px;
}

.cookie-banner:not(.advanced) .cookie-advanced {
  display: none;
}

.cookie-banner.advanced .btn-toolbar:not(.cookie-advanced) {
  display: none;
}

/* Z-Index */
.page-hero .container-image .image-mask1 {
  z-index: 18;
}

.page-hero .container-image .image-mask2 {
  z-index: 19;
}

.page-hero .container-logged {
  z-index: 20;
}

.menu-desk .search-wrapper .dropdown-menu,
.header-middle .lang-wrapper .dropdown-menu {
  z-index: 900;
}

.header-bottom .nav-item.dropdown > .dd-menu {
  z-index: 1000;
}

.nav-mobile .mobile-wrapper {
  z-index: 1400;
}

.cookie-banner {
  z-index: 1500;
}

/* Responsive */
/* XXL */
@media (max-width: 1399.9px) {
  /* Mobile - Feature */
  .mobile-show-xl {
    display: none;
  }
  /* Header - Middle DropDown Search */
  .menu-desk .search-wrapper.show .form-group {
    width: 230px;
  }
}
/* XL */
@media (max-width: 1199.9px) {
  /* Mobile - Feature */
  .mobile-hidden-xl {
    display: none;
  }
  /* Header */
  .header-bottom .nav-menu > .navbar-nav > .nav-item > .nav-link {
    padding-left: 12px;
    padding-right: 12px;
  }
  .header-bottom .nav-menu > .navbar-nav > .nav-item > .nav-link::after {
    right: 12px;
    left: 12px;
  }
  /* Page Header */
  .page-hero.hero-l1 > .container,
  .page-hero.hero-l2 > .container,
  .page-hero.hero-l1 > .container-fluid,
  .page-hero.hero-l2 > .container-fluid {
    display: block;
  }
  .page-hero.hero-l1 .container-image,
  .page-hero.hero-l2 .container-image {
    display: none;
  }
  /* */
  .page-hero.hero-l1 {
    background-image: url("../imgs/header/hero-mask-mobile-02.svg"), url("../imgs/header/hero-mask-mobile-01.svg");
    background-position: right bottom, left top;
    background-size: 1980px auto;
  }
  .page-hero.hero-l1 .container-hero {
    padding: 32px 24px 56px 0;
  }
  .page-hero.hero-l1 .container-logged {
    padding-right: 32px;
  }
  /* */
  .page-hero.hero-l2 {
    background-image: url("../imgs/header/hero-mask-mobile-01.svg");
    background-position: left top;
    background-size: 1980px auto;
  }
  .page-hero.hero-l2 .container-hero {
    padding: 32px 0 24px 0;
  }
  /* */
  .page-hero.hero-l3 > .container,
  .page-hero.hero-l3 > .container-fluid {
    padding: 24px calc(var(--bs-gutter-x) * 0.5);
  }
  /* */
  .page-hero.hero-l3.hero-small .container {
    padding: 16px calc(var(--bs-gutter-x) * 0.5);
  }
  /* */
  .page-hero .container-logged {
    position: static;
    margin-top: -32px;
    padding-bottom: 56px;
  }
  /* Cotainer Frame */
  .container-frame {
    --bs-frame-info: auto;
    --bs-frame-nav: auto;
    flex-direction: column;
  }
  .container-frame > .frame-info {
    order: 1;
    padding: 0;
  }
  .container-frame > .frame-nav {
    order: 3;
    padding: 0;
  }
  .container-frame > .frame-body {
    order: 2;
    max-width: none;
    padding: 1rem 0 2rem 0;
  }
  /* Sidebar */
  .sidebar > .card {
    background-color: var(--bs-white);
  }
  .sidebar .card-header {
    display: none;
  }
  .sidebar .card-header-mobile {
    display: flex;
  }
  .sidebar .sidebar-scroll {
    height: 0;
    overflow: hidden;
    overflow-y: auto;
    transition: height 0.3s;
  }
  /* Sidebar - Show */
  .sidebar.show .card-header-mobile .dropdown-icon {
    transform: rotate(180deg);
  }
  /* Sidebar Nav */
  .frame-nav .sidebar > .card {
    position: fixed;
    right: 0;
    bottom: 0px;
    left: 0;
    border-radius: 0;
  }
  /* Sidebar Nav - Show */
  .frame-nav .sidebar.show .card-header-mobile {
    color: var(--bs-white);
    background-color: var(--bs-primary80);
  }
  .frame-nav .sidebar.show .card-header-mobile .icon {
    --bs-icon-fill: var(--bs-white);
  }
  .frame-nav .sidebar.show .sidebar-scroll {
    height: calc(100vh - 62px);
  }
  /* Sidebar Info */
  .frame-info .sidebar > .card {
    --bs-card-border-width: 1px;
  }
  .frame-info .sidebar-scroll > .sidebar-list {
    border-top: none;
    padding: 16px;
  }
  /* Sidebar Info - Show */
  .frame-info .sidebar.show .sidebar-scroll {
    height: auto;
  }
  /* KPI - Micro */
  .card.kpi-micro .kpi-content {
    justify-content: start;
  }
  /* Z-Index */
  .frame-nav .sidebar > .card {
    z-index: 1010;
  }
  .frame-nav .sidebar.show > .card {
    z-index: 2000;
  }
}
/* LG */
@media (min-width: 992px) {
  /* Mobile - Feature */
  .mobile-show-lg {
    display: none;
  }
  /* Header */
  header.anim-shrink .container {
    transition: height 0.3s, opacity 0.3s;
  }
  header.shrink .header-top > .container,
  header.shrink .header-middle > .container {
    height: 0;
    overflow: hidden;
    opacity: 0;
  }
  header.shrink .header-bottom > .container {
    height: 60px;
  }
  /* Header - Fixed */
  header.fixed-top + .web-view {
    padding-top: 240px;
  }
  header.fixed-top.header-md + .web-view {
    padding-top: 185px;
  }
  header.fixed-top.header-sm + .web-view {
    padding-top: 80px;
  }
  /* Footer */
  footer .container {
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    justify-content: space-between;
    align-items: center;
  }
  /* Footer - Top */
  .footer-top .footer-contact {
    border-left: 1px solid var(--bs-gray-300);
    padding-left: 24px;
  }
  /* Alert */
  .alert.alert-dismissible .btn-close {
    position: static;
  }
  .alert.alert-dismissible .alert-link {
    padding-right: 32px;
  }
  /* Stepper */
  .stepper-wrapper .step-item::before {
    height: 2px;
    top: calc(var(--bs-step-icon-size) * 0.5);
    right: 0;
    left: calc(var(--bs-step-icon-size) + 13px);
  }
  .stepper-wrapper .step-item + .step-item {
    margin-left: 8px;
  }
  .stepper-wrapper .step {
    padding-bottom: 16px;
  }
}
/* */
@media (max-width: 991.9px) {
  /* Mobile - Feature */
  .mobile-hidden-lg {
    display: none;
  }
  /* Title bar */
  .title-bar {
    display: block;
  }
  .title-bar > :last-child {
    margin-top: 16px;
    margin-right: 0;
  }
  .title-bar .mobile-hidden {
    display: none;
  }
  .title-bar-mobile {
    display: block;
  }
  /* Header */
  header .header-top,
  header .header-bottom,
  .header-middle .navbar-brand .brand-text {
    display: none;
  }
  .header-middle > .container {
    height: 56px;
  }
  .header-middle .navbar-brand {
    height: 28px;
  }
  .header-middle .mobile-handle {
    display: inline-block;
  }
  /* Header - Mobile */
  .header-middle .nav-right.menu-desk {
    display: none;
  }
  .header-middle .nav-right.menu-mobile {
    display: flex;
  }
  header .nav-mobile {
    display: block;
  }
  .menu-show {
    overflow-y: hidden !important;
  }
  .menu-show .nav-mobile .mobile-wrapper {
    left: 0;
  }
  .menu-show header .mobile-handle .hamburger {
    display: none;
  }
  .menu-show header .mobile-handle .menu-close {
    display: block;
  }
  /* Header - Fixed */
  header.fixed-top + .web-view {
    padding-top: 64px;
  }
  /* Footer */
  footer .container {
    display: block;
  }
  footer .nav {
    display: block;
    padding: 16px 0;
  }
  /* Footer - Top */
  .footer-top .nav-item .nav-link {
    padding: 16px 0;
  }
  .footer-top .footer-contact {
    border-top: 1px solid var(--bs-gray-300);
    padding-top: 24px;
  }
  /* Footer - Bottom */
  .footer-bottom .nav-item .nav-link {
    padding: 8px 0;
  }
  /* Alert */
  .alert {
    display: block;
    padding: 8px 16px 8px 56px;
    background-position: 12px 8px;
    background-size: 32px 32px;
    border-left-width: 4px;
  }
  .alert .alert-link {
    justify-content: end;
    padding-top: 16px;
  }
  .alert.alert-dismissible .btn-close {
    top: 8px;
    right: 16px;
    line-height: 0;
  }
  .alert.alert-dismissible .btn-close .icon {
    --bs-icon-size: 24px;
  }
  /* Breadcrumb */
  .breadcrumb-container {
    display: flex;
    align-items: center;
    justify-content: space-between;
    background-color: var(--bs-primary05);
    border-bottom: 1px solid var(--bs-primary30);
    padding: 8px 16px;
  }
  .breadcrumb-container .breadcrumb {
    margin-bottom: 0;
  }
  .breadcrumb-container .link-mobile {
    display: block;
  }
  .breadcrumb-container .breadcrumb-item:not(:last-child):not(.active) {
    display: none;
  }
  .breadcrumb-container .breadcrumb-item::before {
    display: none;
  }
  /* Card */
  .card {
    --bs-card-spacer-x: 16px;
    --bs-card-spacer-y: 16px;
  }
  /* Card - Image side */
  .card.card-img-side .card-img:not(.img-inner) {
    display: none;
  }
  /* Card - Search */
  .form-search {
    --bs-field-space: 16px;
  }
  .form-search .card-filter .card-body {
    flex-direction: column;
  }
  .form-search .filter-list .badge {
    margin-bottom: 8px;
  }
  /* Stepper */
  .stepper-wrapper {
    background-color: var(--bs-primary02);
    padding: 24px 16px;
  }
  .stepper-wrapper .stepper {
    display: none;
    flex-direction: column;
    padding: 24px;
  }
  .stepper-wrapper .step-item {
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    padding-bottom: 40px;
  }
  .stepper-wrapper .step-item::before {
    width: 2px;
    top: calc(var(--bs-step-icon-size) + 24px);
    bottom: 0;
    left: calc(var(--bs-step-icon-size) * 0.5);
  }
  .stepper-wrapper .step {
    padding-top: 12px;
  }
  .stepper-wrapper .step-info {
    padding-left: 12px;
  }
  .stepper-wrapper .stepper-mobile {
    display: flex;
  }
  .stepper-wrapper.show .stepper {
    display: flex;
  }
  .stepper-wrapper.show .stepper-mobile .stepper-title {
    display: block;
  }
  .stepper-wrapper.show .stepper-mobile .step-item {
    display: none;
  }
  /* Tab */
  .nav.nav-tabs {
    --bs-nav-link-padding-y: 8px;
    --bs-nav-link-padding-x: 16px;
  }
  .nav.nav-tabs .nav-link {
    font-size: 1rem;
  }
  .nav.nav-tabs.blue .nav-link::before,
  .nav.nav-tabs.dark .nav-link::before {
    right: 8px;
    bottom: 3px;
    left: 8px;
  }
  /* Carousel */
  .carousel {
    --bs-slider-inner-p: 0px;
  }
  .carousel .carousel-control-prev,
  .carousel .carousel-control-next {
    display: none;
  }
  .carousel .carousel-indicators {
    padding: 8px 0 16px 0;
  }
  .carousel .slider-inner .slider-item:not(.active) {
    opacity: 0.5;
  }
  /* KPI - Micro */
  .card.kpi-micro {
    --bs-card-spacer-y: 8px;
    --bs-card-spacer-x: 8px;
  }
  /* KPI  - Mobile */
  .kpi .nav-tabs {
    display: none;
  }
  .kpi .carousel {
    display: none;
  }
  .kpi .accordion {
    display: block;
  }
  /* Cookie banner */
  .cookie-banner {
    position: absolute;
    bottom: auto;
    top: 64px;
  }
  .cookie-banner .btn-toolbar {
    flex-direction: column-reverse;
  }
  .cookie-banner .btn-close .icon {
    --bs-icon-size: 24px;
  }
}
/* MD */
@media (min-width: 768px) {
  /* Mobile - Feature */
  .mobile-show {
    display: none;
  }
}
/* */
@media (max-width: 767.9px) {
  /* Mobile - Feature */
  .mobile-hidden {
    display: none;
  }
  /* Card - Search */
  .form-search .card-search .v-line {
    --bs-line-padding: 8px;
  }
  /* Modal */
  .modal .modal-content {
    padding: 16px 16px 0px 16px;
  }
  /* Modal - Filters */
  .modal-dialog.dialog-filters {
    --bs-modal-margin: 0;
  }
  .modal-dialog.dialog-filters .modal-header {
    padding: 16px;
    background-color: var(--bs-primary80);
    color: var(--bs-white);
  }
  .modal-dialog.dialog-filters .modal-content {
    padding: 0;
    height: 100vh;
  }
  .modal-dialog.dialog-filters .modal-body {
    padding: 16px 16px 0px 16px;
    max-height: none;
  }
  .modal-dialog.dialog-filters .modal-footer {
    padding: 16px;
  }
  .modal-dialog.dialog-filters .btn-close {
    margin-top: 0;
  }
  .modal-dialog.dialog-filters .btn-close .icon {
    --bs-icon-fill: var(--bs-white);
  }
  /* Cookie banner */
  .btn-toolbar .btn-group-left,
  .btn-toolbar .btn-group-right {
    display: flex;
    flex-direction: row;
    flex-direction: column-reverse;
  }
}
/* SM */
/* */
@media (max-width: 575.9px) {
  /* Header */
  .header-middle > .container {
    padding-right: calc(var(--bs-gutter-x) * 0.5);
    padding-left: calc(var(--bs-gutter-x) * 0.5);
  }
  /* Page Header */
  .page-hero .hero-image .container-hero {
    padding: 1.5rem 1rem 2rem 1rem;
  }
  /* Header - Middle Search Wrapper */
  .menu-mobile .search-wrapper .group-inline {
    flex-wrap: nowrap;
  }
  .menu-mobile .search-wrapper .form-group {
    --bs-form-width: 100%;
  }
}
/* XS */
.user-logged-in .dialog-off-canvas-main-canvas header.navbar {
  padding-top: 80px;
}

#toolbar-administration {
  z-index: 10000;
}

/* Stili per l'header */
header {
  color: #FFFFFF;
}

.site-header {
  background-color: #004990;
  padding: 10px 0;
  color: #fff;
}
.site-header .logo a {
  display: inline-block;
}
.site-header .logo a img {
  max-width: 100%;
  height: auto;
}
.site-header .site-title h1 {
  margin: 0;
  font-size: 1.5rem;
  color: #fff;
}
.site-header .site-title .site-description {
  font-size: 1rem;
  color: #dcdcdc;
}
.site-header .navbar-toggler {
  background-color: #fff;
  border: none;
  padding: 8px 12px;
  border-radius: 4px;
}
.site-header .navbar-toggler .navbar-toggler-icon {
  background-color: #004990;
  display: block;
  width: 30px;
  height: 3px;
  margin: 5px 0;
}

/* Stili responsive per l'header */
@media (max-width: 768px) {
  .site-header .site-title h1 {
    font-size: 1.2rem;
  }
  .site-header .site-description {
    font-size: 0.9rem;
  }
}
/* Admin Toolbar */
.toolbar-horizontal.toolbar-tray-open header {
  top: 80px !important;
}

.toolbar-horizontal header,
.toolbar-vertical header {
  top: 40px !important;
}

/* Gestione del main rispoetto all'header variabile */
.user-login-form .form-control {
  padding: 10px 15px;
}

/* Admin attivo con toolbar attiva */
.toolbar-horizontal.toolbar-tray-open main {
  padding-top: 169px;
  flex: 1;
}

.toolbar-horizontal {
  flex: 1;
}

.toolbar-horizontal .dialog-off-canvas-main-canvas {
  min-height: 100vh; /* Altezza minima pari all'altezza della viewport */
}

/* Admin attivo con toolbar chiusa */
.toolbar-horizontal main,
.toolbar-vertical main {
  padding-top: 169px;
}

/* Admin NON attivo  */
main {
  padding-top: 169px;
}

/* Container */
.container {
  width: 100%;
  margin-right: auto;
  margin-left: auto;
  padding-right: 12px; /* Gutter sm */
  padding-left: 12px; /* Gutter sm */
}

@media (min-width: 576px) {
  .container {
    max-width: 540px;
  }
}
@media (min-width: 768px) {
  .container {
    max-width: 720px;
    padding-right: 24px; /* Gutter md */
    padding-left: 24px; /* Gutter md */
  }
}
@media (min-width: 992px) {
  .container {
    max-width: 960px;
    padding-right: 24px; /* Gutter lg */
    padding-left: 24px; /* Gutter lg */
  }
}
@media (min-width: 1200px) {
  .container {
    max-width: 1184px;
    padding-right: 24px; /* Gutter xl */
    padding-left: 24px; /* Gutter xl */
  }
}
@media (min-width: 1400px) {
  .container {
    max-width: 1316px;
    padding-right: 28px; /* Gutter xxl */
    padding-left: 28px; /* Gutter xxl */
  }
}
/* Row */
.row {
  display: flex;
  flex-wrap: wrap;
  margin-right: -12px;
  margin-left: -12px;
}

@media (min-width: 768px) {
  .row {
    margin-right: -24px; /* Gutter md */
    margin-left: -24px; /* Gutter md */
  }
}
@media (min-width: 1400px) {
  .row {
    margin-right: -28px; /* Gutter xxl */
    margin-left: -28px; /* Gutter xxl */
  }
}
/* Column */
.col {
  position: relative;
  width: 100%;
  padding-right: 12px;
  padding-left: 12px;
}

@media (min-width: 768px) {
  .col {
    padding-right: 24px; /* Gutter md */
    padding-left: 24px; /* Gutter md */
  }
}
@media (min-width: 1400px) {
  .col {
    padding-right: 28px; /* Gutter xxl */
    padding-left: 28px; /* Gutter xxl */
  }
}
/* Column Sizes */
.col-1 {
  flex: 0 0 8.33333%;
  max-width: 8.33333%;
}

.col-2 {
  flex: 0 0 16.66667%;
  max-width: 16.66667%;
}

.col-3 {
  flex: 0 0 25%;
  max-width: 25%;
}

.col-4 {
  flex: 0 0 33.33333%;
  max-width: 33.33333%;
}

.col-5 {
  flex: 0 0 41.66667%;
  max-width: 41.66667%;
}

.col-6 {
  flex: 0 0 50%;
  max-width: 50%;
}

.col-7 {
  flex: 0 0 58.33333%;
  max-width: 58.33333%;
}

.col-8 {
  flex: 0 0 66.66667%;
  max-width: 66.66667%;
}

.col-9 {
  flex: 0 0 75%;
  max-width: 75%;
}

.col-10 {
  flex: 0 0 83.33333%;
  max-width: 83.33333%;
}

.col-11 {
  flex: 0 0 91.66667%;
  max-width: 91.66667%;
}

.col-12 {
  flex: 0 0 100%;
  max-width: 100%;
}

/* Responsive Column Sizes */
@media (min-width: 576px) {
  .col-sm-1 {
    flex: 0 0 8.33333%;
    max-width: 8.33333%;
  }
  .col-sm-2 {
    flex: 0 0 16.66667%;
    max-width: 16.66667%;
  }
  .col-sm-3 {
    flex: 0 0 25%;
    max-width: 25%;
  }
  .col-sm-4 {
    flex: 0 0 33.33333%;
    max-width: 33.33333%;
  }
  .col-sm-5 {
    flex: 0 0 41.66667%;
    max-width: 41.66667%;
  }
  .col-sm-6 {
    flex: 0 0 50%;
    max-width: 50%;
  }
  .col-sm-7 {
    flex: 0 0 58.33333%;
    max-width: 58.33333%;
  }
  .col-sm-8 {
    flex: 0 0 66.66667%;
    max-width: 66.66667%;
  }
  .col-sm-9 {
    flex: 0 0 75%;
    max-width: 75%;
  }
  .col-sm-10 {
    flex: 0 0 83.33333%;
    max-width: 83.33333%;
  }
  .col-sm-11 {
    flex: 0 0 91.66667%;
    max-width: 91.66667%;
  }
  .col-sm-12 {
    flex: 0 0 100%;
    max-width: 100%;
  }
}
@media (min-width: 768px) {
  .col-md-1 {
    flex: 0 0 8.33333%;
    max-width: 8.33333%;
  }
  .col-md-2 {
    flex: 0 0 16.66667%;
    max-width: 16.66667%;
  }
  .col-md-3 {
    flex: 0 0 25%;
    max-width: 25%;
  }
  .col-md-4 {
    flex: 0 0 33.33333%;
    max-width: 33.33333%;
  }
  .col-md-5 {
    flex: 0 0 41.66667%;
    max-width: 41.66667%;
  }
  .col-md-6 {
    flex: 0 0 50%;
    max-width: 50%;
  }
  .col-md-7 {
    flex: 0 0 58.33333%;
    max-width: 58.33333%;
  }
  .col-md-8 {
    flex: 0 0 66.66667%;
    max-width: 66.66667%;
  }
  .col-md-9 {
    flex: 0 0 75%;
    max-width: 75%;
  }
  .col-md-10 {
    flex: 0 0 83.33333%;
    max-width: 83.33333%;
  }
  .col-md-11 {
    flex: 0 0 91.66667%;
    max-width: 91.66667%;
  }
  .col-md-12 {
    flex: 0 0 100%;
    max-width: 100%;
  }
}
@media (min-width: 992px) {
  .col-lg-1 {
    flex: 0 0 8.33333%;
    max-width: 8.33333%;
  }
  .col-lg-2 {
    flex: 0 0 16.66667%;
    max-width: 16.66667%;
  }
  .col-lg-3 {
    flex: 0 0 25%;
    max-width: 25%;
  }
  .col-lg-4 {
    flex: 0 0 33.33333%;
    max-width: 33.33333%;
  }
  .col-lg-5 {
    flex: 0 0 41.66667%;
    max-width: 41.66667%;
  }
  .col-lg-6 {
    flex: 0 0 50%;
    max-width: 50%;
  }
  .col-lg-7 {
    flex: 0 0 58.33333%;
    max-width: 58.33333%;
  }
  .col-lg-8 {
    flex: 0 0 66.66667%;
    max-width: 66.66667%;
  }
  .col-lg-9 {
    flex: 0 0 75%;
    max-width: 75%;
  }
  .col-lg-10 {
    flex: 0 0 83.33333%;
    max-width: 83.33333%;
  }
  .col-lg-11 {
    flex: 0 0 91.66667%;
    max-width: 91.66667%;
  }
  .col-lg-12 {
    flex: 0 0 100%;
    max-width: 100%;
  }
}
@media (min-width: 1200px) {
  .col-xl-1 {
    flex: 0 0 8.33333%;
    max-width: 8.33333%;
  }
  .col-xl-2 {
    flex: 0 0 16.66667%;
    max-width: 16.66667%;
  }
  .col-xl-3 {
    flex: 0 0 25%;
    max-width: 25%;
  }
  .col-xl-4 {
    flex: 0 0 33.33333%;
    max-width: 33.33333%;
  }
  .col-xl-5 {
    flex: 0 0 41.66667%;
    max-width: 41.66667%;
  }
  .col-xl-6 {
    flex: 0 0 50%;
    max-width: 50%;
  }
  .col-xl-7 {
    flex: 0 0 58.33333%;
    max-width: 58.33333%;
  }
  .col-xl-8 {
    flex: 0 0 66.66667%;
    max-width: 66.66667%;
  }
  .col-xl-9 {
    flex: 0 0 75%;
    max-width: 75%;
  }
  .col-xl-10 {
    flex: 0 0 83.33333%;
    max-width: 83.33333%;
  }
  .col-xl-11 {
    flex: 0 0 91.66667%;
    max-width: 91.66667%;
  }
  .col-xl-12 {
    flex: 0 0 100%;
    max-width: 100%;
  }
}
@media (min-width: 1400px) {
  .col-xxl-1 {
    flex: 0 0 8.33333%;
    max-width: 8.33333%;
  }
  .col-xxl-2 {
    flex: 0 0 16.66667%;
    max-width: 16.66667%;
  }
  .col-xxl-3 {
    flex: 0 0 25%;
    max-width: 25%;
  }
  .col-xxl-4 {
    flex: 0 0 33.33333%;
    max-width: 33.33333%;
  }
  .col-xxl-5 {
    flex: 0 0 41.66667%;
    max-width: 41.66667%;
  }
  .col-xxl-6 {
    flex: 0 0 50%;
    max-width: 50%;
  }
  .col-xxl-7 {
    flex: 0 0 58.33333%;
    max-width: 58.33333%;
  }
  .col-xxl-8 {
    flex: 0 0 66.66667%;
    max-width: 66.66667%;
  }
  .col-xxl-9 {
    flex: 0 0 75%;
    max-width: 75%;
  }
  .col-xxl-10 {
    flex: 0 0 83.33333%;
    max-width: 83.33333%;
  }
  .col-xxl-11 {
    flex: 0 0 91.66667%;
    max-width: 91.66667%;
  }
  .col-xxl-12 {
    flex: 0 0 100%;
    max-width: 100%;
  }
}
/*
@media (min-width: 1440px) {
  .container {
    max-width: 1316px;
    margin-left: auto;
    margin-right: auto;
  }

  .row {
    display: flex;
    flex-wrap: wrap;
    margin-right: -28px;
    margin-left: -28px;
  }

  .col {
    flex: 0 0 auto;
    width: 100%;
    max-width: calc((100% - (11 * 28px)) / 12);
    padding-right: 28px;
    padding-left: 28px;
  }
}

// Regole per Mobile (XS)
/*
@media (max-width: 575.98px) {
  .container {
    max-width: 342px;
    margin-left: auto;
    margin-right: auto;
  }

  .row {
    display: flex;
    flex-wrap: wrap;
    margin-right: -12px;
    margin-left: -12px;
  }

  .col {
    flex: 0 0 auto;
    width: 100%;
    max-width: calc((100% - (5 * 12px)) / 6);
    padding-right: 12px;
    padding-left: 12px;
  }
}

// Layout Desktop (max-width 1440px)
@media (min-width: 1440px) {
  .page-wrapper {
    max-width: 1440px;
    margin: 0 auto;
  }
}


*/
header {
  padding-top: 0px !important;
}
header .navTitle {
  font-size: 1.25rem;
  font-weight: 600;
  line-height: 1rem;
}
header .navSub {
  font-size: 0.875rem;
  font-weight: 600;
  line-height: 1.375rem;
}

.contentinfo {
  padding: 0px !important;
}

footer {
  padding: 0px !important;
}
footer .ps-1 {
  display: ruby;
}
footer .footer-link {
  width: 100%;
}
footer .footer-link .nav-link {
  text-decoration: none !important;
}
footer .navbar-brand img {
  width: 280px !important;
}

.nav-mobile {
  display: none; /* Nascondi il menu mobile per impostazione predefinita */
}

@media (max-width: 768px) {
  .nav-mobile.menu-open {
    display: block; /* Mostra il menu su dispositivi mobili */
    position: fixed; /* Mantieni fisso il menu mobile in alto */
    top: 0;
    left: 0;
    width: 100%;
    background-color: white;
    z-index: 1000; /* Assicurati che il menu mobile sia in primo piano */
  }
}
.book-card .disabled-card {
  pointer-events: none; /* Disabilita l'interattività */
  opacity: 0.5;
}
.book-card .card:hover {
  background: #0a6eb4;
  color: #fff;
}
.book-card .card.active {
  background: #143467;
  color: #fff;
}
.book-card .card .badge {
  height: 2rem;
  text-align: center !important;
}
.book-card .card .badge span {
  font-size: 1rem;
  font-weight: 600;
  line-height: 1.3rem;
}

main {
  padding-top: 40px !important;
}

.custom-prev.disabled, .custom-next.disabled {
  opacity: 0.5 !important;
}

.custom-prev, .custom-next {
  cursor: pointer;
}

.page-404 {
  min-height: 60vh;
  padding-top: 40px;
  padding-bottom: 40px;
}
@media (max-width: 768px) {
  .page-404 button {
    margin-top: 40px;
  }
}

#owl-gallery .owl-dots {
  display: none !important;
}

.text-primary {
  color: #2156AB !important;
}
.text-primary .bg-primary {
  background-color: #2156AB !important;
}

h1 {
  font-family: "Titillium Web", sans-serif;
  font-size: 2.5rem;
  font-weight: 700;
  line-height: 3.25rem;
  text-align: left;
  color: #2156AB;
  padding-top: 1rem;
  padding-bottom: 1rem;
}
@media (max-width: 768px) {
  h1 {
    font-size: 1.5rem;
    line-height: 1.95rem;
    font-weight: 700;
  }
}

h5 {
  font-family: "Titillium Web", sans-serif;
  font-size: 1.25rem;
  font-weight: 400;
  line-height: 1.625rem;
  text-align: left;
}

h6 {
  font-family: "Titillium Web", sans-serif;
  font-size: 1.125rem;
  font-weight: 400;
  font-weight: 400;
  line-height: 1.4625rem;
  text-align: left;
}

p {
  font-family: "Titillium Web", sans-serif;
  font-size: 1.125rem;
  font-weight: 400;
  line-height: 1.4625rem;
  text-align: left;
}

.asterisco {
  font-size: 0.75rem !important;
  font-weight: 400 !important;
  line-height: 0.975rem !important;
}

semib {
  font-weight: 600 !important;
}

endata {
  color: #2156AB;
}

#fromReservation h1 {
  font-family: "Titillium Web", sans-serif;
  font-size: 2.5rem;
  font-weight: 700;
  line-height: 3.25rem;
  text-align: left;
  color: #2156AB;
}

.hero-section h1 {
  font-family: "Titillium Web", sans-serif;
  font-size: 2.5rem;
  font-weight: 400;
  line-height: 3.25rem;
  text-align: left;
  color: #fff;
}
@media (max-width: 768px) {
  .hero-section h1 {
    font-family: "Titillium Web", sans-serif;
    font-size: 1.5rem;
    font-weight: 400;
    line-height: 1.95rem;
    text-align: left;
    color: #fff;
  }
}
.hero-section h2 {
  font-family: "Titillium Web", sans-serif;
  font-size: 2rem;
  line-height: 2.6rem;
  text-align: left;
  color: #fff;
}
@media (max-width: 768px) {
  .hero-section h2 {
    font-family: "Titillium Web", sans-serif;
    font-size: 1.25rem;
    font-weight: 400;
    line-height: 1.625rem;
    text-align: left;
    color: #fff;
  }
}

.call-action {
  background: #F6F9FD;
}

note {
  font-family: "Titillium Web", sans-serif;
  font-size: 0.75rem;
  font-weight: 400;
  line-height: 0.975rem;
  text-align: left;
}

/* Buttons */
.btn-primary {
  padding: 1rem 2rem 1rem 2rem;
  gap: 0.5px;
  border-radius: 0.375rem;
  opacity: 0rem;
  background: #2156AB;
}

.text-primary {
  color: #2156AB;
  font-weight: 700;
  font-size: 1rem;
}

.iframe-container {
  position: relative;
  width: 100%;
  height: 70vh;
}
.iframe-container iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border: 0;
}

.iframe-container.room {
  position: relative;
  width: 100%;
  height: 60vh;
}
.iframe-container.room iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border: 0;
}

.hero-section {
  background-image: url("https://www.openhouseroma.org/sites/default/files/styles/hpbanner/public/%C2%A9%20Masterline%20Italy%20Roma%2005.jpg");
  background-size: cover;
  background-position: center;
  position: relative;
  min-height: 700px;
}
.hero-section .overlay {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: rgba(0, 0, 0, 0.5);
  z-index: 1;
}
.hero-section .container {
  position: relative;
  bottom: -110px;
}
.hero-section .container .content {
  position: relative;
  z-index: 2;
  color: #fff; /* Colore bianco per il testo */
}

.info-section {
  position: relative;
  bottom: 0;
  width: 100%;
  padding: 1.25rem;
  z-index: 1;
}
.info-section .owl-item .info-box {
  padding: 5px;
  padding-top: 0.625rem;
  border-top: 0.125px solid #fff;
}
.info-section .owl-item .info-box:hover {
  border-top: 0.125px solid #2156AB;
  color: #2156AB;
}
.info-section .owl-item .info-box:hover a {
  color: #2156AB;
}
.info-section .owl-item .info-box h6 {
  font-family: "Titillium Web", sans-serif;
  font-size: 1.125rem;
  line-height: 1.462rem;
  text-align: left;
}
.info-section .owl-item .info-box a {
  font-family: "Titillium Web", sans-serif;
  font-size: 1.125rem;
  line-height: 1.462rem;
  text-align: left;
  font-weight: 700;
  color: #fff;
  text-decoration: none;
}
.info-section .owl-item:hover {
  background-color: #fff;
  opacity: 0.6;
}
.info-section #prevSlide .icon use {
  color: #fff !important;
}

.intestazione {
  background: #0D2244;
  color: #fff;
  padding-top: 28px;
}
.intestazione h1 {
  font-family: "Titillium Web", sans-serif;
  font-size: 2.5rem;
  font-weight: 700;
  line-height: 3.25rem;
  text-align: left;
  color: #fff;
}
@media (max-width: 768px) {
  .intestazione h1 {
    font-family: "Titillium Web", sans-serif;
    font-size: 2rem;
    font-weight: 700;
    line-height: 2.6rem;
    text-align: left;
    color: #fff;
  }
}
.intestazione h2 {
  font-family: "Titillium Web", sans-serif;
  font-size: 1.125rem;
  font-weight: 400;
  line-height: 1.4625rem;
  text-align: left;
  color: #fff;
}
@media (max-width: 768px) {
  .intestazione h2 {
    font-family: "Titillium Web", sans-serif;
    font-size: 1rem;
    font-weight: 400;
    line-height: 1.3rem;
    text-align: left;
    color: #fff;
  }
}

.stanze .intestazione {
  background: #0D2244;
  color: #fff;
}
.stanze .intestazione h1 {
  font-family: "Titillium Web", sans-serif;
  font-size: 2.5rem;
  font-weight: 700;
  line-height: 3.25rem;
  text-align: left;
  color: #fff;
}
@media (max-width: 768px) {
  .stanze .intestazione h1 {
    font-family: "Titillium Web", sans-serif;
    font-size: 2rem;
    font-weight: 700;
    line-height: 2.6rem;
    text-align: left;
    color: #fff;
  }
}
.stanze .intestazione h5 {
  font-family: "Titillium Web", sans-serif;
  font-size: 1.125rem;
  font-weight: 400;
  line-height: 1.4625rem;
  text-align: left;
  color: #fff;
}
@media (max-width: 768px) {
  .stanze .intestazione h5 {
    font-family: "Titillium Web", sans-serif;
    font-size: 1rem;
    font-weight: 400;
    line-height: 1.3rem;
    text-align: left;
    color: #fff;
  }
}
.stanze .owl-nav {
  display: none !important;
}

.rooms .carousel-item h5 {
  font-size: 1.25rem;
  font-weight: 600;
  line-height: 1.625rem;
  text-align: left;
  color: #2156AB;
}

.slider-item .card-title span {
  font-size: 1.25rem;
  font-weight: 600;
  line-height: 1.625rem;
  text-align: left;
  color: #2156AB;
}

.collapse {
  display: none;
}

.collapse.show {
  display: block;
  transition: max-height 0.5s ease-in-out;
}

.accordion-item .text-primary {
  font-weight: 600 !important;
}
.accordion-item .accordion-collapse {
  padding-left: 2.3rem;
}
.accordion-item p {
  font-size: 1rem;
  font-weight: 400;
  line-height: 1.3rem;
  text-align: left;
}

.image-caption {
  background-color: #CCDCF5;
  color: #000 !important;
}

.cropped-image {
  width: 100%;
  height: 258px;
  object-fit: cover; /* Ensures the image fills the container while keeping aspect ratio */
}

.card-home {
  min-height: 10rem !important;
}
.card-home .text-cotainer {
  height: 3rem !important;
}

.owl-dots {
  display: none !important;
}

.thank-you {
  font-size: 2.3rem;
  font-weight: 700;
  line-height: 3.25rem;
}

.dd-menu.show {
  opacity: 1 !important;
  top: 100% !important;
}

.region {
  padding: 0px !important;
}
@media (max-width: 728px) {
  button.btn.btn-link {
    text-decoration: none;
  }
  .d-sm-none {
    display: none;
  }
  .navSub {
    display: none;
  }
  .header-middle .navbar-brand {
    height: 25px;
    display: flex;
    flex-direction: column;
    margin-top: -16px;
    align-items: baseline;
  }
  .header-middle > .container {
    height: 80px !important;
  }
  header .navTitle {
    font-size: 1rem;
    font-weight: 600;
    line-height: 1rem;
    margin-top: 5px;
  }
  .menu {
    font-family: Titillium Web;
    font-size: 20px;
    font-weight: 600;
    line-height: 26px;
    text-align: left;
    color: #FFF;
    padding-bottom: 16px;
  }
  a.portale {
    padding-left: 0px !important;
  }
  .nav-link {
    font-family: Titillium Web;
    font-size: 16px;
    font-weight: 600;
    line-height: 20.8px;
    text-align: left;
    text-decoration: none !important;
  }
  .navbar-nav {
    color: white;
  }
  .nav-link {
    color: white;
    padding-bottom: 8px;
    display: flex;
    justify-content: space-between;
    align-items: center;
  }
  .dropdown .dropdown-content {
    display: none;
    background: rgba(229, 237, 250, 0.2);
    position: relative;
    list-style-type: none;
    padding: 0;
    border-radius: 4px;
    margin: 0;
    max-height: 324px;
  }
  .dropdown-content .nav-item {
    font-family: Titillium Web;
    font-size: 16px;
    font-weight: 400;
    line-height: 20.8px;
    text-align: left;
  }
  .dropdown-arrow {
    margin-left: auto;
    font-size: 12px;
  }
  /* Stili per le frecce nel dropdown */
  .dropdown-content .nav-link i {
    margin-left: auto;
    font-size: 10px;
  }
  .dropdown-content .nav-link {
    color: white;
    padding: 8px;
    display: flex;
    justify-content: space-between;
  }
  .icon-circle {
    background-color: #0a3c8a;
    border-radius: 50%;
    padding: 5px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 20px;
    height: 20px;
  }
  .icon-circle .bi {
    color: white; /* Colore bianco per la freccia */
    font-size: 16px; /* Dimensione della freccia */
  }
  /* Hover effect per ciascun link nel dropdown */
  .dropdown-content .nav-link:hover {
    background-color: #0a3c8a;
  }
  .mobile-line {
    background-color: #6595E1;
  }
}
.mobile-wrapper {
  padding: 16px;
}

.dropdown-content {
  display: none;
  padding-left: 15px;
}

.dropdown-content a {
  display: block;
}

/* Mostra il menu quando attivato */
.show-menu {
  display: block;
}

.mobile-open {
  left: 0px !important;
}

.nav-mobile {
  display: none;
}

.nav-mobile {
  display: block;
}

/* Stile specifico per dispositivi mobili */
@media (max-width: 768px) {
  .navbar-nav {
    flex-direction: column;
  }
  .dropdown .dropdown-content {
    position: relative; /* Mantiene i dropdown ancorati all'elemento padre */
    width: 100%;
  }
  .dropdown-content .nav-item {
    width: 100%;
  }
}
/* tablet */
@media (max-width: 998px) {
  .palazzo {
    width: 99%;
  }
  .d-sm-none {
    display: none;
  }
  .navSub {
    display: none;
  }
  .header-middle .navbar-brand {
    height: 25px;
    display: flex;
    flex-direction: column;
    margin-top: -16px;
    align-items: baseline;
  }
  /* Stili per le frecce nel dropdown */
  /* Hover effect per ciascun link nel dropdown */
}
@media (max-width: 998px) and (max-width: 768px) {
  .header-middle .navbar-brand .navTitle {
    padding-top: 10px;
  }
}
@media (max-width: 998px) {
  .header-middle > .container {
    height: 80px !important;
  }
  header .navTitle {
    font-size: 1rem;
    font-weight: 600;
    line-height: 1rem;
    margin-top: 5px;
  }
  .menu {
    font-family: Titillium Web;
    font-size: 20px;
    font-weight: 600;
    line-height: 26px;
    text-align: left;
    color: #FFF;
    padding-bottom: 16px;
  }
  a.portale {
    padding-left: 0px !important;
  }
  .nav-link {
    font-family: Titillium Web;
    font-size: 16px;
    font-weight: 600;
    line-height: 20.8px;
    text-align: left;
  }
  .navbar-nav {
    color: white;
  }
  .nav-link {
    color: white;
    padding-bottom: 8px;
    display: flex;
    justify-content: space-between;
    align-items: center;
  }
  .dropdown .dropdown-content {
    display: none;
    background: rgba(229, 237, 250, 0.2);
    position: relative;
    list-style-type: none;
    padding: 0;
    border-radius: 4px;
    margin: 0;
    max-height: 324px;
  }
  .dropdown-content .nav-item {
    font-family: Titillium Web;
    font-size: 16px;
    font-weight: 400;
    line-height: 20.8px;
    text-align: left;
  }
  .lang-wrapper .lang-toggle.show .icon {
    transform: rotate(180deg);
  }
  .dropdown-arrow {
    margin-left: auto;
    font-size: 12px;
  }
  .dropdown-content .nav-link i {
    margin-left: auto;
    font-size: 10px;
  }
  .dropdown-content .nav-link {
    color: white;
    padding: 8px;
    display: flex;
    justify-content: space-between;
  }
  .icon-circle {
    background-color: #0a3c8a;
    border-radius: 50%;
    padding: 5px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 20px;
    height: 20px;
  }
  .icon-circle .bi {
    color: white;
    font-size: 16px;
  }
  .dropdown-content .nav-link:hover {
    background-color: #3271D7;
  }
  .mobile-line {
    background-color: #6595E1;
    height: 2px;
    width: 100%;
    margin: 10px 0;
  }
}
i.bi.bi-chevron-right {
  font-size: 20px;
  width: 20px;
  height: 20px;
  color: white;
}

.icon-circle > i.bi.bi-chevron-right {
  font-size: 13px;
}

.rotate {
  transform: rotate(180deg);
  transition: transform 0.3s ease;
}

.masaf-link a {
  font-family: Titillium Web;
  font-size: 16px;
  font-weight: 600;
  line-height: 20.8px;
  text-align: center;
  padding-right: 5px;
  text-decoration: none !important;
}

.palazzo {
  width: 98%;
}

button:focus,
a:not(:active):focus {
  box-shadow: none !important;
  outline: none !important;
}

.accordion {
  --bs-accordion-color: none !important;
}

.room-gallery .slider-inner .slider-item {
  max-width: 72%;
  margin: auto;
}

.pt-20 {
  padding-top: 20rem;
}

@media (max-width: 900px) {
  .mobile-padding {
    padding-top: 1rem;
  }
}
.user-pass {
  margin-top: 6rem;
  padding: 2rem;
}

/** Fix gallery image resize */
.image-container {
  position: relative;
  width: 100%;
  padding-top: 56.25%; /* 16:9 aspect ratio */
  overflow: hidden;
  background: #f8f9fa; /* Optional: Placeholder background */
}
.image-container img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: contain; /* Ensures the image covers the container */
}

#roomNodesCarousel .owl-item .card {
  box-shadow: 1px 0px 3px rgba(0, 0, 0, 0.1);
}
#roomNodesCarousel .owl-item .card img {
  height: 8rem;
  object-fit: cover;
}
@media (min-width: 900px) {
  #roomNodesCarousel {
    width: 80%;
    position: relative;
    left: 7rem;
  }
}

/*# sourceMappingURL=style.css.map */
