@import url('https://fonts.googleapis.com/css2?family=Raleway:ital,wght@0,100..900;1,100..900&display=swap');
*:not(.fa):not(.fas):not(.far):not(.fal):not(.fad):not(.fa-solid):not(.glyphicon) {
    font-family: "Raleway", sans-serif !important;
    font-weight: 600;
}

:root {
    --primary: #E74C3C;
    --secondary: #FBDFDC;
    --accent: #B92518;
    --background: #F2F6F8;
    --text-color: #000000;
  }
/* navbar */
.static-top.navbar .menu-bar > .navbar-nav > .divider-vertical{
    border-right: 0;
    border-left: 1px solid #000000;
}
.dropdown-item{
    color:var(--text-color) !important;
}
.dropdown-item:hover{
    background-color: transparent!important;
}

.dropdown-toggle:hover{
    color: var(--secondary)!important;
}

.nav-link {
    padding: 0.5em 1em !important;        /* Spaziatura interna per sembrare un bottone */
    border-radius: 999px !important;      /* Angoli arrotondati */
    text-decoration: none !important;     /* Rimuove sottolineatura */
    transition: background-color 0.3s, color 0.3s !important;  /* Animazione fluida */
    color: var(--text-color) !important;               /* Colore del testo */
    background-color: #F4F4F4 !important; 
}
.nav-link:hover,
.nav-link[aria-current="page"]{
    background-color: var(--secondary) !important; 
    color: var(--accent) !important; 
    text-decoration: none !important;             
}

.divider-vertical{
display: none !important;
}
.dropdown-menu{
    background-color: white!important;
    box-shadow: 2px 2px 5px -3px rgb(0 0 0 / 54%)!important;
}

/* pagina log-in */
#external-login-heading , #local-login-heading{
    font-family: Roboto, Oxygen, Ubuntu, Cantarell, 'Open Sans', 'Helvetica Neue', sans-serif!important;
    color: var(--secondary);
    margin-bottom: 30px;
    font-size: 16px!important;
    margin-top: 20%;
}
#mainContent{
    margin: 30px 0;
    flex: 1 0 auto;
}
.col-form-label{
    font-family: Roboto, Oxygen, Ubuntu, Cantarell, 'Open Sans', 'Helvetica Neue', sans-serif!important;
    font-size: 14px;
    word-break: normal!important;
    color: var(--primary);
}
.portal-form{
    padding: 0 20px;
}
.xrm-attribute-value ,.xrm-attribute-value-encoded{
    font-family: Roboto, Oxygen, Ubuntu, Cantarell, 'Open Sans', 'Helvetica Neue', sans-serif!important;
    font-size: 14px;
}
.row-mb-3{
    width: 100%;
}
.offset-md-4{
    display: flex;
    gap: 10px;
    height: 40px;
    margin: 0;
    width: 100%;
    justify-content: end;
}

/* modale */
#EntityFormPanel{
    border: none!important;
}
#EntityFormControl_EntityFormView>.tab-title{
    font-family: Roboto, Oxygen, Ubuntu, Cantarell, 'Open Sans', 'Helvetica Neue', sans-serif!important;
    font-size: 20px;
      color: var(--primary);
      text-align: center;
      padding-bottom: 14px;
      border-bottom: 1px solid rgb(220, 220, 220);
}
.section-title>h3{
    font-size: 16px!important;
    text-transform: uppercase!important;
    font-weight: 600!important;
    border-bottom: 1px solid!important;
    width: 90%!important;
    margin-bottom: 20px!important;
    color:var(--accent)!important;
}
.field-label{
    font-family: Roboto, Oxygen, Ubuntu, Cantarell, 'Open Sans', 'Helvetica Neue', sans-serif!important;
    margin-left: 0px!important;
      font-size: 16px!important;
      margin-bottom: 6px!important;
      font-weight: 500!important;
      color: var(--primary)!important;
      background-color: transparent!important;
  }
/* text input box */
.form-control{
    height: 37px!important;
    font-size: 14px!important;
    font-family: Inter!important;
  }
  .input-text-box{
    font-size: 14px!important;
    font-family: Inter!important;
  }
.form-control.query{
    height: 32px!important;
}
  /* btn calendario */
.input-group-addon{
    border-color: #3b3d4021!important;
      background: white!important;
      margin-left: 20px!important;
      box-shadow: 2px 2px 5px -3px rgb(0 0 0 / 54%);
  }
  /* icona calendario */
  .fa-calendar{
    color: var(--primary)!important;
  }
  /* pulsante invia */
.actions{
    display: flex;
    justify-content: end;
  }
  #InsertButton{
    width: 200px;
  }

li > a[title="Registra"] {
    display: none;
}

.swal-button {    
    background-color: #003366;    
  }

.user-adding-info {
    color: #3B7BAD;
    font-weight: bold;
    font-size: small;
    margin-left: 12px;
    border-top: 1px solid lightgray;
    padding-top: 4px;
}

.float-end.toolbar-actions {
    margin: 8px 8px 0px 0px;
}

.banner-titolo{
    height: 100px; 
    background-color: #E74C3C; 
    display: flex; 
    align-items: center;
    flex-shrink: 0;
}

.banner-titolo > p {
    color: white !important;
    font-size: 30px;
    font-weight: 400 !important;
    margin-bottom: 0px !important;
}


 #pageTitlePlaceholder {
    visibility: hidden;
  }

