

html, body {
  width: 100%;
  max-width: 100%;
  
}
body {
  font-family: "Roboto", sans-serif;
  line-height: 1.5;
}


/* headings */

h1, h2, h3, h4, h5 {
  font-weight: 700;
}

  
.h1,
h1 {
  font-size: 2.2rem;
}

.section-container h1, .section-container h2 {
  text-align: center;
}


form h2 {
  margin-bottom: 0;
}



.h3,
h3 {
  font-size: 1.45rem;
}

.h4,
h4 {
  font-size: 1.25rem;
  margin-bottom: 1rem;
}

h5 {
  font-size: 1rem;
}




h6 {
  text-transform: uppercase;
  font-size: smaller;
}

a {
  cursor: pointer;
}

a.in-progress, button.in-progress {
  cursor: progress;
}

  .small, small {
    font-size: 90%;
  }

option {
  font-family: "Segoe UI", sans-serif;
}

img, figure {
    max-width: 100%;
    height: auto;
    vertical-align: middle;
    margin:0;
}      



/************************* SCROLLBAR ***************************/
::-webkit-scrollbar {
  height: 6px;
  width: 6px;
  background: transparent;
}

::-webkit-scrollbar-thumb {
  background: #c8d0db;
  -webkit-border-radius: 1ex;
  /* // -webkit-box-shadow: 0px 1px 2px rgba(0, 0, 0, 0.75); */
}

::-webkit-scrollbar-corner {
  /* // background: #000; */
}










.overflow-y-scroll {
  height:100vh;
  scroll-behavior: smooth;
  overflow-y: scroll;
  scroll-padding-top: 8rem;
}
@media screen and (min-width: 768px) {
  .full-height-scrollable-y {
    height: 100vh;
    overflow-y: scroll;
    overflow-x:hidden;
  }

  .full-height-overflow-hidden {
    height: 100vh;
    overflow: hidden;
  }

  .overflow-y-scroll {
  scroll-padding-top: 1rem;
  }
}




  a.in-progress {
    cursor: progress;
  }
  
  button.in-progress {
    cursor: progress;
  }

/*///////////////////////// LAYOUT //////////////////////////////*/
 
  .main-content {
    min-height: 100vh;
  }


    #contents,.sidebar {
  
  height: 100vh;
  overflow-y: scroll;
  }

 @media only screen and (max-width: 768px) {
  #contents,.sidebar {
    
    z-index: 500;
    padding-top: 8rem;
    position: fixed;
    width: 100vw;
    height: 100vh;
    overflow: scroll;

  }
 }
  





/* ///
////////////////////////////
//////////////////////////////////// FORM ///////////////////// */

  
label {
  position: relative;
  font-weight: 400;
  line-height: 1.5;
  margin-bottom: 0.5rem;
}

  label.required:after {
    content: "*";
    color: red;
  }
  label.include-vc-tutorial {
  padding-bottom: 2rem;
}

  
 
  
  .btn {
    color: white;
    border-style: solid;
    border-width: 1px;
    outline: none;
    box-shadow: none !important;
    background-color: transparent;
  }
  
  .btn:hover, .btn:focus, .btn:active, .btn.active {
    box-shadow: none;
    outline: none;
  }
  
  .btn:hover, .btn:focus, .btn:active {
    box-shadow: none;
    outline: none;
  }
  
  .invalid-feedback {
    display: block;
  }
  
  .dayBox {
    transition-duration: 800ms;
    .span {
      display: block;
    }
  }
  
  .unselected:hover {
    .cal_option_bullet {
      opacity: 1;
    }
  }
  .selected {
    .cal_option_bullet {
      transform: scale(1.3);
      transition-duration: 300ms;
    }
  }




.blockquote {
  font-size: 1.1rem;
  text-align: center;
  border: 0;
  line-height: 1.5;
  font-style: italic;
}
.questionmark,
.btn-vc-tutorial {
  padding: 1px 12px;
  margin-bottom: 0.5rem;
  margin-top: -.5rem;
}
.btn-vc-tutorial {
  bottom: 0;
}


  
  .inline-guidance {
    font-style: italic;
    line-height: 1.5;
    margin: 1rem 0 1.2rem 0;
    background-image: url("/common/assets/img/VC/VC-icon.png");
    background-size: 5.5rem auto;
    background-repeat: no-repeat;
    background-position-y: 5px;
    padding-left: 8rem;
    min-height: 6.6rem;
    max-width: 60rem;
    transition: ease-in-out;
  }

  .tutorial-body h2 {
  margin-bottom: 1rem;
}

  
  .charsLeft {
    margin-top: .2rem;
    text-align: right;
  }
  
  img.checked {
    opacity: 1;
  }
  
  img.unchecked {
    opacity: 0.5;
  }
  
  .checkbox {
    margin-left: 1rem;
  }

  .checkbox-icon {
    width:3rem;
  }

  
  
.checkbox label {
    font-weight: normal;
    padding-right: 0;
    width: auto;
  }
  
  select.form-control {
    -webkit-appearance: menulist;
  }
  
  .checkbox-container.form-control {
    height: auto;
  }
  
  .form-control.traveller-checkbox-list {
    display: flex;
    padding-top: .2rem;
  }
  
  .traveller-checkbox-list .formCheck {
    margin-left: 0;
    margin-top: 1rem;
    margin-bottom: 1rem;
  }
  
  .traveller-icon {
    display: block;
    margin: 0 auto 10px auto;
    height: 80px;
    width: 80px;
    opacity: .5;
  }
  
  .control:not(.hidden) {
    margin-top: 1rem;
    padding:1rem;
    position:relative;
  }

  .btn-preview {
  display:none;  
  position: absolute;
  right: 0;
  
}

