/* Reperibilità C.S.T. - Nuova sezione (v1) */

body.reperibilita-page {
	background: #f5f5f5;
	margin: 0;
	padding: 0;
	font-family: Arial, Helvetica, sans-serif;
}

.reperibilita-wrapper {
	max-width: 1400px;
	margin: 0 auto;
	padding: 18px 16px 40px 16px;
}

.reperibilita-header {
	margin-bottom: 18px;
}
.reperibilita-header h1 {
	margin: 4px 0 14px 0;
	color: #007bff;
	font-size: 26px;
	text-align: center;
}
.reperibilita-header-info {
	display: flex;
	flex-wrap: wrap;
	gap: 14px;
	align-items: stretch;
	justify-content: center;
}
.reperibilita-numero,
.reperibilita-oggi,
.reperibilita-stato {
	background: #fff;
	border-radius: 10px;
	box-shadow: 0 2px 6px rgba(0,0,0,0.08);
	padding: 12px 18px;
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	min-width: 220px;
}
.reperibilita-numero {
	background: linear-gradient(135deg, #dc3545 0%, #a71d2a 100%);
	color: #fff;
}
.reperibilita-numero-label {
	font-size: 12px;
	text-transform: uppercase;
	letter-spacing: 0.6px;
	opacity: 0.85;
	margin-bottom: 4px;
}
.reperibilita-numero-value {
	font-size: 24px;
	font-weight: 700;
	letter-spacing: 0.5px;
	font-variant-numeric: tabular-nums;
}
.reperibilita-oggi-label {
	font-size: 12px;
	text-transform: uppercase;
	letter-spacing: 0.6px;
	color: #555;
	margin-bottom: 4px;
}
.reperibilita-oggi-value {
	font-size: 18px;
	font-weight: 700;
	color: #007bff;
}
.reperibilita-stato {
	min-width: 160px;
	justify-content: center;
	color: #666;
	font-size: 13px;
}
.reperibilita-stato.salvataggio {
	color: #f0932b;
}
.reperibilita-stato.salvato {
	color: #22a06b;
}
.reperibilita-stato.errore {
	color: #dc3545;
}

/* Toolbar mese */
.reperibilita-toolbar {
	display: flex;
	align-items: center;
	gap: 10px;
	justify-content: center;
	margin: 14px 0 10px 0;
}
.reperibilita-nav-btn {
	background: #007bff;
	color: #fff;
	border: none;
	border-radius: 6px;
	height: 36px;
	min-width: 42px;
	font-size: 16px;
	cursor: pointer;
	padding: 0 10px;
}
.reperibilita-nav-btn:hover { background: #0056b3; }
.reperibilita-mese-titolo {
	margin: 0;
	min-width: 220px;
	text-align: center;
	color: #333;
	font-size: 20px;
	text-transform: uppercase;
	letter-spacing: 0.4px;
}
.reperibilita-oggi-btn {
	background: #28a745;
	color: #fff;
	border: none;
	border-radius: 6px;
	height: 36px;
	padding: 0 16px;
	font-weight: 600;
	cursor: pointer;
}
.reperibilita-oggi-btn:hover { background: #218838; }

/* Tabella mese */
.reperibilita-mese-box {
	background: #fff;
	border-radius: 10px;
	box-shadow: 0 2px 8px rgba(0,0,0,0.08);
	padding: 10px;
	overflow-x: auto;
	-webkit-overflow-scrolling: touch;
	margin-bottom: 18px;
}
.reperibilita-mese-box h3 {
	margin: 4px 6px 10px 6px;
	color: #007bff;
	font-size: 18px;
}

/*
 * Tabella mese.
 * NOTA iOS: su Safari mobile il `table-layout: fixed` combinato con
 * `width: 100%` + `min-width` + `width: calc(...)` sulle celle collassa
 * le colonne giorno a 0 (si vedono solo i nomi tecnico). Usiamo width
 * fisse in px sia sulla colonna tecnico (140) sia sulle colonne giorno
 * (30), senza forzare la tabella al 100%. Il container ha overflow-x
 * per lo scroll orizzontale su mobile.
 */
.reperibilita-table {
	border-collapse: separate;
	border-spacing: 0;
	table-layout: fixed;
	width: auto;
	font-size: 13px;
}
.reperibilita-table th,
.reperibilita-table td {
	border: 1px solid #dee2e6;
	text-align: center;
	vertical-align: middle;
	padding: 0;
	background: #fff;
	box-sizing: border-box;
}
.reperibilita-table thead th {
	background: #f1f3f5;
	color: #333;
	font-weight: 700;
	height: 28px;
}
.reperibilita-table th.col-tecnico,
.reperibilita-table td.col-tecnico {
	background: #f8f9fa;
	text-align: left;
	padding-left: 8px;
	font-weight: 700;
	color: #222;
	width: 140px;
	min-width: 140px;
	max-width: 140px;
	position: -webkit-sticky;
	position: sticky;
	left: 0;
	z-index: 2;
	box-shadow: 1px 0 0 #dee2e6;
}
.reperibilita-table thead th.col-tecnico {
	z-index: 3;
}

.reperibilita-table .col-giorno {
	width: 30px;
	min-width: 30px;
	max-width: 30px;
}
.reperibilita-table th.giorno-num {
	font-size: 13px;
}
.reperibilita-table th.giorno-let {
	font-size: 11px;
	color: #777;
	font-weight: 600;
	text-transform: uppercase;
}

.reperibilita-table th.weekend,
.reperibilita-table td.weekend {
	background: #f3e9ef;
}
/*
 * Evidenza "oggi":
 *  - Sull'header (th) manteniamo il fondo giallo chiaro: lì non c'è colore tecnico.
 *  - Sulle celle-giorno (td) usiamo SOLO un bordo giallo spesso (box-shadow inset)
 *    in modo da non coprire il colore del tecnico di turno.
 */
.reperibilita-table th.oggi {
	background: #fff3cd !important;
	box-shadow: inset 0 0 0 2px #ffc107;
}
.reperibilita-table td.oggi {
	box-shadow: inset 0 0 0 3px #ffc107;
	position: relative;
}
.reperibilita-table td.cella-giorno.oggi:not(.cella-occupata):not(.cella-barrata) {
	background: #fffbe6;
}

.reperibilita-table td.cella-giorno {
	height: 34px;
	cursor: default;
	font-weight: 600;
	color: transparent;
	font-size: 13px;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
	user-select: none;
	-webkit-user-select: none;
}
.reperibilita-table td.cella-giorno.editabile {
	cursor: pointer;
}
.reperibilita-table td.cella-giorno.editabile:hover {
	outline: 2px solid #007bff;
	outline-offset: -2px;
}
.reperibilita-table td.cella-non-applicabile {
	background: repeating-linear-gradient(
		-45deg,
		#f1f1f1 0,
		#f1f1f1 6px,
		#e2e2e2 6px,
		#e2e2e2 12px
	);
}

/*
 * Cella occupata: colori fedeli al file Excel originale
 * (REPERIBILITA' C.ST 2026-27.xls).
 *  tec-0 CARLOTTI  rosso    #FF0000
 *  tec-1 SASSO     verde    #00B050
 *  tec-2 CHIRIVINO azzurro  #00B0F0
 *  tec-3 FRASSINI  arancio  #E26B0A
 *  tec-4 SIINO     fucsia   #CC0099
 *  tec-5 MELCHIONI grigio   #808080
 */
.reperibilita-table td.cella-occupata {
	color: transparent;
	font-weight: 700;
}
.reperibilita-table td.cella-occupata.tec-0 { background: #FF0000; }
.reperibilita-table td.cella-occupata.tec-1 { background: #00B050; }
.reperibilita-table td.cella-occupata.tec-2 { background: #00B0F0; }
.reperibilita-table td.cella-occupata.tec-3 { background: #E26B0A; }
.reperibilita-table td.cella-occupata.tec-4 { background: #CC0099; }
.reperibilita-table td.cella-occupata.tec-5 { background: #808080; }
.reperibilita-table td.cella-occupata.tec-6 { background: #2c3e50; }
.reperibilita-table td.cella-occupata.tec-7 { background: #d35400; }

/* Intestazione tecnico colorata (prima colonna) */
.reperibilita-table td.col-tecnico.tec-0,
.reperibilita-table tbody tr.riga-tec.tec-0 > th.col-tecnico { color: #FF0000; }
.reperibilita-table tbody tr.riga-tec.tec-1 > th.col-tecnico { color: #00B050; }
.reperibilita-table tbody tr.riga-tec.tec-2 > th.col-tecnico { color: #00B0F0; }
.reperibilita-table tbody tr.riga-tec.tec-3 > th.col-tecnico { color: #E26B0A; }
.reperibilita-table tbody tr.riga-tec.tec-4 > th.col-tecnico { color: #CC0099; }
.reperibilita-table tbody tr.riga-tec.tec-5 > th.col-tecnico { color: #808080; }

.reperibilita-table td.cella-barrata {
	background: repeating-linear-gradient(
		-45deg,
		#ffe3e3 0,
		#ffe3e3 6px,
		#ffd1d1 6px,
		#ffd1d1 12px
	);
	color: #c0392b;
	font-weight: 700;
}

/* Vista annuale */
.reperibilita-vista-annuale {
	display: flex;
	flex-direction: column;
	gap: 14px;
}

/* Legenda */
.reperibilita-legenda {
	margin-top: 22px;
	background: #fff;
	border-radius: 10px;
	box-shadow: 0 2px 8px rgba(0,0,0,0.08);
	padding: 12px 16px;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 14px;
	font-size: 13px;
	color: #444;
}
.reperibilita-legenda .legenda-titolo {
	font-weight: 700;
	color: #222;
	margin-right: 4px;
}
.reperibilita-legenda .legenda-item {
	display: inline-flex;
	align-items: center;
	gap: 6px;
}
.reperibilita-legenda .legenda-col {
	display: inline-block;
	width: 18px;
	height: 18px;
	border: 1px solid #bbb;
	border-radius: 3px;
}
.legenda-col.legenda-feriale { background: #fff; }
.legenda-col.legenda-weekend { background: #f3e9ef; }
.legenda-col.legenda-oggi {
	background: #fffbe6;
	box-shadow: inset 0 0 0 3px #ffc107;
	border-color: #ffc107;
}
.legenda-col.legenda-occupato {
	background: linear-gradient(90deg, #FF0000 0 16%, #00B050 16% 33%, #00B0F0 33% 50%, #E26B0A 50% 66%, #CC0099 66% 83%, #808080 83% 100%);
	border-color: #666;
}
.legenda-col.legenda-barrato {
	background: repeating-linear-gradient(
		-45deg,
		#ffe3e3 0,
		#ffe3e3 4px,
		#ffd1d1 4px,
		#ffd1d1 8px
	);
}

/* Responsive */
@media (max-width: 800px) {
	.reperibilita-header-info { flex-direction: column; align-items: stretch; }
	.reperibilita-numero,
	.reperibilita-oggi,
	.reperibilita-stato { min-width: 0; }
	.reperibilita-mese-titolo { font-size: 16px; min-width: 160px; }
	.reperibilita-table { font-size: 11px; }
	.reperibilita-table th.col-tecnico,
	.reperibilita-table td.col-tecnico {
		width: 100px;
		min-width: 100px;
		max-width: 100px;
		font-size: 12px;
	}
	.reperibilita-table .col-giorno {
		width: 26px;
		min-width: 26px;
		max-width: 26px;
	}
}

/* Stampa */
@media print {
	#topBar, .reperibilita-toolbar, .reperibilita-legenda, .reperibilita-stato { display: none !important; }
	.reperibilita-wrapper { max-width: 100%; padding: 6mm; }
	.reperibilita-mese-box { box-shadow: none; border: 1px solid #aaa; page-break-inside: avoid; }
	.reperibilita-table { min-width: 0; font-size: 9px; }
	.reperibilita-table td.cella-occupata { color: #000 !important; background: #fff !important; border: 1px solid #333; }
}