body {
  display: flex;
  flex-direction: column;
  min-height: 100vh;
  margin: 0;
}


#liquid_form {
  flex-grow: 1;
}


body .columnBlockLayout {
  margin-top: 0 !important;
  margin-bottom: 0 !important;
  padding: 0 16px !important;
}

  .grid-actions ,.entitylist{
    border: none !important;
  }

  button.btn.btn-default.btn-md.aria-exp {
    width: 30px;
    height: 30px; 
    background-color: #ffffff; 
    border: none; 
    border-radius: 12px; 
    cursor: pointer; 
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1); 
    transition: all 0.3s ease; 
    color: #6c757d; 
    font-size: 15px; 
}


table.table {
  --bs-table-bg: #F8F8F8;
  --bs-table-striped-bg: #F8F8F8;
  --bs-table-hover-bg: #F8F8F8;
  --bs-table-active-bg: #F8F8F8;
}


.table tbody tr {
  background-color: #F8F8F8;
}

.table tbody tr td:first-child {
  border-top-left-radius: 8px;
  border-bottom-left-radius: 8px;
  
}

.table tbody tr td:last-child {
  border-top-right-radius: 8px;
  border-bottom-right-radius: 8px;
  
}

.table {
  border-collapse: separate;
  border-spacing: 0 8px;
}

.table thead th {
  background-color: white !important;
  border-bottom: none !important;
}


.input-group-btn .btn {
  border: none;
}


input.query.form-control {
  border-radius: .375rem !important;
}


.fa, .fa-chevron-down::before {
    content: "\f054" !important;
}

.desktop-action-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 30px;
  height: 30px;
  background-color: #ffffff;
  border: none;
  border-radius: 6px;
  cursor: pointer;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
  transition: all 0.3s ease;
  color: #6c757d;
  font-size: 14px;
  text-decoration: none !important;
}

.desktop-action-btn:hover {
  background-color: var(--secondary);
  color: var(--accent) !important;
  transform: translateX(2px);
  text-decoration: none !important;
}

.desktop-action-btn:focus {
  outline: none;
}

.view-grid.table-responsive table.table > thead > tr > th,
.view-grid.table-responsive table.table > tbody > tr > td {
  vertical-align: middle !important;
}


/* K: Stili per i pallini della colonna status, nella lista delle richieste */
.status-dot {
  display: inline-block;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  margin-right: 6px;
  vertical-align: middle;
}


.status-request-sent {
  background-color: #17a2b8;
  color: #fff;
}

.status-in-progress {
  background-color: #fd7e14;
  color: #fff;
}

.status-processed {
  background-color: #28a745;
  color: #fff;
}

.status-error {
  background-color: #dc3545;
  color: #fff;
}

.status-cancelled {
  background-color: #6c757d;
  color: #fff;
}







/* =============================================================================
   K: Impostazioni pagina di login
   ========================================================================== */


/* K: Nasconde le tab di navigazione */
#content-container.signinpage #content .nav.nav-tabs {
  display: none !important;
}

/* K: Background principale */
#content-container.signinpage {
  background: linear-gradient(135deg, var(--background) 0%, #ffffff 100%);
  background-size: cover;
  background-repeat: no-repeat;
  margin-top: 0;
  min-height: 79.2vh;
  display: flex;
  align-items: flex-start;
  justify-content: center;
  padding-top: 0;
  padding-bottom: 0;
  flex: 1 0 auto;
  place-items: center;
}

/* K: Centratura del container principale */
#content-container.signinpage #content {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  display: flex;
  justify-content: center;
  align-items: center;
  min-height: unset;
}

/* K: Page content centratura */
#content-container.signinpage .page-content {
  width: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 0;
}

/* K: Card principale del form di login */
#content-container.signinpage .page-content .row {
  background: #ffffff;
  border-radius: 12px !important;
  margin: 24px auto;
  padding: 1.75rem 1.5rem !important;
  flex-direction: column;
  justify-content: center;
  box-shadow: 0 8px 25px rgba(0, 0, 0, 0.1);
  border: 1px solid rgba(231, 76, 60, 0.1);
  animation: fadeInUp 0.8s cubic-bezier(0.4, 0, 0.2, 1);
  width: 100%;
  max-width: 500px;
}

/* K: Animazione di ingresso */
@keyframes fadeInUp {
  from {
    opacity: 0;
    transform: translateY(30px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* K: Responsive per desktop */
@media (min-width: 992px) {
  #content-container.signinpage .page-content .row {
    max-width: 500px;
    padding: 3.5rem 3rem !important;
  }
}

/* K: Responsive per tablet */
@media (max-width: 991px) {
  #content-container.signinpage .page-content .row {
    max-width: 450px;
    padding: 2.5rem 2rem !important;
    margin: 2rem auto;
  }
}

/* K: Responsive per mobile */
@media (max-width: 768px) {
  #content-container.signinpage {
    padding: 1rem;
  }
  
  #content-container.signinpage .page-content .row {
    max-width: 100%;
    padding: 2rem 1.5rem !important;
    margin: 1rem auto;
  }
}

/* K: Colonne del form */
#content-container.signinpage .page-content .row .col-md-6 {
  flex: 0 0 100%;
  max-width: 100%;
  width: 100%;
}

#content-container.signinpage .page-content .row .col-md-6:first-child {
  margin-bottom: 30px;
}