.btn-preview::before {
  transition-duration: 500ms; /* Durata della transizione solo per ::before */
}
.btn-preview:hover::before {
    content: "Preview ";
    transform: translateX(-50%);
    color: #fff;    
    white-space: nowrap;
}


  body.preview-enabled .control.see-preview:hover .btn-see-preview {
    display: block;
  }

  .form-group > .form-group {
    margin-bottom: 0;
  }
  
  .form-control.is-invalid {
    padding-right: 0;
    background-position: top calc(.375em + .1875rem) right calc(.375em + .1875rem);
  }
  
  .validation-message-icon {
    font-size: 115%;
    margin-right: .5rem;
  }
  
  .list-group {
    margin: 0;
  }
  
  .sa-button-container {
    margin-top: 1rem;
    margin-bottom: 3rem;
  }
  

  
  .gallery-item {
    float: left;
  }
  
  .gallery-list-group {
    display: block;
  }
  
  
  /* .btn.draggable:not(:disabled):not(.disabled) {
    cursor: move !important;
  } */
  
  .draggable{
    padding-left:3rem;
  z-index: 450;
  cursor: move;
}



  .draggable:before {
    position: absolute;
    font-family: 'FontAwesome';
    top: .8rem;
    left: 1rem;
    content: "\f338";
  }
  
  
  
  .add-item-icon{
    margin:.5rem 1.2rem;
  }


  .distance_slider {
    padding-right: 1.5rem;
  }
  
/******************************************** PHOTOGALLERY *************************************/

.custom-control-input{
  position:absolute;
  margin:.1rem;
  
} 
.custom-control-input:checked{
  z-index:8000;
}


.img-checkbox.img-checked {
  scale:0.8;
}



iframe {
  border: 0;
}




 /* datetimepicker */
  
  .bootstrap-datetimepicker-widget table td, .bootstrap-datetimepicker-widget table th {
    border: 0;
  }
  
  .bootstrap-datetimepicker-widget table tr:nth-child(2) th {
    font-size: smaller;
  }
  
/* Alert */
  
  #iaagtAlertGraphic {
    font-size: 8rem;
    font-weight: lighter;
  }
  
  .stars {
    background-image: url(https://assets.iamagoodtraveller.com/img/VC/VC-alert-header.svg), url(https://assets.iamagoodtraveller.com/img/VC/VC-alert-footer.svg);
    background-size: 92% auto, 102% auto;
    background-repeat: no-repeat;
    background-position: 50% 10%, bottom;
  }
  
 
  
  .validation {
    margin-top: 10px;
  }
  
  .main-content {
    padding: 0 6%;
  }
  
  .traveller-checkbox-list label {
    width: 100%;
    margin: 0 auto;
    display: block;
  }
  
  .form-control {
    color: #1a1a1a;
    background-color: #fff;
    background-image: none;
    border: 0.8px solid #c8d1dd;
    border-radius: 5px;
    transition: none;
  
  }
  
  .form-control.checkbox-container {
    border-color: transparent;
    background-color: transparent;
  }
  
  .form-control.is-invalid {
    border-color: red !important;
  }
  
  .form-control-number {
    width: 50% !important;
  }
  
  .form-control, .input-group .form-control, .input-group-addon {
    border: 0.8px solid #c8d1dd;
    border-radius: 5px;
  }

  .form-control-list {
  background-color: #fff;
  background-image: none;
  border: 0.8px solid #c8d1dd;
  border-radius: 5px;
  margin-top: 5px;
  margin-bottom: 10px;
  transition: none;
  cursor: move;
}

.dropdown-header {
  font-weight: 700;
}

  
  .checkbox, .radio {
    margin: 0;
  }
  
  input[type="checkbox"], input[type="radio"] {
    margin-right: 15px;
  }


.img-check-control input:disabled {
  pointer-events: none; /* Disabilita gli eventi del mouse */
}

.img-check-control input:disabled + label {
  opacity: 0.5; /* Opacità ridotta per l'etichetta quando l'input è disabilitato */
}

/* Disabilita gli effetti di hover quando l'input è disabilitato */
.img-check-control input:disabled:hover,
.img-check-control input:disabled + label:hover {
  /* Puoi lasciare vuoto o aggiungere ulteriori proprietà se vuoi modificare l'aspetto durante il hover disabilitato */
}



  
  .form-group .alert, .form-group .label {
    border-style: none;
  }
  
  .form-group .tag.label {
    padding: 5px;
    display: inline;
    font-size: 14px;
    font-weight: bold;
  }
  
  .input-group {
    padding: 0;
    margin: 0;
  }
  
  ::-webkit-file-upload-button {
    background: #c8d1dd;
    border: 0;
    color: white;
  }
  
  ::-webkit-file-upload-button:hover {
    background: #adb4bc;
  }
  
  ::placeholder {
    color: #1a1a1a;
  }
  
  #button-toggle {
    background: transparent;
    border: none;
    color: gray;
    padding: 0;
    position: relative;
  }
  










  
  #collapseOne, #collapseTwo {
    height: auto;
    word-wrap: break-word !important;
  }
  
  .radio-type {
    padding: 0;
  }
  
 /* // .btn .badge {
 //    position: relative;
 //    margin-left: -15px;
 //    margin-bottom: -10px;
 //    background: #fff;
 //    border-width: 1px;
 //    border-style: solid;
 //    border-color: #c8d1dd;
 //    color: gray;
 //  } */


 .rounded-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px; /* cambia a piacere */
  height: 40px;
  border-radius: 50%;
  color: white;
  font-size: 18px;
  margin-right:.2rem;
}

