/* General */
* {
  outline: none;
}
:root {
  --primary: #004486;
  --secondary: #0052a3;
  --tertiary: #f8c364;
  --text: #112b44;
  --backgroundBody: linear-gradient(180deg, #e5ecf2 0%, #cadae9 100%);
  --backgroundHighligth: linear-gradient(180deg, #0a3976 0%, #1a86b0 100%);
}
@font-face {
  font-family: Lato;
  src: url("../fonts/Lato.ttf");
}
@font-face {
  font-family: Raleway;
  src: url("../fonts/Raleway.ttf");
}

body {
  font-family: Lato;
  background: var(--backgroundBody);
}

main {
  min-height: 80vh;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-family: Raleway;
}
h1,
h2,
h3 {
  font-weight: 600;
}
h1 {
  font-size: calc(2.986rem + ((1vw - 4px) * 0.5264));
}
h2 {
  font-size: calc(2.488rem + ((1vw - 4px) * 0.5264));
}
h3 {
  font-size: calc(2.074rem + ((1vw - 4px) * 0.5264));
}
h4 {
  font-size: calc(1.728rem + ((1vw - 4px) * 0.5264));
}
h5 {
  font-size: calc(1.44rem + ((1vw - 4px) * 0.5264));
}
h6 {
  font-size: calc(1.2rem + ((1vw - 4px) * 0.5264));
}

p,
.nav-link,
.page-link,
.message,
.p {
  font-size: calc(1rem + ((1vw - 4px) * 0.2632));
}

body,
p,
small,
input,
label,
h1,
h2,
h3,
h4,
h5,
h6,
.p,
.form-select,
.form-control,
.flatpickr-current-month .flatpickr-monthDropdown-months,
.flatpickr-current-month input.cur-year {
  color: var(--text);
}

a {
  color: var(--primary);
}
a:hover {
  --bs-link-color-rgb: var(--secondary);
}
#topBtn {
  display: none;
  position: fixed;
  bottom: 20px;
  right: 20px;
  cursor: pointer;
}
.btn-primary {
  --bs-btn-color: #fff;
  --bs-btn-bg: var(--primary);
  --bs-btn-border-color: var(--primary);
  --bs-btn-hover-bg: var(--secondary);
  --bs-btn-hover-border-color: var(--secondary);
  --bs-btn-active-bg: var(--secondary);
  --bs-btn-active-border-color: var(--secondary);
  --bs-btn-disabled-bg: var(--primary);
  --bs-btn-disabled-border-color: var(--primary);
}
.btn-outline-primary {
  --bs-btn-color: var(--primary);
  --bs-btn-border-color: var(--primary);
  --bs-btn-hover-color: #fff;
  --bs-btn-hover-bg: var(--secondary);
  --bs-btn-hover-border-color: var(--secondary);
  --bs-btn-focus-shadow-rgb: 13, 110, 253;
  --bs-btn-active-color: #fff;
  --bs-btn-active-bg: var(--secondary);
  --bs-btn-active-border-color: var(--secondary);
  --bs-btn-active-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);
  --bs-btn-disabled-color: var(--primary);
  --bs-btn-disabled-bg: transparent;
  --bs-btn-disabled-border-color: var(--primary);
  --bs-gradient: none;
}
.btn-tertiary {
  --bs-btn-color: var(--text);
  --bs-btn-bg: var(--tertiary);
  --bs-btn-border-color: var(--tertiary);
  --bs-btn-hover-bg: var(--tertiary);
  --bs-btn-hover-border-color: var(--tertiary);
  --bs-btn-active-bg: var(--tertiary);
  --bs-btn-active-border-color: var(--tertiary);
  --bs-btn-disabled-bg: var(--tertiary);
  --bs-btn-disabled-border-color: var(--tertiary);
}
.btn-outline-tertiary {
  --bs-btn-color: var(--tertiary);
  --bs-btn-border-color: var(--tertiary);
  --bs-btn-hover-color: var(--text);
  --bs-btn-hover-bg: var(--tertiary);
  --bs-btn-hover-border-color: var(--tertiary);
  --bs-btn-focus-shadow-rgb: 13, 110, 253;
  --bs-btn-active-color: #fff;
  --bs-btn-active-bg: var(--tertiary);
  --bs-btn-active-border-color: var(--tertiary);
  --bs-btn-active-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);
  --bs-btn-disabled-color: var(--tertiary);
  --bs-btn-disabled-bg: transparent;
  --bs-btn-disabled-border-color: var(--tertiary);
  --bs-gradient: none;
}