/* K: Logo */
#content-container.signinpage .page-content .row::before {
  content: "";
  display: block;
  width: 100px;
  height: 80px;
  background-image: url("/logo.png");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  margin: 0 auto 2rem auto;
  animation: logoFloat 0.8s cubic-bezier(0.4, 0, 0.2, 1) 0.2s both;
}

/* K: Animazione del logo */
@keyframes logoFloat {
  from {
    opacity: 0;
    transform: translateY(-10px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* K: Sottotitolo */
#content-container.signinpage .page-content .row .col-md-6:first-child::before {
  content: "Login with your Microsoft account";
  display: block;
  text-align: center;
  color: #6c757d;
  font-size: 16px;
  margin-bottom: 30px;
  font-family: Roboto, Oxygen, Ubuntu, Cantarell, 'Open Sans', 'Helvetica Neue', sans-serif !important;
  animation: textSlide 0.8s cubic-bezier(0.4, 0, 0.2, 1) 0.6s both;
}

/* K: Animazione del testo */
@keyframes textSlide {
  from {
    opacity: 0;
    transform: translateY(10px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* K: Nasconde il titolo originale */
#content-container.signinpage .page-content .row #external-login-heading {
  display: none !important;
}

/* K: Form fieldset */
#content-container.signinpage .page-content .row .col-md-6 form fieldset {
  position: relative;
  border: none;
  padding: 0;
  margin: 0;
}

/* K: Pulsante Microsoft Entra ID */
#content-container.signinpage .page-content .row .col-md-6 button.btn[name='provider'] {
  margin: 10px auto !important;
  width: 100%;
  padding: 1rem 1.5rem;
  font-size: 1.1rem;
  line-height: 1.5;
  border-radius: 12px;
  flex: 0 0 auto;
  background: var(--primary) !important;
  border-color: var(--primary) !important;
  color: white !important;
  font-family: "Raleway", sans-serif !important;
  font-weight: 600;
  transition: all 0.3s ease;
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
  display: flex;
  align-items: center;
  justify-content: center;
}

/* K: Icona Microsoft nel pulsante */
#content-container.signinpage .page-content .row .col-md-6 button.btn[title*="Microsoft"] {
  background: var(--primary) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 23 23'%3E%3Cpath fill='white' d='M1 1h9v9H1V1zm12 0h9v9h-9V1zM1 13h9v9H1v-9zm12 0h9v9h-9v-9z'/%3E%3C/svg%3E") no-repeat 16px center !important;
  background-size: 20px 20px !important;
  padding-left: 42px !important;
  justify-content: flex-start !important;
}

/* K: Hover del pulsante */
#content-container.signinpage .page-content .row .col-md-6 button.btn[name='provider']:hover {
  border-color: var(--accent) !important;
  transform: translateY(-2px);
  box-shadow: 0 6px 15px rgba(231, 76, 60, 0.3);
}

/* K: Focus del pulsante */
#content-container.signinpage .page-content .row .col-md-6 button.btn[name='provider']:focus {
  outline: none;
  box-shadow: 0 0 0 3px rgba(231, 76, 60, 0.2);
}

/* K: Nasconde messaggi di validazione */
#content-container.signinpage .validation-summary-valid,
#content-container.signinpage .alert {
  display: none !important;
}

/* K: Responsive per mobile piccolo */
@media (max-width: 480px) {
  #content-container.signinpage .page-content .row::before {
    width: 60px;
    height: 60px;
  }
  
  #content-container.signinpage .page-content .row::after {
    font-size: 24px;
  }
  
  #content-container.signinpage .page-content .row .col-md-6 button.btn[name='provider'] {
    padding: 0.875rem 1.25rem;
    font-size: 1rem;
  }
}


/* =============================================================================
   K: Styling paginazione Lista Richieste
   ========================================================================== */

.view-pagination .pagination {
    margin: 0;
}

.view-pagination {
  margin-top: 2rem;
  margin-bottom: 2rem;
  display: flex;
  justify-content: center;
}

.jquery-bootstrap-pagination {
  width: 100%;
  display: flex;
  justify-content: center;
}

.pagination {
  margin: 0;
  padding: 0;
  gap: 8px;
  border-radius: 8px;
  background: white;
  padding: 12px 16px;
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
  border: 1px solid rgba(231, 76, 60, 0.1);
}

.pagination .page-item {
  margin: 0;
}

.pagination .page-link {
  border: none !important;
  background: transparent !important;
  color: var(--text-color) !important;
  font-family: "Raleway", sans-serif !important;
  font-weight: 600 !important;
  padding: 8px 12px !important;
  border-radius: 6px !important;
  transition: all 0.3s ease !important;
  text-decoration: none !important;
  min-width: 40px;
  text-align: center;
}

.pagination .page-item:not(.active):not(.disabled) .page-link:hover {
  background-color: var(--secondary) !important;
  color: var(--accent) !important;
  transform: translateY(-1px);
}

.pagination .page-item.active .page-link {
  background-color: var(--primary) !important;
  color: white !important;
  font-weight: 700 !important;
  box-shadow: 0 2px 4px rgba(231, 76, 60, 0.3);
}

.pagination .page-item.disabled .page-link {
  background-color: transparent !important;
  color: #6c757d !important;
  opacity: 0.5;
  cursor: not-allowed;
}

.pagination .entity-pager-prev-link,
.pagination .entity-pager-next-link {
  font-weight: 700 !important;
  font-size: 14px !important;
}