.icon-vc-tutorial {
  font-size: 6rem;
  line-height: 9rem;
}


.icon-codelist {
  width:20px;
}

  
  #radio-label {
    margin-left: 10px;
  }
  
  #radio {
    margin-top: 10px;
  }
  
  .drop-placeholder {
    background-color: transparent;
    height: 3.5em;
  }
  



/* ////////////////////////// functional buttons ///////////////////////////////*/
.btn-edit {
  opacity:0;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  border-radius: 50%;
  transition: opacity 0.3s ease;
  z-index:1000;
  width: auto;
  height: auto;
}




.btn-functional {
  background-color: transparent !important;
  border: 0;
  padding: 0;
  margin-left: 0.6rem;
}

.btn-functional:focus,
.btn-functional.active {
  outline: none;
  border: 0;
  box-shadow: none;
}



/* //////////////////////////////////// bootstrap-tagsinput //////////////////////////////// */

  .bootstrap-tagsinput {
    background-color: #fff;
    border: 1px solid #ccc;
    box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075);
    display: inline-block;
    padding: 4px 6px;
    color: #555;
    vertical-align: middle;
    border-radius: 4px;
    width: 100%;
    line-height: 22px;
    cursor: text;
  }
  
  .bootstrap-tagsinput input {
    border: none;
    box-shadow: none;
    outline: none;
    background-color: transparent;
    padding: 0 6px;
    margin: 0;
    width: auto;
    max-width: inherit;
  }
  
  .bootstrap-tagsinput.form-control input::-moz-placeholder {
    color: #777;
    opacity: 1;
  }
  
  .bootstrap-tagsinput.form-control input:-ms-input-placeholder {
    color: #777;
  }
  
  .bootstrap-tagsinput.form-control input::-webkit-input-placeholder {
    color: #777;
  }
  
  .bootstrap-tagsinput input:focus {
    border: none;
    box-shadow: none;
  }
  
  .bootstrap-tagsinput .badge {
    margin: 2px 0;
    padding: 5px 8px;
  }
  
  .bootstrap-tagsinput .badge [data-role="remove"] {
    margin-left: 8px;
    cursor: pointer;
  }
  
  .bootstrap-tagsinput .badge [data-role="remove"]:after {
    content: "Ãƒâ€”";
    padding: 0px 4px;
    background-color: rgba(0, 0, 0, 0.1);
    border-radius: 50%;
    font-size: 13px;
  }
  
  .bootstrap-tagsinput .badge [data-role="remove"]:hover:after {
    background-color: rgba(0, 0, 0, 0.62);
  }
  
  .bootstrap-tagsinput .badge [data-role="remove"]:hover:active {
    box-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);
  }



  /* ///////////////////////////////////// Toggle Switch  ///////////////////////////////////////////////*/
  
 .switch {
  display: inline-block;
  width: 60px;
  height: 34px;
  margin: 0;
}
  
  .switch input {
    display: none;
  }
  
  #guide_switch:before {
    content: "published";
    color: white;
    left: -4.8rem;
    margin-top: .2rem;
    display: inline-block;
    position: absolute;
  } 
  #guide_switch:after {
    content: "edit";
    color: white;
    padding-left: .5rem;
    top: 0;
    display: inline-block;
    position: absolute;
    margin-top: .2rem;
    } 





/* //////////////////////////////////////////// file-drop-area //////////////////////////////////////////////////////// */

.file-drop-area {
    position: relative;
    padding: 2rem 1rem;
    transition: border-color .15s ease-in-out,box-shadow .15s ease-in-out;
    border: 2px dashed #dae1e7;
    background-color: #fff;
    text-align: center;
    cursor: pointer;
}

.file-drop-area .file-drop-icon {
    display: block;
    margin-bottom: 0.75rem;
    color: #aeb4be;
    font-size: 1.625rem;
}    
.file-drop-area .file-drop-message {
    display: block;
    font-size: .875rem;
    margin-bottom: 1.25rem;
}    
.file-drop-area .file-drop-input {
    display: block;
    position: absolute;
    top: 0;
    left: 0;
/*     width: 100%; */
    height: 100%;
    background-color: transparent;
    opacity: 0;
    outline: none;
    cursor: pointer;
    z-index: 2;
}   
.file-drop-area .btn {
    position: relative;
    z-index: 3;
}    


