/* luca */
:root{
  --navy:#050d42;
  --header:#050d42;
  --navy-light:#0B1F3F;
  --bg:#fff;
  --bglogin:#f2f6fa;
  --card-bg:#edf1f7;
  --sidebar-bg:#ededed;
  --icon:#cc0000;
  --radius:6px;
  --shadow-sm:0 1px 3px rgba(0,0,0,.06);
  --shadow-lg:0 2px 6px rgba(0,0,0,.10);
  --toolbar:#e2e2e2;
  --btn:#050d42;
  --danger:#cc0000;

  --cell-bg:#ffffff;
  --weekend-bg:#f5f7f9;
  --thisweek-bg:#ffeeba;
  --border:#c9d1de;
  --radius:6px;
  --shadow:0 2px 6px rgba(0,0,0,.10);
  --azienda:#cc0000;     /* blu    */
  --pubblico:#048421;     /* verde  */
  --generali:#e045a9; /* fucsia */
  --commerciali:#03fd44;  /* rosso  */
  --promemoria:#04e2fc;  /*azzurro */
  --sede:#c9f7fc;
  --daconfermare:#ff45a9;
}
*,*::before,*::after{box-sizing:border-box}
body{margin:0;font-family:"Montserrat",Arial,sans-serif;background:var(--bg);color:#101828;display:flex;flex-direction:column;min-height:100vh}
body.blogin{background:var(--bglogin)}
ul{margin:0;padding:0;list-style:none}
a{color:inherit;text-decoration:none}
a:hover{opacity:0.7}

/* ---------- HEADER ---------- */
header{
  display:grid;
  grid-template-columns:1fr auto 1fr;   /* logo | titolo | user */
  align-items:center;
  background:var(--header);
  color:#fff;
  padding:.75rem 1.5rem;
}
header a{
  color:#fff;
}
.logo{justify-self:start;}
.logo img{width:160px}
.header-title{
  justify-self:center;
  margin:0;
  font-size:1rem;
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:.04em;
}
.user-area{justify-self:end;display:flex;align-items:center;gap:.75rem}
.user-info{display:flex;flex-direction:column;text-align:right;line-height:1}
.user-info .role{font-size:.75rem;font-weight:600;text-transform:uppercase}
.user-info .name{font-size:.75rem;font-weight:500}
.user-area i{font-size:1.2rem;cursor:pointer}
/* dropdown profilo */
.profile{position:relative;display:inline-flex}
.user-menu{
  position:absolute;right:0;top:calc(100% + .13rem);
  background:#fff;border:1px solid #d0d5dd;border-radius:6px;
  box-shadow:0 2px 6px rgba(0,0,0,.12);
  display:none;flex-direction:column;min-width:200px;z-index:10
}
.user-menu a{padding:.6rem .9rem;font-size:.85rem;font-weight:500;white-space:nowrap;color:#333}
.user-menu a:hover{background:#f0f2f5}
.user-area:hover .user-menu{display:flex}

/* ---------------- LAYOUT ---------------- */
main{flex:1 1 auto;display:flex;overflow:hidden;justify-content: center; }
main.login{padding: 2rem 1rem;align-items: center;}
main.tabella,main.modifica{padding:1.5rem}

.dashboard{flex:1 1 0;padding:1.5rem;overflow:hidden}
.grid{height:100%;display:grid;grid-template-columns:2fr 1.15fr;grid-template-rows:repeat(3,1fr);gap:1.5rem}

/* ---------------- CARD ------------------ */
.dashboard .card{
  background:var(--card-bg);border-radius:var(--radius);
  box-shadow:var(--shadow-lg);display:flex;flex-direction:column;min-height:0
}
.card-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem .75rem;font-weight:600;position:relative}
.card-header::after{content:"";position:absolute;left:1.5rem;right:1.5rem;bottom:0;height:1px;background:var(--navy-light)}
.card-header span{color:var(--navy);}
.card-header i{color:var(--icon)}
.card-body{padding:1rem 1.5rem 1.5rem;overflow-y:auto;font-size:.9rem;display:flex;flex-direction:column;gap:.5rem}
.card-body a{font-weight:500}
.card:hover{box-shadow:0 4px 12px rgba(0,0,0,.14)}
.card-form {
  max-width: 900px;
  margin-inline: auto;
}
/* LOGIN */
.login .card {
  background: #fff;
  border-radius: var(--radius);
  box-shadow: var(--shadow-lg);
  width: 100%;
  max-width: 380px;
  display: flex;
  flex-direction: column;
}
.login .card-header {
  padding: 1.25rem 1.5rem .75rem;
  font-weight: 600;
  font-size: 1.1rem;
  text-align: center;
  display: block;
  background: none;
}
.login .card-header::after{background:none}

.card-control {
  padding: .375rem;
  border: var(--bs-border-width) solid var(--bs-border-color);
  border-radius: var(--bs-border-radius);
}

/* GRID PLACEMENT */
#team-interno{grid-column:1/2;grid-row:1/4}
#commerciale {grid-column:2/3;grid-row:1/2}
#docente     {grid-column:2/3;grid-row:2/3}
#partecipanti{grid-column:2/3;grid-row:3/4}

/* ---------------- SIDEBAR -------------- */
.sidebar{flex:0 0 260px;max-width:260px;background:var(--sidebar-bg);padding:1.5rem 1rem;overflow-y:auto;display:flex;flex-direction:column}
.sidebar h3{font-size:1rem;font-weight:600;margin-bottom:1rem;display:flex;justify-content:space-between;align-items:center;position:relative}
.sidebar h3::after{content:"";position:absolute;left:0;right:0;bottom:-.5rem;height:1px;background:var(--navy-light)}
.sidebar h3 i{color:var(--icon)}
.sidebar ul{margin-top:.5rem;display:flex;flex-direction:column;gap:.4rem;font-size:.9rem}
.sidebar ul li{font-weight:500}

/* ---------------- FOOTER --------------- */
footer{background:var(--navy);color:#fff;font-size:.75rem;text-align:center;padding:.5rem 1rem}

/* -------------- RESPONSIVE ------------- */
@media(max-width:960px){
  .grid{grid-template-columns:1fr}
  #team-interno{grid-column:1/2;grid-row:auto}
  
}

/* -------- ROLE VISIBILITY (già presente) */
.role-commercial #team-interno,
.role-commercial #docente,
.role-commercial #partecipanti{display:none}
.role-docente #team-interno,
.role-docente #commerciale,
.role-docente #partecipanti{display:none}
.role-partecipante #team-interno,
.role-partecipante #commerciale,
.role-partecipante #docente{display:none}
.role-commercial .grid,
.role-docente .grid,
.role-partecipante .grid{grid-template-columns:1fr}

/* FORM  */
.input-group{display:flex;flex-direction:column;gap:.25rem;margin-bottom:1.1rem}
.login label{font-size:.85rem;font-weight:600;text-transform:uppercase}
.login input{
  padding:.6rem .75rem;
  border:1px solid #d0d5dd;
  border-radius:var(--radius);
  font-size:.95rem;
}
input:focus{outline:2px solid var(--navy-light);outline-offset:1px}

.btn-login{
  width:100%;
  padding:.65rem .75rem;
  border:none;
  border-radius:var(--radius);
  background:var(--navy);
  color:#fff;
  font-size:.95rem;
  font-weight:600;
  cursor:pointer;
  transition:opacity .15s;
}
.btn-login:hover{opacity:.9}


/*  TOOLBAR  */
.toolbar{
  position:relative;             
  background:var(--toolbar);
  padding:1rem;
  display:flex;
  justify-content:center;         
  align-items:center;
  flex-wrap:wrap;
}
.toolbar-title{
	font-weight:600;
	font-size:.9rem;
	text-transform:uppercase;
}

/* wrapper con i pulsanti, appoggiato a destra */
.toolbar-actions{
  position:absolute;
  right:1rem;
  top:50%;
  transform:translateY(-50%);
  display:flex;
  gap:.75rem;
}

/* bottoni */
.btn-ig{
  background:var(--btn);
  color:#fff;
  border:none;
  border-radius:6px;
  padding:.45rem .9rem;
  font-size:.8rem;
  font-weight:600;
  display:inline-flex;align-items:center;gap:.35rem;
  cursor:pointer;
  transition:opacity .15s;
  text-decoration: none;
  text-wrap: nowrap;
}
.btn-ig:hover{opacity:.9}
.btn-ig.outline{
  background:#fff;
  color:var(--btn);
  border:2px solid var(--btn);
}
.btn-ig.noflex{
  display:inline;
}
.btn-ig.danger{background:var(--danger);color:#fff}               /* ← rosso cancella */
.btn-ig.danger:hover{opacity:.9}

/*  TABELLA  */

table.dataTable thead th{
  background:#eef3f9 !important;
  color:#050d42;
  vertical-align:middle;
}
#consultants   {font-size:.78rem}
#consultants td{padding:.30rem .5rem}
.table-hover tbody tr:hover{background:#e9f4ff}

/* azioni */
td.actions{text-align:center}
td.actions a{margin:0 .3rem;font-size:1rem;color:var(--navy)}
td.actions a:hover{opacity:.7}

/* filtri colonna */
.column-filter{
  width:100%;
  font-size:.8rem;
  padding:.15rem .35rem;
  border:1px solid #ced4da;
  border-radius:.25rem;
}
/* modifica */
.modifica input{border-color:var(--border)}

.form-label {
  font-weight: 600;
}
.form-par {
  font-weight: 600;
  box-shadow: var(--bs-box-shadow-sm) !important;
}
.msg {
  font-weight: 600;
  text-align: center;
  color: var(--danger);
}
main.modifica{flex-wrap: wrap;}
.modifica .form-select{
	max-width:550px;
	display: inline;
	padding: .375rem;
	font-size: 0.9rem;
	font-weight: 400;
	line-height: 1;
	color: var(--bs-body-color);
	background-color: var(--weekend-bg);
	background-clip: padding-box;
	border: var(--bs-border-width) solid var(--bs-border-color);
	border-radius: var(--bs-border-radius);
	transition: border-color .15s ease-in-out,box-shadow .15s ease-in-out;
}
.modifica .form-select.size2{
	width:4em;
}
input[readonly].form-control{
	background-color: var(--weekend-bg);
}
.modifica tr.trdati{
  box-shadow: var(--bs-box-shadow-sm) !important;
}
.modifica td.tdlabel{
  vertical-align: top;
}
.modifica td{
  padding-top: 0.3rem;
}
.modifica .card{
  min-width:800px;
  flex: 1 1;
}
.modifica .form-control{
  width: auto;
  max-width: 100%;
  font-size: .9rem;
}
.modifica textarea.form-control{
  width: 100%;
}
.modifica textarea.form-control.noflex{
  width: 80%;
  display:inline;
}

.modifica input[type=text].form-control, .modifica input[type=password].form-control{
	display: inline;
}
#lato{
	background: var(--card-bg);
	display: flex;
	min-width:800px;
}
#lato legend, fieldset.rubrica legend{
	float: none;
	width: auto;
	padding: 0 1em;
	background: var(--card-bg);
	border: var(--bs-card-border-width) solid var(--bs-card-border-color);
	border-radius: var(--bs-
	card-border-radius);
	font-size: 1em;
}
span.help{font-size:.8rem;font-style:italic;}

.preview-img {
  max-width: 110px;
  max-height: 110px;
  border-radius: var(--radius);
  border: 1px solid #ddd;
}
.modifica fieldset{
  padding:.6rem 1rem;
  border:1px solid var(--border);
}

/*  FILTER BAR (mesi & docente) */
.filterbar{
  background:#f6f8fb;           /* diverso dal grigio della toolbar  */
  padding:.6rem 1rem;
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  align-items:center;
  gap:.75rem;
  border-bottom:1px solid var(--border);
  font-size:.8rem;
}
.filterbar form{
  margin:0;
}
.filterbar select{
  font-family:inherit;
  font-size:.8rem;
  padding:.25rem .4rem;
  border:1px solid var(--border);
  border-radius:var(--radius);
  background:#fff;
  cursor:pointer;
}
.filterbar input[type=text]{
  font-family:inherit;
  font-size:.8rem;
  padding:.25rem .4rem;
  border:1px solid var(--border);
  border-radius:var(--radius);
  background:#fff;
  cursor:pointer;
}
.filterbar a{
  font-weight:600;
  color:var(--btn);
  text-decoration:none;
}
.filterbar a:hover{text-decoration:underline}
.current-month{font-weight:700;color:#fff;font-size:1rem;background:var(--navy);padding:.5rem;border-radius:.4rem}

.filterbar fieldset{
  background:#f6f8fb;
  padding:.6rem 1rem;
  display:inline;
  border:1px solid var(--border);
}


/*  CALENDARIO GRID  */
.calendar-wrapper{
  flex:1 1 auto;
  padding:1rem;                 
}
.calendar{
  width:100%;
  display:grid;
  grid-template-columns:repeat(7,1fr);
  grid-template-rows:30px repeat(6,minmax(120px,auto));
  border-top:1px solid var(--border);
  border-left:1px solid var(--border)
}
.day{
  position:relative;
  padding:.25rem;              /* micro-padding globale  */
}
.day-name,
.day{
  border-right:1px solid var(--border);
  border-bottom:1px solid var(--border);
  background:var(--cell-bg)
}
.day-name{
  background:#0f54a3;
  color:#fff;
  font-size:.75rem;
  font-weight:600;
  height:30px;                
  padding:0 .25rem;           
  display:flex;               
  align-items:center;
  justify-content:center;
}

.day[data-weekend="true"]{background:var(--weekend-bg)}
.day[data-thisweek="true"]{background:var(--thisweek-bg)}
.day-num{font-weight:600;font-size:.8rem;margin-bottom:.15rem}
.day-body{overflow:auto}
.event{
  position:relative;
  background:#fff;
  border-radius:4px;
  box-shadow:var(--shadow);
  padding:.24rem .5rem .28rem .66rem;
  margin-bottom:.32rem;
  font-size:.73rem
}
.event::before{
  content:"";
  position:absolute;
  left:0;
  top:0;
  bottom:0;
  width:4px;
  border-radius:4px 0 0 4px
}
.event.pubblico::before{background:var(--pubblico)}
.event.commerciali::before{background:var(--commerciali)}
.event.azienda::before{background:var(--azienda)}
.event.generali::before{background:var(--generali)}
.event.promemoria::before{background:var(--promemoria)}
	
.event.sede{background-color:var(--sede);} /* BG diverso per eventi in sede */
	
.event span{font-size:.65rem;margin-bottom:.04rem}
.ev-title{font-weight:600;font-size:.68rem;margin-bottom:.06rem}

.admin-link{font-size:.6rem;
	font-weight:normal;}
.ev-time{font-size:.68rem;}
.ev-details{font-size:.68rem;
font-style:italic;
padding-top:.1rem}
	
.areaverde { color: var(--pubblico); }
.arearossa { color: var(--daconfermare); }
.areablu { color: var(--promemoria); }

/* LEGENDA */
.legend{
  margin:1rem 0 0;               
  padding:0;
  display:flex;
  gap:1.25rem;                  
  list-style:none;
  font-size:.78rem;
  align-items:center;
  flex-wrap:wrap;  
  justify-content:flex-end; 
}

.legend-item{
  display:flex;
  align-items:center;
  gap:.35rem;                   
}

.legend-dot{
  width:10px;
  height:10px;
  border-radius:50%;
  display:inline-block;
}
.legend-square{
  width:10px;
  height:10px;
  display:inline-block;
}
.legend-line{
  width:10px;
  height:5px;
  display:inline-block;
}

/* collegamento pallino → variabile colore */
.dot-generali     {background:var(--generali)}
.dot-azienda      {background:var(--azienda)}
.dot-pubblico     {background:var(--pubblico)}
.dot-commerciali  {background:var(--commerciali)}
.dot-promemoria     {background:var(--promemoria)}
.dot-sede     {background:var(--sede)}
.dot-daconfermare     {background:var(--daconfermare)}

/* dicono */
.testoboldbianco {
  FONT-SIZE: 12px;
  MARGIN: 0px;
  COLOR: #FFFFFF;
  FONT-FAMILY: Verdana, Arial, Helvetica, sans-serif;
  TEXT-DECORATION: none;
  font-weight: bold;
}
.testosize2 {
  FONT-SIZE: 12px;
  MARGIN: 0px;
  COLOR: #2B3D26;
  FONT-FAMILY: Verdana, Arial, Helvetica, sans-serif;
  TEXT-DECORATION: none;
}
.trvalutaz{
  border-bottom:1px solid var(--border);
  background:var(--cell-bg)
}
ul.ultesto{
	list-style: inside;
}
.areatitoloscheda {
  font-weight: bold;
}
span.nolink {
  COLOR: #777;
}