@media (max-width: 768px) {
  .pagination {
    padding: 8px 12px;
    gap: 4px;
  }
  
  .pagination .page-link {
    padding: 6px 8px !important;
    font-size: 14px !important;
    min-width: 35px;
  }
}

.pagination .page-item .page-link {
  position: relative;
  overflow: hidden;
}

.pagination .page-item .page-link::before {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(90deg, transparent, rgba(231, 76, 60, 0.1), transparent);
  transition: left 0.5s;
}

.pagination .page-item:not(.disabled) .page-link:hover::before {
  left: 100%;
}

/* =============================================================================
   K: Styling cards lista richieste per mobile
   ========================================================================== */

.desktop-view {
  display: block;
}

.mobile-view {
  display: none;
}

.mobile-card {
  background: white;
  border-radius: 12px;
  margin-bottom: 16px;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
  border: 1px solid rgba(231, 76, 60, 0.1);
  overflow: hidden;
  transition: all 0.3s ease;
}

.mobile-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}

.mobile-card-header {
  background: var(--background);
  padding: 12px 16px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  border-bottom: 1px solid rgba(231, 76, 60, 0.1);
}

.mobile-status {
  display: flex;
  align-items: center;
  font-weight: 600;
  font-size: 14px;
}

.mobile-date {
  font-size: 12px;
  color: #6c757d;
  font-weight: 500;
}

.mobile-card-body {
  padding: 16px;
}

.mobile-field {
  margin-bottom: 12px;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.mobile-field:last-child {
  margin-bottom: 0;
}

.mobile-label {
  font-size: 12px;
  font-weight: 600;
  color: var(--accent);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.mobile-value {
  font-size: 14px;
  color: var(--text-color);
  font-weight: 500;
}

.mobile-card-footer {
  padding: 12px 16px;
  background: #f8f9fa;
  border-top: 1px solid rgba(231, 76, 60, 0.1);
}

.mobile-action-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 16px;
  background: var(--primary);
  color: white !important;
  text-decoration: none !important;
  border-radius: 6px;
  font-size: 14px;
  font-weight: 600;
  transition: all 0.3s ease;
  font-family: "Raleway", sans-serif !important;
}

.mobile-action-btn:hover {
  background: var(--accent);
  transform: translateY(-1px);
  text-decoration: none !important;
}

.mobile-action-btn:focus {
  outline: 2px solid var(--primary);
  outline-offset: 2px;
}

.pagination .page-link:focus {
  box-shadow: none !important;
}

@media (max-width: 768px) {
  .desktop-view {
    display: none;
  }
  
  .mobile-view {
    display: block;
  }
  
  .view-grid.table-responsive {
    padding: 0 8px;
  }
  
  .pagination {
    gap: 4px;
    padding: 8px 12px;
  }
  
  .pagination .page-link {
    padding: 6px 10px !important;
    font-size: 14px !important;
    min-width: 36px;
    min-height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
  }
  
  .mobile-action-btn {
    min-height: 44px;
  }
  
  .mobile-card {
    margin-bottom: 20px;
  }
  
  .mobile-value {
    font-size: 15px;
  }
}

@media (hover: none) and (pointer: coarse) {
  .mobile-card:hover {
    transform: none;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
  }
  
  .pagination .page-item:not(.active):not(.disabled) .page-link:hover {
    background-color: transparent !important;
    color: var(--text-color) !important;
    transform: none;
  }
  
  .pagination .page-item:not(.disabled) .page-link:hover::before {
    left: -100%;
  }
}

/* =============================================================================
   K: Messaggio richieste non trovate
   ========================================================================== */

.empty-state-container {
  display: flex;
  justify-content: center;
  align-items: center;
  min-height: 400px;
  padding: 60px 20px;
  background: linear-gradient(135deg, #f8f9fa 0%, #e9ecef 100%);
  border-radius: 12px;
  margin: 20px 0;
  border: 2px dashed #dee2e6;
}

.empty-state-content {
  text-align: center;
  max-width: 500px;
  animation: fadeInUp 0.6s ease-out;
}

.empty-state-icon {
  font-size: 80px;
  color: #6c757d;
  margin-bottom: 24px;
  opacity: 0.7;
}

.empty-state-title {
  font-size: 28px;
  font-weight: 600;
  color: #343a40;
  margin-bottom: 16px;
  line-height: 1.2;
}

.empty-state-description {
  font-size: 16px;
  color: #7d716c;
  margin-bottom: 32px;
  line-height: 1.5;
}

@keyframes fadeInUp {
  from {
    opacity: 0;
    transform: translateY(30px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@media (max-width: 768px) {
  .empty-state-container {
    min-height: 300px;
    padding: 40px 15px;
  }
  
  .empty-state-icon {
    font-size: 60px;
  }
  
  .empty-state-title {
    font-size: 24px;
  }
  
  .empty-state-description {
    font-size: 14px;
  }
  
  .empty-state-actions .btn {
    padding: 10px 24px;
    font-size: 14px;
  }
}

.pva-floating-style {
  display: none;
}




/* =============================================================================
   K: Stilizzazione pagina NUOVA RICHIESTA
   ========================================================================== */

.custom-multiselect-container {
    position: relative;
    width: 100%;
}

.custom-multiselect-trigger {
    display: flex;
    justify-content: flex-start;
    align-items: center;
    cursor: pointer;
    padding: 8px 12px;
    background-color: white;
    border: 1px solid #d1d5db;
    min-height: 34px;
    box-sizing: border-box;
}

.custom-multiselect-trigger .selected-text {
    flex: 1;
    text-align: left;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.custom-multiselect-options {
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    background: white;
    border: 1px solid #d1d5db;
    border-top: none;
    max-height: 200px;
    overflow-y: auto;
    z-index: 1000;
    box-shadow: 0 2px 8px rgba(0,0,0,0.1);
}

.option-item {
    border-bottom: 1px solid #f0f0f0;
}

.option-item:last-child {
    border-bottom: none;
}

.option-label {
    display: flex;
    align-items: center;
    padding: 8px 12px;
    cursor: pointer;
    margin: 0;
    transition: background-color 0.2s ease;
}

.option-label:hover {
    background-color: #f8f9fa;
}

.option-checkbox {
    margin-right: 8px;
    margin-left: 0;
    width: 16px;
    height: 16px;
    accent-color: #0078d4;
    outline: none !important;
    border: none;
}

.option-checkbox:focus {
    outline: none !important;
    box-shadow: none !important;
    border: none !important;
}

.checkmark {
    position: relative;
    margin-right: 8px;
}

.option-text {
    flex: 1;
}

.options-loading,
.no-options,
.error-options {
    padding: 12px;
    text-align: center;
    color: #666;
    font-style: italic;
}

.error-options {
    color: #d32f2f;
}


.lookup.form-control:hover {
    border-color: #0078d4;
    transition: border-color 0.2s ease;
}

.lookup.form-control:focus {
    outline: none;
    border-color: #0078d4;
    box-shadow: 0 0 0 1px rgba(0, 120, 212, 0.3);
}

.form-control {
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

@media (max-width: 768px) {
    .custom-multiselect-container {
        position: relative !important;
        overflow: visible !important;
    }
    
    .custom-multiselect-options {
        position: absolute !important;
        left: 0 !important;
        right: 0 !important;
        width: 100% !important;
        max-height: 50vh !important;
        z-index: 9999 !important;
        border-radius: 0 0 8px 8px !important;
        box-shadow: 0 4px 16px rgba(0, 0, 0, 0.15) !important;
        border: 1px solid #d1d5db !important;
        border-top: 1px solid #d1d5db !important;
        margin-top: 0px !important;
    }
    
    .custom-multiselect-trigger {
        min-height: 37px !important;
        padding: 12px 12px !important;
        font-size: 14px !important;
        border-radius: 8px !important;
    }
    
    .custom-multiselect-trigger[aria-expanded="true"] {
        border-color: #0078d4 !important;
        box-shadow: 0 0 0 2px rgba(0, 120, 212, 0.3) !important;
        border-radius: 8px !important;
        border-bottom-color: #0078d4 !important;
    }
    
    .option-label {
        min-height: 44px !important;
        padding: 12px 12px !important;
        font-size: 14px !important;
    }
    

    .textarea.form-control-cell,
    .control,
    .file-and-actions-container {
        overflow: visible !important;
    }
}

#cps_userprompt {
    min-height: 150px !important; 
    resize: vertical;
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    font-size: 14px;
    line-height: 1.5;
    padding: 12px;
    border-radius: 4px;
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
    width: 100% !important;
    box-sizing: border-box;
}


#cps_userprompt:focus {
    outline: none;
    border-color: #0078d4;
    box-shadow: 0 0 0 2px rgba(0, 120, 212, 0.3);
}

#cps_userprompt:hover {
    border-color: #0078d4;
    transition: border-color 0.2s ease;
}


.textarea.form-control {
    width: 100% !important;
    box-sizing: border-box;
}


@media (max-width: 768px) {
    #cps_userprompt {
        min-height: 100px;
        font-size: 16px;
        padding: 10px;
    }
    
    
    .textarea.form-control-cell {
        width: 100% !important;
        overflow-x: hidden;
    }
}

@media (max-width: 480px) {
    #cps_userprompt {
        min-height: 80px;
        padding: 8px;
    }
}


@media (min-width: 769px) and (max-width: 1024px) {
    #cps_userprompt {
        min-height: 140px;
    }
}


@media (min-width: 1025px) {
    #cps_userprompt {
        min-height: 160px;
    }
}