.file-drop-area .file-drop-preview {
    max-width: 16rem;
    margin-right: auto;
    margin-bottom: 0.75rem;
    margin-left: auto;
} 

  


  /* /////////////////////////////////////////////////////////////// Navigation ///////////////////////////////// */
  
    .collapsing {
    transition-property: height, visibility;
    transition-duration: .35s;
  }
  
  .menu.navbar-collapse#contents {
    background-color: #1a88a9;
  
  }
  
  #contents.navbar-collapse ul {
    list-style-type: none;
    padding: 0;
    margin: 0;
  }

  #contents.navbar-collapse ul li {
    padding: .5rem 1.5rem;
    background-color: transparent; 
    border-bottom: 1px solid #fff;
    transition: all 2s ease;
  }
 @media only screen and (min-width: 768px) {  
#contents.navbar-collapse ul li {
  padding: 1rem 1.5rem;
  }}
  
  .menu.navbar-collapse#contents li a {
    color: #333;
  }
  
  .menu.navbar-collapse#contents li a:hover {
    font-weight: normal;
  }
  
  .menu.navbar-collapse#contents li.required {
    background-color: #c8d1dd;
  
  }
  
  .menu.navbar-collapse#contents li.completed {
    background-color: #1a88a9;
    color: white;
    border-bottom: 1px solid #fff;
  
  }
  
  .menu.navbar-collapse#contents li.completed a {
    color: white;
  }
  
  .menu.navbar-collapse#contents li:active a, .menu.navbar-collapse#contents li.active a {
    font-weight: bold;
  }
  
  .menu.navbar-collapse#contents li li:last-child {
    border-bottom: none;
  }
  
  .strcol {
    padding: 0;
  }

  @media only screen and (min-width: 768px) {
     .strcol {
    position: relative;
    z-index: 500;
    height:100vh;
  }
  }

    .rounded-circle-container {
    max-width:3rem;
    margin:auto;
  }
  
  
  #contents.navbar-collapse .btn {
    margin: 4vh .3rem;
  }


.navbar-dark .navbar-nav .bg-secondary .nav-link {
  filter: invert(65%);
}


nav {
  letter-spacing: 0.03rem;
}



.btn-collabsible-nav > i {
  transform: rotate(90deg);
  transition-duration: 0.5s;
}
.btn-collabsible-nav.collapsed > i {
  transform: rotate(0deg);
}

.navbar-dark .navbar-nav .bg-secondary .nav-link {
  filter: invert(65%);
}



  
  div#myaccount.navbar-collapse {
    position: absolute;
    right: 0;
    width: 250px;
    overflow: hidden;
    background: white;
  }
  
  div#myaccount.navbar-collapse a {
    color: #1a1a1a;
    font-weight: normal;
    text-decoration: none;
  }
  
  div#myaccount.navbar-collapse div {
    display: block;
    padding: 30px;
  }
  
  div#myaccount.navbar-collapse div ul li {
    padding: 5px 0;
  }
  
  div#myaccount.navbar-collapse div ul li a i {
    margin-right: 10px;
    color: #56b9d6;
  }
  
  #tool-sidebar.navbar-collapse {
    padding: 20px 15px 0 15px;
  
  }
  
  #tool-sidebar.navbar-collapse li {
    padding: 0;
    margin: 5px 0;
  }
  
  #tool-sidebar.navbar-collapse li a {
    display: block;
  }
  
  #tool-sidebar.navbar-collapse li a.btn.navtoggle {
    opacity: 1;
  }

  
  #tool-sidebar.navbar-collapse li i {
    position: relative;
    font-size: 35px;
  }
  
  #tool-sidebar.navbar-collapse li a#account-icon > i {
    font-size: 50px;
  }
  
  @media only screen and (max-width: 768px) {
    .menu.navbar-collapse {
      position: fixed;
      top: 100px;
      width: 100%;
      z-index: 500;
      padding: 0;
    }
  }
  
  @media only screen and (max-width: 768px) {
    .menu.navbar-collapse#myaccount {
      top: 0;
      right: 0;
      margin-left: -250px;
    }
  }
  
  @media only screen and (max-width: 768px) {
    .menu.navbar-collapse#contents {
  
      right: 0;
    }
  }
  
  @media only screen and (max-width: 768px) {
    div#tool-sidebar.navbar-collapse {
      background: white;
      padding: 10px 30px 0px 30px;
      left: 0;
      right: 0;
      width: 100%;
    }
  }
  
  @media only screen and (max-width: 768px) {
    div#tool-sidebar.navbar-collapse li {
      padding: 0px;
    }
  }
  
  @media only screen and (min-width: 768px) {
    div.container-fluid .row {
      width: 100 !important;
    }
  }
  
  @media only screen and (min-width: 768px) {
    .menu.navbar-collapse {
      display: block;
      position: fixed;
      padding: 0;
      height: 100vh;
    }
  }
  
  @media only screen and (min-width: 768px) {
    .menu.navbar-collapse#contents {
      left: 0;
    }
  }
  
  @media only screen and (min-width: 768px) {
    .menu.navbar-collapse#tools {
      float: right;
    }
  }

  
  .nav-link.navtoggle::after {
    display: none;
  }
  
  .btn.navtoggle:hover, .btn.navtoggle:active, .btn.navtoggle.active {
    opacity: 1;
    color: white;
    background: transparent;
  }
  
  #navbar .btn.navtoggle {
    background: none;
    font-size: 32px;
    opacity: .5;
    box-shadow: none;
    color: white;
  }
  
  .btn.navtoggle:after {
    display: none;
  }
  
  .btn.disabled, .btn:disabled {
    cursor: not-allowed;
  }


  
  
  
  
  div#navbar {
    background-color: #1a88a9;
    padding: 0;
    margin: 0;
    display: block;
  }
  
  div#navbar div {
    height: 100px;
  }
  
  #logo-desktop, #logo-smartphone {
    padding: 0px;
  }
  
  #logo-desktop {
    height: 6rem;
    margin: 1rem 1.5rem;
  }
  
  #logo-smartphone {
    height: 4rem;
    margin: 1rem 1.5rem;;
  }


.nav-link.active {
  font-weight: bolder;
}

.figure-caption {
  color: #212529;
}

.text-courgette {
  font-family: 'Courgette';
  font-weight: 300;
}

