html, body {
  font-family: 'Helvetica Neue', Helvetica, Arial, sans-serif;
  font-size: 0.9rem;
  background: color-mix(in srgb, var(--upf-color-bg) 92%, #dbe4f0 8%);
  color: var(--upf-text-primary);
}

h1, h2, h3, h4 {
  color: var(--upf-text-primary);
  font-weight: 700;
  line-height: 1.25;
  margin-bottom: var(--upf-space-3);
}

h1 { font-size: 1.75rem; }
h2 { font-size: 1.375rem; }
h3 { font-size: 1.125rem; }
h4 { font-size: 1rem; }

h1:focus {
  outline: none;
}

a, .btn-link {
  color: #0071c1;
}

.content {
  padding-top: 1.1rem;
}

.valid.modified:not([type=checkbox]) {
  outline: 1px solid #26b050;
}

.invalid {
  outline: 1px solid red;
}

.validation-message {
  color: red;
}

/* Topbar: override Hyper's solid border with theme-aware token */
.navbar-custom {
  border-bottom: 1px solid var(--upf-color-border) !important;
}

/* -----------------------------------------------
   Sidebar: external-link icon on nav items
   (es. "Apri in nuova finestra" su Calendario)
   ----------------------------------------------- */
.side-nav-item-has-ext {
  position: relative;
}

.side-nav-item-has-ext .side-nav-link {
  /* spazio a destra per non sovrapporsi all'icona */
  padding-right: 36px !important;
}

.side-nav-ext-link {
  position: absolute;
  right: 8px;
  top: 50%;
  transform: translateY(-50%);
  display: flex;
  align-items: center;
  justify-content: center;
  width: 26px;
  height: 26px;
  border-radius: 4px;
  /* Usa la stessa variabile di colore di .side-nav-link per coerenza
     in tutti i temi e stati (light, dark, sidebar colorata) */
  color: var(--ct-menu-item-color);
  opacity: 0;
  transition: opacity 0.2s ease, background-color 0.2s ease;
  font-size: 15px;
  z-index: 1;
  cursor: pointer;
}

.side-nav-item-has-ext:hover .side-nav-ext-link {
  opacity: 0.55;
}

.side-nav-ext-link:hover {
  opacity: 1 !important;
  background-color: rgba(255, 255, 255, 0.12);
  color: var(--ct-menu-item-active-color);
}

.blur,
.dialog-blurry {
  backdrop-filter: blur(10px);
}

.menu-background {
  color: var(--upf-text-primary);
  background-color: color-mix(in srgb, var(--upf-color-surface-muted) 92%, #eef3f9 8%);
}

.popovermenu-background {
  background-color: var(--upf-color-surface);
  color: var(--upf-text-primary);
}

.topbarsearch-control,
.formsearch-control {
  display: block;
  width: 100%;
  padding: .45rem .9rem;
  font-size: .9rem;
  font-weight: 400;
  line-height: 1.5;
  color: var(--upf-text-primary);
  appearance: none;
  background-color: var(--bs-body-bg);
  background-clip: padding-box;
  border: 1px solid var(--upf-color-border);
  border-radius: .5rem;
  transition: border-color .15s ease-in-out, box-shadow .15s ease-in-out;
}

.formsearch-text {
  margin-top: .25rem;
  font-size: .75rem;
  color: var(--upf-text-secondary);
}

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

.login-layout,
.login-layout__main {
  min-height: 100vh;
  width: 100%;
}

.scheduler-layout {
  width: auto;
  height: 80vh;
  overflow-y: auto;
}

.appointmenttext {
  color: #2b2928;
  font-size: 16px;
  font-weight: bold;
}