.entity-form table[role="presentation"] {
    width: 100%;
    table-layout: fixed;
}


.entity-form table[role="presentation"] td[colspan="3"] {
    width: 100% !important;
    max-width: 100%;
    overflow-wrap: break-word;
}


.auto-resize-textarea {
    overflow: hidden;
    resize: none;
}


/* =============================================================================
   K: Stilizzazione pulsante INVIA
   ========================================================================== */
.submit-button-wrapper {
    position: relative !important;
    display: inline-block !important;
}

#InsertButton {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    border-radius: 8px !important;
    padding: 12px 20px !important;
    min-width: 120px !important;
    width: auto !important;
    background-color: #000000 !important;
    border: 2px solid #000000 !important;
    color: #ffffff !important;
    font-family: "Raleway", sans-serif !important;
    font-weight: 600 !important;
    font-size: 14px !important;
    cursor: pointer !important;
    transition: all 0.3s ease !important;
    outline: none !important;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2) !important;
    position: relative !important;
    z-index: 1 !important;
    float: none !important;
    margin: 0 !important;
    height: 44px !important;
    box-sizing: border-box !important;
}

#InsertButton:hover {
    background-color: #333333 !important;
    border-color: #333333 !important;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.3) !important;
    transform: translateY(-1px) !important;
}