/*************************** custom breaks *****************************/

.break-xs {
  max-width: 480px;
  margin: auto;
}

.break-sm {
  max-width: 576px;
  margin: auto;
}

.break-md {
  max-width: 768px;
  margin: auto;
}

.break-lg {
  max-width: 992px;
  margin: auto;
}

.navbar-brand-logo {
  height: 3rem;
}

@media (min-width: 992px) {
  .navbar-brand-logo {
    height: 4rem;
  }
}

.cover:before {
  height: 100%;
  content: '';
  background: linear-gradient(180deg, rgba(0,77,129,1) 5%, rgba(0,77,129,0) 30rem);
  width: 100%;
  display: block;
  position: absolute;
}

.cover:after {
  height: 100%;
  content: '';
  background: url(https://assets.iamagoodtraveller.com/img/bg/bg-cover-wave.svg);
  width: 100%;
  display: block;
  position: absolute;
  background-repeat: no-repeat;
  background-position: 0 100%;
  bottom: -1px;
  background-size: 100% auto;
}

.cover {
  height: 170vh;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  position: relative;
  background-attachment: fixed;
  /* transition: all 1s ease-out;; */
}

.cover.heading_int {
  height: 22rem;
  /* background-image: url('https://assets.iamagoodtraveller.com/img//misc/bellezza%20romantico%20abbandono%20decadenza%20malinconia.jpg'); */
}

.welcome-cover {
  /* background-image: url('https://assets.iamagoodtraveller.com/img/misc/bellezza%20romantico%20abbandono%20decadenza%20malinconia.jpg'); */
}

.points-of-interest-cover {
  /* background-image: url(https://assets.iamagoodtraveller.com/img/cover/05777e96f6d4b41f20d3bb91f161cc54798c0891b7f30382eb72ce82d38c1d0f.jpeg); */
}

.food-cover {
  /* background-image: url(https://assets.iamagoodtraveller.com/img/misc/local-community-food.jpg); */
}

.tools {
  position: fixed;
  right: 0rem;
  z-index: 1000;
  bottom: 0;
  left: 0;
  margin: 0;
}

.toolbar {
  background-color: #175980;
  margin: 0;
  padding: .2rem 0rem;
}

.tools li {
  display: inline-block;
  margin: 0;
}

@media (min-width: 768px) {
  .tools {
    position: fixed;
    right: .5rem;
    top: 50%;
    left: auto;
    transform: translate(0, -50%);
    bottom: auto;
    z-index: 5040;
  }
}

@media (min-width: 768px) {
  .toolbar {
    background-color: transparent;
  }
}

@media (min-width: 768px) {
  .tools li {
    margin: 1.8rem 0;
    display: list-item;
  }
}

.header {
  z-index: 1000;
  display: block;
  position: relative;
  height: 100%;
}

.header-goal-icon {
  max-height: 5rem;
  margin: 5px;
}

.myCompass {
  max-height: 10rem;
}

.headings {
  top: 3rem;
  left: 2.5rem;
  right: 2.5rem;
}

/* carousel */

.highlight-body {
  height: 18rem;
}

.crop-landscape {
  object-fit: cover;
}

.carousel-indicators [data-bs-target] {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: #56b9d6;
  border: 0;
}

.carousel-control {
  bottom: 15%;
}

/* logos bar */

.figure.container-logo {
  position: relative;
}

#navbar-destination-official-logo-container{
  width:3rem;
}

#navbar-destination-official-logo {
  height: 4.5rem;
}

.nav-item {
  margin:0;
  padding:0;
}

.nav-dots .nav-item:not(:first-child) {
  margin-left: 2rem;
  list-style-type: disc;
  list-style-position: outside;
}

.nav-dash .nav-item:not(:last-child) a:after {
  content: 'â™¦';
  padding-left: 1rem;
}

.nav-icon {
  height: 40px;
  font-size: 40px;
}

.filter-item {
  width: 15%;
  padding: .1rem;
}

.filter-icon {
  width: 100%;
  max-width: 4rem;
  max-height: 13vh;
}

/* compass nav */

.icon-navbar.navbar {
  height: 3.6rem;
}

.user-nav-shortcuts, .main-nav-toggler {
  padding: .25rem .40rem;
  line-height: 1;
}

.user-nav-shortcuts {
  font-size: 30px;
}

.user-nav-account-icon, .main-nav-toggler {
  font-size: 44px !important;
  padding: .3rem;
}

.user-nav-account-icon {
  line-height: 1.5;
}

.btn-hover-white {
}