.text-primary {
  color: var(--primary) !important;
}
.mylabelrequired:after {
  content: "*";
  color: red;
  padding-left: 0.2em;
}

.form-select:focus,
.form-control:focus,
.flatpickr-input:focus {
  color: var(--text);
  border-color: transparent;
  outline: 0;
  box-shadow: 0 0 0 0.25rem #00448640;
}

/* Header */
header {
  background: #ffffff;
  border-bottom: 0.2em solid var(--primary);
}
.logo {
  height: 70px;
  width: auto;
}
.nav-link {
  color: var(--text);
  font-weight: 500;
  text-transform: uppercase;
}
.nav-link:hover,
.nav-link.active {
  color: var(--secondary) !important;
  fill: var(--secondary);
}
.nav-link:after {
  width: 10px;
  inset-inline-start: 100%;
  background-color: var(--secondary);
  opacity: 0;
  content: "";
  bottom: 0;
  height: 3px;
  left: 0;
  z-index: 2;
  display: block;
  transition: 0.3s;
  transition-timing-function: cubic-bezier(0.58, 0.3, 0.005, 1);
}

.nav-link:hover:after,
.nav-link.active:after {
  width: 100%;
  opacity: 1;
  transform: scale(1);
  transform-origin: bottom left;
}
.banner-highlight {
  background: var(--backgroundHighligth);
}
.banner-highlight h4,
.banner-highlight h5,
.banner-highlight h6,
.banner-highlight p {
  color: #ffffff;
}

/* Card */
i.list-icon {
  color: var(--secondary);
  width: 24px;
}
.card-header,
.card-footer {
  background-color: transparent;
}
.page-link {
  color: var(--primary);
}
.page-link:hover,
.page-link:focus {
  color: var(--secondary);
  box-shadow: none;
}
.active > .page-link {
  background-color: var(--primary);
  border-color: var(--primary);
}
.active > .page-link:focus,
.active > .page-link:hover {
  color: #ffffff;
}

.maestriImmobiliare{
  background: url(../images/bg-i-maestri-dellimmobiliare-2026.webp);
  min-height: 20vh;
}

/* Cropped image */
.userImg {
  width: 300px;
}

#modal .image_area {
  position: relative;
}

#modal img {
  display: block;
  max-width: 100%;
}

#modal .overlay {
  position: absolute;
  bottom: 10px;
  left: 0;
  right: 0;
  background-color: rgba(255, 255, 255, 0.5);
  overflow: hidden;
  height: 0;
  transition: 0.5s ease;
  width: 100%;
}

#modal .image_area:hover .overlay {
  height: 50%;
  cursor: pointer;
}

/* Star Rating */
.star-rating input {
  display: none;
}

.star-rating label {
  font-size: 1.2rem;
  color: #929292;
  cursor: pointer;
}

.star-rating label::before {
  font-family: "Font Awesome 6 Free";
  content: "\f005";
  font-weight: 400;
  opacity: 0.5;
  transition: all 0.2s;
}

.star-rating label:hover {
  color: #ffd700;
}

.star-rating input:checked ~ label::before,
.star-rating :hover label:hover ~ label::before,
.star-rating :hover label:hover::before {
  color: #ffd700;
  opacity: 1;
}

/* Footer */
footer {
  background: #ffffff;
  border-top: 0.2em solid var(--primary);
}

/* MediaQuery */
@media screen and (min-width: 576px) and (max-width: 992px) {
  .userImg {
    width: 250px;
  }
}