#InsertButton:focus {
    outline: 2px solid #000000 !important;
    outline-offset: 2px !important;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.3), 0 0 0 3px rgba(0, 0, 0, 0.4) !important;
}

#InsertButton:active {
    transform: translateY(0) !important;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1) !important;
}

#InsertButton:disabled {
    background-color: #666666 !important;
    border-color: #666666 !important;
    cursor: not-allowed !important;
    transform: none !important;
}

.form-action-container-left {
    float: none !important;
}


@media (max-width: 768px) {
    #InsertButton {
        min-width: 120px !important;
        height: 40px !important;
        padding: 10px 16px !important;
        font-size: 13px !important;
    }
}

@media (max-width: 480px) {
    #InsertButton {
        width: 100% !important;
        justify-content: center !important;
        min-width: unset !important;
    }
}




/* =============================================================================
   K: Stilizzazione pulsante upload file
   ========================================================================== */

.buttonForFileUpload {
    position: relative;
    display: flex;
    align-items: center;
    gap: 8px;
    margin: 16px 0;
}

#UploadButton {
    display: flex !important;
    align-items: center !important;
    justify-content: flex-start !important;
    gap: 10px !important;
    width: auto !important;
    min-width: 140px !important;
    height: 44px !important;
    padding: 12px 20px !important;
    background-color: #ffffff !important;
    color: #000000 !important;
    border: 1px solid #e0e0e0 !important;
    font-family: "Raleway", sans-serif !important;
    font-weight: 600 !important;
    font-size: 14px !important;
    line-height: 1.4 !important;
    text-decoration: none !important;
    border-radius: 8px !important;
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.1) !important;
    cursor: pointer !important;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
    outline: none !important;
    -webkit-appearance: none !important;
    -moz-appearance: none !important;
    appearance: none !important;
}

#UploadButton .fa {
    font-family: "FontAwesome" !important;
    font-weight: 900 !important;
    font-size: 16px !important;
    color: #666666 !important;
    transition: color 0.3s ease !important;
}


#UploadButton .fa-arrow-up::before {
    content: "\f0c6" !important;
}

#UploadButton:hover {
    background-color: #f8f9fa !important;
    border-color: #d1d5db !important;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15) !important;
    transform: translateY(-1px) !important;
}

#UploadButton:hover .fa {
    color: #333333 !important;
}

#UploadButton:focus {
    outline: 2px solid #0078d4 !important;
    outline-offset: 2px !important;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15), 0 0 0 3px rgba(0, 120, 212, 0.3) !important;
}

#UploadButton:active {
    transform: translateY(0) !important;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1) !important;
}

#UploadButton:disabled {
    background-color: #f5f5f5 !important;
    color: #999999 !important;
    border-color: #e0e0e0 !important;
    cursor: not-allowed !important;
    transform: none !important;
    box-shadow: none !important;
}

#UploadButton:disabled .fa {
    color: #cccccc !important;
}

.table-info {
    margin-bottom: 12px;
}

#NewAttachFileLabel {
    font-family: "Raleway", sans-serif !important;
    font-weight: 600 !important;
    font-size: 16px !important;
    color: var(--primary, #E74C3C) !important;
    margin-bottom: 6px !important;
    display: block;
}

.table-info {
    font-family: "Raleway", sans-serif !important;
    font-size: 14px !important;
    color: #666666 !important;
    line-height: 1.4;
}

@media (max-width: 768px) {
    #UploadButton {
        min-width: 120px !important;
        height: 40px !important;
        padding: 10px 16px !important;
        font-size: 13px !important;
    }
    
    #UploadButton .fa {
        font-size: 14px !important;
    }
    
    .buttonForFileUpload {
        margin: 12px 0;
    }
}

@media (max-width: 480px) {
    #UploadButton {
        width: 100% !important;
        justify-content: center !important;
        min-width: unset !important;
    }
}

.buttonForFileUpload .errordiv {
    margin-top: 8px !important;
    border-radius: 6px !important;
    font-family: "Raleway", sans-serif !important;
    font-size: 13px !important;
}

#UploadButton.loading {
    position: relative;
    color: transparent !important;
}

#UploadButton.loading::after {
    content: "";
    position: absolute;
    top: 50%;
    left: 50%;
    width: 16px;
    height: 16px;
    margin: -8px 0 0 -8px;
    border: 2px solid #e0e0e0;
    border-top-color: #666666;
    border-radius: 50%;
    animation: uploadSpinner 0.8s linear infinite;
}

@keyframes uploadSpinner {
    from {
        transform: rotate(0deg);
    }
    to {
        transform: rotate(360deg);
    }
}

.file-cell .buttonForFileUpload #UploadButton {
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.1) !important;
}

#UploadButton[aria-label] {
    position: relative;
}

.custom-multiselect-container ~ .buttonForFileUpload #UploadButton,
.form-control ~ .buttonForFileUpload #UploadButton {
    margin-top: 8px;
}

.table-info {
    display: block !important;
}

.file-cell .table-info {
    display: none !important;
}

.ContainerForFile ~ .table-info,
.ContainerForFile + .table-info {
    display: none !important;
}

.tr .file-cell .table-info {
    display: none !important;
}

.field-label,
.col-form-label,
label:not(#NewAttachFileLabel) {
    display: block !important;
}

#NewAttachFileLabel {
    display: none !important;
}

div[class*="file"] .table-info,
.file-upload-container .table-info {
    display: none !important;
}