.rounded-circle-content {
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

.nav-destination ul .nav-item {
  margin-right: .8rem;
  margin-left: .8rem;
}

/* calendar */

.calendarDay {
  cursor: pointer;
}

.calendarContainer {
  text-align: center;
  position: relative;
  overflow: hidden;
  width: 270px;
  height: 400px;
  margin: auto;
  opacity: 0.8;
  display: inline-block;
  margin: 15px;
}

.calendarTitle {
  width: 100%;
  margin-bottom: 5px;
  background-color: white;
  color: #444;
  opacity: 1;
  cursor: default;
  border-radius: 5px;
  height: 38px;
  text-align: center;
}

.buttonsMonthContainer {
  height: 40px;
  overflow: hidden;
}

.buttonPreviousMonth {
  width: 128px;
  margin: 1px;
}

.buttonNextMonth {
  width: 128px;
  margin: 1px;
}

.selectsYearAndMonthContainer {
  height: 40px;
  overflow: hidden;
}

.selectsYearAndMonthLabel {
  width: 75px;
}

.yearAndMonthSelect {
  width: 88px;
}

/* sustainability box */

.sustainability-box {
  background-image: url('https://assets.iamagoodtraveller.com/img/bg/sustainability-box.svg');
  background-size: 40% auto;
  background-repeat: repeat-x;
  margin-bottom: -5rem;
}

.sustainability-box .list-group-item{
  background:transparent;
  border: 0;
}

.bg-goal {
  background-repeat: no-repeat;
  background-size: 3rem auto;
  background-position: 0px 8px;
  padding-left: 5rem;
}

.bg-goal:before {
  width: 60px;
  position: absolute;
  left: 0rem;
}

.bg-goal-1:before {
  content: url(https://assets.iamagoodtraveller.com/img/goal/environment.svg);
}

.bg-goal-2:before {
  content: url(https://assets.iamagoodtraveller.com/img/goal/economy.svg);
}

.bg-goal-3:before {
  content: url(https://assets.iamagoodtraveller.com/img/goal/social.svg);
}

.bg-goal-4:before {
  content: url(https://assets.iamagoodtraveller.com/img/goal/conservation.svg);
}

.bg-goal-5:before {
  content: url(https://assets.iamagoodtraveller.com/img/goal/authenticity.svg);
}

.sustainability-box-goal {
  padding-bottom: 2rem;
  background: transparent;
  border: 0;
}

.sustainability-box-text {
  width: 100%;
  color: #222;
}

li {
  margin-bottom: .3rem;
}

.local-community-cover {
  /*background-image: url('https://assets.iamagoodtraveller.com/img/misc/local-community-food.jpg');*/
  background-size: cover;
  background-position: 50% 50%;
  min-height: 20rem;
}

span.km:after {
  content: 'km';
}

.big-icon {
  height: 5rem;
  width: 8rem;
}

div.date-container {
}

.date-container {
  position: absolute;
  z-index: 1;
  width: auto;
  left: 1.5rem;
  height: auto;
  padding: 10px 0;
  top:0;
}

.date-content {
  margin: 0;
  display: inline-block;
  list-style: none;
  padding-left: 0;
}

.date {
  padding-right: 12px;
  padding-left: 12px;
  margin: 0;
  display: inline-block;
  text-transform: uppercase;
  line-height: 1;
}

.date:not(:first-child) {
  border-left: 1px solid black;
}

.day {
  display: block;
  font-weight: bold;
  font-size: larger;
}

.month {
  font-size: small;
}

.accordion-button {
  font-weight: bold;
}

.accordion-button:focus {
  box-shadow: none;
  border-color: rgba(0,0,0,.125);
}

.accordion .card {
  border:0;
}

.accessibility-filter .form-check {
  margin: 0;
  padding: 0;
  text-align: center;
}

#accessibility-filter .form-check-input {
  display: none;
}

.accessibility-icon:before {
  display: block;
  font-size: 45px;
}

.filter-button.btn {
  padding: 0;
}

.filter-button.btn.active {
}

.btn:focus, .btn:active {
  outline: none !important;
  box-shadow: none;
}

section {
  padding-bottom: 3rem;
}

.component {
  scroll-margin-top: 10rem;
}

.intro {
  padding-top: .2rem;
  padding-bottom: 1rem;
}

.tooltip.show {
  opacity: 1;
}

.network-logo {
  align-items: center !important;
  height: 50% !important;
  display: flex !important;
  padding: .5rem;
  padding-top: 1.5rem;
}

.network-logo img {
  max-height: 100%;
  margin: auto;
}

.network-name {
  position: absolute !important;
  display: flex !important;
  justify-content: center !important;
  height: 50% !important;
  top: 50%;
  padding: .5rem;
  padding-bottom: 1.5rem;
}

.btn-questionmark {
  padding: .08rem .50rem;
  font-size: .875rem;
  border-radius: 1rem;
}

.fa.fa-star {
  font-size: 40px;
}

.star-tdr {
  width: 70px;
}

.crowding-icon {
  height: 2.55rem;
}




/*********************************** TDR ****************************/
.tdr-label {
  width: 3rem;
  margin: auto;
}

.tdr-label-modal {
  width: 6rem;
  margin: auto;
}

.tdr-label-score {
  width: 3rem;
  padding: .55rem;
}

.tdr_score:before {
  content: '';
  width: 70px;
  height: 70px;
  position: absolute;
  bottom: -60px;
  left: 50%;
  transform: translateX(-80%);
}

.tdr_score {
  margin-bottom: 4rem;
}

.tdr-label-score-modal {
  width: 6rem;
  padding: 1rem;
}

.tdr_1::before {
  background-image: url(https://assets.iamagoodtraveller.com/img/icon/score/tdr-1.svg);
  transform: translateX(-70%);
}

.tdr_2::before {
  background-image: url(https://assets.iamagoodtraveller.com/img/icon/score/tdr-2.svg);
}

.tdr_3::before {
  background-image: url(https://assets.iamagoodtraveller.com/img/icon/score/tdr-3.svg);
  transform: translateX(-100%);
}

.tdr_4::before {
  background-image: url(https://assets.iamagoodtraveller.com/img/icon/score/tdr-4.svg);
}

.tdr_5::before {
  background-image: url(https://assets.iamagoodtraveller.com/img/icon/score/tdr-5.svg);
}





/********************************* TDR sidebar background ********************/

.bg-tdr-1 {
  background: linear-gradient(#175980 80%, #4e6095 95%, #af3787);
}

.bg-tdr-2 {
  background: linear-gradient(
    #175980 60%,
    #4e6095 80%,
    #af3787 98%,
    #e54a92
  ); 
  /* //bello! */
}

.bg-tdr-3 {
  background: linear-gradient(
    #175980 55%,
    #4e6095 80%,
    #af3787 90%,
    #e54a92 96%,
    #e866a0 98%,
    #fc86b7
  ); 
  /* //bello! */
}

.bg-tdr-4 {
  background: linear-gradient(
    #175980 50%,
    #4e6095 80%,
    #af3787 90%,
    #e54a92 96%,
    #e866a0 97%,
    #fc86b7 98%,
    #ffdb92
  ); 
  /* // bellissimo!! */
}

.bg-tdr-5 {
  /* // background: linear-gradient(#175980 45%,#4e6095 65%,#af3787 90%,#e54a92 95%,#e866a0 96%,#fc86b7 97%, #fffab6 99%,#ffdb92);  //bello!! */
  background: linear-gradient(
    #175980 50%,
    #4e6095 80%,
    #af3787 92%,
    #e54a92 95%,
    #fc86b7 97%,
    #fffab6 99%,
    #ffdb92
  );
}



/************************** tdr Overview Modal Window *************/


input[type="range"] {
  -webkit-appearance: none;

  width: 100%;
  height: 13px;
  border-radius: 5px;
  background-repeat: no-repeat;
  background-color: #7f83a2;
}

input[type="range"].tdr-1 {
  background-image: linear-gradient(to right, #0c79b7, #af3787);
  background-size: 20% 100%;
}
input[type="range"].tdr-2 {
  background-image: linear-gradient(to right, #0c79b7, #af3787, #e54a92);
  background-size: 40% 100%;
}
input[type="range"].tdr-3 {
  background-image: linear-gradient(
    to right,
    #0c79b7,
    #af3787,
    #e54a92,
    #fc86b7
  );
  background-size: 60% 100%;
}
input[type="range"].tdr-4 {
  background-image: linear-gradient(
    to right,
    #0c79b7,
    #af3787,
    #e54a92,
    #fc86b7,
    #ffdb92
  );
  background-size: 80% 100%;
}
input[type="range"].tdr-5 {
  background-image: linear-gradient(
    to right,
    #0c79b7,
    #af3787,
    #e54a92,
    #fc86b7,
    #ffdb92,
    #fffab6
  );
  background-size: 100% 100%;
}









.list-group.values-list li {
  margin-bottom: 5rem;
}

.tab-label-logo {
  height: 4rem;
}

.warning-icon {
  font-size: 5rem;
}

.bg-dark-blue, .bg-dark, .bg-dark .list-group-item {
  color: white;
}

.full-image {
  width: 100%;
  height: 100%;
}

/* Tags */

.tagsFlexWrapDiv {
  display: flex; 
  flex-flow: wrap;
}

.tagForceFirst {
  order: -1;
}


/* Modals */
.modal-header,.modal-footer {
  border: 0;
}

/* Forms */
button.edit-button:disabled {
  cursor:progress;
}



/* ////////////////////// LOADER /////////////////////////////////*/


.loader {
    width: 48px;
    height: 48px;
    border: 5px solid #FFF;
    border-bottom-color: transparent;
    border-radius: 50%;
    display: inline-block;
    box-sizing: border-box;
    animation: rotation 1s linear infinite;
  position:absolute;
  z-index: 8000;
  top: 50%;
  left: 50%;
    }

    @keyframes rotation {
    0% {
        transform: rotate(0deg);
    }
    100% {
        transform: rotate(360deg);
    }
    } 


/****************************** CARDS *****************************/


.card {
  position: relative;
  display: flex;
  flex-direction: column;
  min-width: 0;
  word-wrap: break-word;
  background-color: #fff;
  background-image: none;
  border: 0;
  border-radius: 5px;
  margin-top: 10px;
  padding-left: 20px;
  padding-right: 20px;
  padding-bottom: 15px;
}

.card.card-vc {
  padding: 1.5rem;
}

.card-header {
  height: auto;
  background-color: transparent;
  background-image: none;
  border: none;
  word-wrap: break-word;
  padding: 0px;
  cursor: pointer;
}

.card-body {
  padding: 0px;
}


/*********************************** TOGGLE **********************************************/
  
  .slider {
    position: absolute;
    cursor: pointer;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-color: #ccc;
    -webkit-transition: .4s;
    transition: .4s;
  }
  
  .slider:before {
    position: absolute;
    content: "";
    height: 26px;
    width: 26px;
    left: 4px;
    bottom: 4px;
    background-color: white;
    -webkit-transition: .4s;
    transition: .4s;
  }
  

  
  input:checked + .slider:before {
    -webkit-transform: translateX(26px);
    -ms-transform: translateX(26px);
    transform: translateX(26px);
  }
  
  .slider.round {
    border-radius: 34px;
  }
  
  iframe{
    border:0;
  }
  
  .slider.round:before {
    border-radius: 50%;
  }





/* /////////////////////// EDITABLE PREVIEW  //////////////////////////////////*/

.opacity-hovered {
  transition: opacity 0.3s ease;
}

/* Escludi l'effetto blur per l'elemento con l'ID "cover-headings" */
.opacity-hovered:not(.background-image) {
    filter: blur(2px);
    opacity: 0.8;
}

/* Stile di overlay per l'elemento con l'ID "cover-headings" */
#cover-headings {
    /* filter: none !important; */
    opacity: 1 !important;
}

.opacity-hovered.background-image::before {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    background: inherit;  /* Usa il colore di sfondo dell'elemento principale */
    filter: blur(2px);
    opacity: 0.8;
}


.linked-to-admin-panel:hover .btn-edit , .btn-edit:hover{
  opacity:1 !important;
  filter: blur(0px) !important;
}











/* //
///
////
/////
//////
///////
/////////////////////////// search engine & filter ///////////////////////// */






#search-engine {
  overflow:hidden;
}

.compass-search-engine {
  opacity: 1;
  transition: all 2s ease;
  height: 3rem;
  margin: auto;
}

@media screen and (min-width: 768px) {
  .compass-search-engine {
    /* position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0; */
    height: 15vh;
    }
    
}



.compass-search-engine.hidden {
  opacity:0;
}

.control.preview-not-allowed {
  padding:0;
}

.filter-container-fixed {
  position: fixed;
  z-index: 999999999999999999999999999999;
  right: 0;
}
.title-filter-container {
  margin:0;
  padding:0;
}

.list-group.checkbox-container {
  display:content;
}

#filter * {
  /* transition: opacity .2s ease; */
}

.visible {
  /* // opacity: 1; */
  display:inline-block;
}

.hidden {
  /* // opacity: 0; */
  display:none !important;
  pointer-events: none;  /* Disable interaction when hidden */

}

.control.badgeboxinput {
  display: inline-block;
  margin:0;
}

.badgebox {
  margin:.2rem;
}
.badgebox.active{
  padding-right:1.3rem;
  
}
.badgebox.active::after {
  content: '\00D7';
  padding: 0px .3rem;
  position: absolute;
  right: 0;
  top: 50%;
  transform: translate(0%, -50%);
  font-size: x-large;
}





/*****************************  DISTANCE SLIDER *******************************/

.distance-slider {
  -webkit-appearance: none;
  -moz-apperance: none;
  appearance: none;
 
  height: 20px;
  cursor: pointer;
  transition: all .25s ease;
  position:relative;
}




.distance-slider::-webkit-slider-thumb {
    -webkit-appearance: none;
    width: 25px; /* 1 */
    height: 25px;
  border-radius:50%;
  border: 2px solid #fff; /* 1 */
  transition: all 1s ease;
}



.distance-slider::-moz-range-track {
    height: 20px;
}

.distance-slider::-moz-range-thumb {
    -webkit-appearance: none;
    width: 25px; /* 1 */
    height: 25px;
  border-radius:50%;
  border: 2px solid #fff; /* 1 */
  box-sizing: border-box;
  transition: all 1s ease;
}



.distance-slider::-ms-thumb { 
    width: 25px; /* 1 */
    height: 25px;
  border-radius:50%;
  border: 2px solid #fff; /* 1 */
  box-sizing: border-box;
  transition: all 1s ease;
}

.distance-slider::-ms-ticks-after { 
    display: none; 
}

.distance-slider::-ms-ticks-before { 
    display: none; 
}

.distance-slider::-ms-track { 
    height: 20px;
    border: none;
}

.distance-slider::-ms-tooltip { 
    display: none;
}



.slider-ticks {
  position:relative;
  padding-bottom:2rem;
}

.slider-tick {
  position:absolute;
  transform: translate(-50%, 0%);
  font-size:small;
}


.distance-slider-label {
position: absolute;
  padding-left: 0.3rem;
  font-size: small;
  line-height: 23px;
}


/******************************* FILTER ***********************************/

.filter-container {
  max-height: 100vh;
  overflow-y: scroll;
  height: auto;

}


.filtered-out{
  display:none !important;
}




.collapsible-section  .control.is-form-group:not(:first-child) {
  margin:0;
}



@media screen and (min-width: 768px) {


  #btn-filter-by {
    z-index: 5001;
  }  

  .btn-rounded-icon {
  width: 2.5rem;
  height: 2.5rem;
  padding: 0;
  }
  }



  /* constellation leaflet map */

  .map {
    width:100%;
    }
    
    .map.full-height-map{
      height: 82vh;
    }
    
    .starmarker-tdrScore-1 {
      animation: twinkle 0.8s infinite alternate;
    }
    .starmarker-tdrScore-2 {
      animation: twinkle 0.9s infinite alternate;
    }
    .starmarker-tdrScore-3 {
      animation: twinkle 1s infinite alternate;
    }
    .starmarker-tdrScore-4 {
      animation: twinkle 1.1s infinite alternate;
    }
    .starmarker-tdrScore-5 {
      animation: twinkle 1.2s infinite alternate;
    }
    @keyframes twinkle {
      0% {
        opacity: 1;
      }
      60% {
        opacity: 1;
      }
      100% {
        opacity: 0.3;
      }
    }
    
    #search-engine-results-map .leaflet-tile {
      filter: invert(12%) sepia(70%) saturate(250%) hue-rotate(180deg)
        brightness(195%) contrast(200%); /* don't touch */
    }
    
    
    .card-popup {
      width:250px !important; 
    }
    
    

    
    .bg-dark .invalid-feedback{
      filter: brightness(1.7);
    }
    
    
    .connectivity-service-icons i {
      line-height: 2rem;
  font-size: 2rem;
    }

    .connectivity-service-icons svg{
      height: 2rem;

    }


/******** ANDREA ************/
.section-without-bottom-margin {
    margin-bottom: 0 !important;
}