/* =============================================================================
   K: Stilizzazione area caricamento file
   ========================================================================== */
.file-and-actions-container {
    background-color: #F6F7F9 !important;
    border-radius: 8px;
    padding-top: 0px;
    padding-left: 15px;
    padding-right: 15px;
    padding-bottom: 0px;
    margin: 0px 0;
    width: 100%;
    box-sizing: border-box;
    display: grid !important;
    grid-template-columns: auto 1fr auto;
    grid-template-rows: auto auto auto;
    grid-template-areas: 
        "info info info"
        "upload empty submit"
        "files files files";
    align-items: center;
}


.file-and-actions-container .table-info {
    grid-area: info;
    margin: 0 0 10px 0;
    align-self: start;
}

.file-and-actions-container .ContainerForFile {
    grid-area: upload;
    justify-self: start;
    align-self: center;
}

.file-and-actions-container .submit-button-wrapper {
    grid-area: submit;
    justify-self: end;
    margin: 0 !important;
    align-self: center;
}

.file-and-actions-container .file-info {
    grid-area: files;
    justify-self: start;
    margin: 0 0 0px 0;
    max-width: 400px;
    align-self: start;
    padding: 0px
}


.file-and-actions-container .custom-button {
    background-color: #ffffff !important;
    box-shadow: rgba(0, 0, 0, 0.08) 0px 2px 4px 0px !important;
    border-radius: 6px;
    padding: 14px 16px;
    min-height: 65px;
    width: 100%;
    display: flex;
    align-items: center;
    transition: all 0.2s ease;
    border: 1px solid #e1e5e9;
    margin-bottom: 15px;
}

.file-and-actions-container .custom-button:hover {
    background-color: #f8f9fa !important;
    box-shadow: rgba(0, 0, 0, 0.12) 0px 3px 6px 0px !important;
    border-color: #d0d7de;
}


.file-and-actions-container .fileNameAndSizeSpan {
    display: flex !important;
    align-items: center;
    gap: 12px;
    margin: 0 !important;
    width: 100%;
    flex: 1;
}

.file-and-actions-container .fileicon {
    width: 32px;
    height: 32px;
    flex-shrink: 0;
}

.file-and-actions-container .filename {
    flex: 1;
    font-size: 14px;
    font-weight: 500;
    color: #323130 !important;
    text-decoration: none !important;
    cursor: default !important;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    min-width: 0;
}


.file-and-actions-container .deleteicondiv,
.file-and-actions-container .cancelIconDiv,
.file-and-actions-container .loadericondiv,
.file-and-actions-container .retrySpan {
    background: none !important;
    border: none !important;
    padding: 8px;
    border-radius: 4px;
    transition: background-color 0.2s ease;
    flex-shrink: 0;
    cursor: pointer;
}

.file-and-actions-container .deleteicondiv:hover,
.file-and-actions-container .cancelIconDiv:hover,
.file-and-actions-container .retrySpan:hover {
    background-color: rgba(0, 0, 0, 0.05) !important;
}

.file-and-actions-container .deleteicon,
.file-and-actions-container .cancelicon {
    width: 16px;
    height: 16px;
}

.file-and-actions-container .retrySpan {
    font-size: 12px;
    color: #0078d4;
    text-decoration: none;
    font-weight: 500;
    padding: 6px 8px;
}


.file-and-actions-container .ContainerForFile > .progress-container {
    display: none;
}


@media (max-width: 768px) {
    .file-and-actions-container {
        grid-template-columns: 1fr;
        grid-template-areas: 
            "info"
            "upload"
            "submit"
            "files";
        gap: 15px;
    }
    
    .file-and-actions-container .ContainerForFile,
    .file-and-actions-container .submit-button-wrapper {
        justify-self: stretch;
    }
    
    .file-and-actions-container .file-info {
        max-width: 100%;
    }
    
    .file-and-actions-container .custom-button {
        min-height: 55px;
        padding: 12px 14px;
    }
}


.file-and-actions-container .custom-button:focus-within,
.file-and-actions-container .deleteicondiv:focus,
.file-and-actions-container .cancelIconDiv:focus,
.file-and-actions-container .retrySpan:focus {
    outline: 2px solid #0078d4;
    outline-offset: 2px;
}


/* =============================================================================
   K: Form dettaglio richiesta
   ========================================================================== */

.form-readonly .form-control:focus,
.form-readonly .textarea.form-control:focus,
.form-readonly textarea:focus,
.form-readonly input:focus,
.form-readonly select:focus,
.form-readonly .lookup:focus,
.entity-form.form-readonly .form-control:focus {
    outline: none !important;
    border-color: inherit !important;
    box-shadow: none !important;
    -webkit-box-shadow: none !important;
    -moz-box-shadow: none !important;
}

.subgrid-cell {
    padding: 0px 15px 15px 15px !important;
    background-color: #fdfdfd;
    border: 1px solid #e9ecef;
    border-radius: 8px;
    margin-bottom: 25px !important;
    display: block;
}

.subgrid-cell .view-grid table {
    display: none;
}

.subgrid-cell .custom-file-list {
    display: flex;
    flex-wrap: wrap;
    gap: 15px;
    margin-top: 15px;
}

.subgrid-cell .form-subgrid-heading {
    font-family: "Raleway", sans-serif !important;
    font-weight: 600 !important;
    margin-bottom: 15px !important;
    display: flex;
    align-items: center;
    gap: 15px;
}

.subgrid-cell .form-subgrid-heading .field-label {
    font-size: 1.25rem !important;
    font-weight: 600 !important;
    flex-shrink: 0;
}

.subgrid-cell .form-subgrid-heading::after {
    content: '';
    flex-grow: 1;
    height: 1px;
    background-color: #e9ecef;
}

.custom-file-card {
    background-color: #ffffff !important;
    box-shadow: rgba(0, 0, 0, 0.06) 0px 2px 4px 0px !important;
    border-radius: 8px;
    padding: 14px 16px;
    min-height: 65px;
    display: flex !important;
    align-items: center;
    gap: 12px;
    transition: all 0.2s ease;
    border: 1px solid #e1e5e9;
    text-decoration: none !important;
    width: 100%;
    box-sizing: border-box;
}

.custom-file-card:hover {
    background-color: #f8f9fa !important;
    box-shadow: rgba(0, 0, 0, 0.1) 0px 4px 8px 0px !important;
    border-color: #0078d4;
    transform: translateY(-2px);
}

.custom-file-card .file-icon {
    width: 32px;
    height: 32px;
    flex-shrink: 0;
}

.custom-file-card .file-name {
    flex: 1;
    font-size: 14px;
    font-weight: 500;
    color: #323130 !important;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}


#sezioneDocumentiInput .custom-file-list .file-item-wrapper {
    width: 100%;
}

#sezioneDocumentiOutput .custom-file-list {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 15px;
}

@media (max-width: 768px) {
    #sezioneDocumentiOutput .custom-file-list {
        grid-template-columns: 1fr;
    }
}

.subgrid-cell .view-empty .alert {
    background-color: #f8f9fa !important;
    border: 2px dashed #e0e0e0 !important;
    color: #6c757d !important;
    text-align: center;
    padding: 40px 20px !important;
    border-radius: 8px;
    box-shadow: none !important;
    margin-top: 15px;
    font-family: "Raleway", sans-serif !important;
    font-size: 14px;
    font-weight: 500;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 10px;
}

.subgrid-cell .view-empty .alert::before {
    font-family: "FontAwesome" !important;
    content: "\f07c";
    font-size: 24px;
    color: #ced4da;
}


.cell.picklist-cell:has(#cps_status) .table-info {
    display: none !important;
}

.cell.picklist-cell:has(#cps_status) {
    padding-top: 15px !important;
    padding-bottom: 60px !important;
    border-bottom: none !important;
}

#cps_status.aspNetDisabled {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    display: block !important;
    width: 100% !important;
    background-color: #f8f9fa !important;
    color: #343a40 !important;
    border: 1px solid #dee2e6 !important;
    border-radius: 8px !important;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.03);
    height: 50px !important;
    line-height: 50px !important;
    padding: 0 20px !important;
    font-family: "Raleway", sans-serif !important;
    font-weight: 600 !important;
    font-size: 16px !important;
    text-align: center;
    letter-spacing: 0.5px;
    opacity: 1 !important;
    cursor: default !important;
}

#cps_status.aspNetDisabled::-ms-expand {
    display: none;
}


#cps_status.status-processed {
    background-color: #e7f5ec !important;
    color: #0a6847 !important;
    border-color: #a4d4be !important;
}

#cps_status.status-in-progress {
    background-color: #eaf2ff !important;
    color: #0052cc !important;
    border-color: #b3d4ff !important;
}

#cps_status.status-sent {
    background-color: #fff8e1 !important;
    color: #f57c00 !important;
    border-color: #ffecb3 !important;
}

#cps_status.status-error {
    background-color: #fbe9e7 !important;
    color: #c62828 !important;
    border-color: #ffcdd2 !important;
}

.textarea.form-control.readonly.readonly-text-div {
  white-space: pre-wrap;
  word-break: break-word;
  height: auto !important;
}


/*K: Stili per ordinamento richieste su homepage */
.sortable-header {
  position: relative;
}

.sortable-header:hover {
  background-color: #f8f9fa;
}

.sort-arrow {
  margin-left: 5px;
  font-size: 12px;
  opacity: 1;
}

.sort-neutral {
  opacity: 0.5;
}

.sortable-header:hover .sort-neutral {
  opacity: 0.8;
}

.mobile-sort-controls {
  margin-bottom: 15px;
  padding: 10px;
  background-color: #f8f9fa;
  border-radius: 4px;
  border: 1px solid #dee2e6;
}

.mobile-sort-header {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

.mobile-sort-label {
  font-weight: 600;
  color: #495057;
  white-space: nowrap;
}

.mobile-sort-buttons {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

.mobile-sort-btn {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 6px 12px;
  background-color: #fff;
  border: 1px solid #ced4da;
  border-radius: 4px;
  font-size: 14px;
  color: #495057;
  cursor: pointer;
  transition: all 0.2s ease;
  position: relative;
}

.mobile-sort-btn:hover {
  background-color: #f8f9fa;
  border-color: #adb5bd;
}

.mobile-sort-btn:active {
  background-color: #e9ecef;
  transform: translateY(1px);
}

.mobile-sort-arrow {
  margin-left: 4px;
  font-size: 12px;
  color: #007bff;
  opacity: 1;
}

.mobile-sort-neutral {
  color: #6c757d;
  opacity: 0.5;
}

.mobile-sort-btn:hover .mobile-sort-neutral {
  opacity: 0.8;
}

@media (min-width: 768px) {
  .mobile-sort-controls {
    display: none !important;
  }
}