:root{
	--sns-bg: #ffffff;
	--sns-surface: #ffffff;
	--sns-surface-alt: #f7f9fb;
	--sns-text: #4d4e4f;
	--sns-muted: #6b7280;
	--sns-border: #c8cad4;
	--sns-border-strong: #183f56;
	--sns-accent: #00728d;
	--sns-accent-dark: #183f56;
	--sns-title-bg: #005A74;
	--sns-title-stripe: #004059;
	--sns-link: #00728d;
	--sns-link-hover: #183f56;
	--sns-shadow: 0 10px 26px rgba(24, 63, 86, 0.08);
}

BODY{
	background:
		linear-gradient(180deg, rgba(0, 114, 141, 0.08) 0, rgba(0, 114, 141, 0.02) 118px, transparent 118px),
		var(--sns-bg);
	color: var(--sns-text);
	margin: 0;
	padding: 0 20px 40px;
	font-family: "Roboto Condensed", "Helvetica Neue", Arial, sans-serif;
	box-shadow: inset 0 16px 0 var(--sns-title-stripe);
}

.titolo{
	margin: 0 -20px 6px;
	padding: 18px 20px 16px;
	background: var(--sns-title-bg);
	box-shadow: inset 0 16px 0 var(--sns-title-stripe);
	display: flex;
	align-items: center;
	justify-content: center;
	flex-wrap: wrap;
	column-gap: 12px;
	row-gap: 4px;
	text-align: center;
	font-family: "Roboto", "Helvetica Neue", Arial, sans-serif;
	font-size: 24px;
	font-weight: 700;
	letter-spacing: 0.02em;
	line-height: 1.1;
	color: #ffffff;
	text-transform: none;
}

.titolo::before{
	content: "";
	display: inline-block;
	width: 121px;
	height: 71px;
	background: url("https://www.sns.it/sites/default/files/logo-sns%402x_0.png") center / contain no-repeat;
	filter: brightness(0) invert(1);
	flex: 0 0 121px;
}

.titolo:after{
	content: " Ufficiale della Scuola Normale Superiore";
	font-weight: 600;
	color: #ffffff;
}

.data-pubblicazione{
	text-align: center;
	margin: 0 0 18px;
	color: var(--sns-muted);
	font-weight: normal;
	font-size: 0.95rem;
	letter-spacing: 0.02em;
}

div[align="right"]{
	width: 93%;
	max-width: 1400px;
	margin: 0 auto 18px;
	padding: 14px 18px;
	background: rgba(255, 255, 255, 0.96);
	border: 1px solid rgba(200, 202, 212, 0.9);
	border-radius: 10px;
	box-shadow: 0 8px 24px rgba(24, 63, 86, 0.05);
}

#searchInput,
#cat_sel,
#subcat_sel{
	border: 1px solid var(--sns-border);
	background: var(--sns-surface);
	color: var(--sns-text);
	border-radius: 6px;
	padding: 8px 10px;
	font: inherit;
	line-height: 1.3;
	box-shadow: inset 0 1px 1px rgba(24, 63, 86, 0.04);
}

#searchInput{
	min-width: 220px;
}

#cat_sel{
	min-width: 280px;
}

#subcat_sel{
	min-width: 210px;
}

#searchInput:focus,
#cat_sel:focus,
#subcat_sel:focus{
	outline: none;
	border-color: var(--sns-accent);
	box-shadow: 0 0 0 3px rgba(0, 114, 141, 0.12);
}

.tabella{
	margin: 0 auto;
	width: 93%;
	max-width: 1400px;
	padding: 0;
	border: 1px solid var(--sns-border);
	border-radius: 10px;
	border-spacing: 0;
	background-color: var(--sns-surface);
	box-shadow: var(--sns-shadow);
	overflow: hidden;
}

TR:nth-child(odd){
	background-color: var(--sns-surface-alt);
}

TR:first-child{
	border-bottom: 1px solid var(--sns-border-strong) !important;
	background: linear-gradient(180deg, #eaf4f7 0%, #d7e9ef 100%) !important;
}

TR:first-child TD{
	border-top: 0;
	white-space: nowrap;
	font-weight: 700;
	font-size: 0.86rem;
	letter-spacing: 0.03em;
	text-transform: none;
	color: var(--sns-accent-dark);
	padding-top: 14px;
	padding-bottom: 14px;
}

TD{
	border-left: 1px solid rgba(31, 35, 40, 0.06);
	padding: 12px 14px;
	line-height: 1.5;
	vertical-align: top;
	border-top: 1px solid rgba(31, 35, 40, 0.06);
	font-size: 0.96rem;
}

TD:first-child{
	border-left: 0;
	padding-left: 16px;
}

TD:last-child{
	padding-right: 16px;
}

TD UL{
	padding-left: 18px;
	margin: 8px 0 0;
	font-size: 0.9rem;
	border-top: 1px dashed var(--sns-border);
	padding-top: 6px;
}

TD LI{
	background: none;
	list-style: disc;
	padding-left: 4px;
	padding-top: 2px;
}

TD LI::marker{
	color: var(--sns-accent);
}

A:link, A:visited{
	color: var(--sns-link);
	text-decoration: none;
}

A:hover{
	color: var(--sns-link-hover);
	text-decoration: underline;
}

A:focus-visible{
	outline: 2px solid var(--sns-accent);
	outline-offset: 2px;
}

TR:not(:first-child):hover{
	background-color: #eef6f9;
}

.error{
	background: linear-gradient(45deg, rgba(0, 114, 141, 0.08) 25%, transparent 25%, transparent 50%, rgba(0, 114, 141, 0.08) 50%, rgba(0, 114, 141, 0.08) 75%, transparent 75%, transparent) repeat;
	background-size: 18px 18px;
	color: #183f56;
}

@media (max-width: 1100px){
	div[align="right"]{
		width: 95%;
	}

	.tabella{
		width: 95%;
	}
}

@media (max-width: 760px){
	div[align="right"]{
		text-align: left !important;
		padding: 10px 12px;
	}

	#searchInput,
	#cat_sel,
	#subcat_sel{
		display: block;
		width: 100%;
		min-width: 0;
		box-sizing: border-box;
		margin-top: 8px;
	}

	.titolo{
		display: block;
		padding: 10px 12px 8px;
		margin: 0 -20px 4px;
		font-size: 16px;
		line-height: 1.1;
		white-space: nowrap;
	}

	.titolo::before{
		display: block;
		width: 72px;
		height: 42px;
		margin: 0 auto 6px;
	}

	.data-pubblicazione{
		letter-spacing: 0.05em;
	}

	BODY{
		box-shadow: inset 0 10px 0 var(--sns-title-stripe);
	}

	.titolo{
		box-shadow: inset 0 10px 0 var(--sns-title-stripe);
	}
}

@media (max-width: 960px){
	.tabella{
		display: block;
		width: 100%;
		max-width: 100%;
		overflow-x: auto;
		-webkit-overflow-scrolling: touch;
		border-radius: 10px;
	}

	.tabella tbody,
	.tabella tr{
		display: block;
		width: 100%;
	}

	.tabella tr:first-child{
		position: sticky;
		top: 0;
		z-index: 2;
	}
}

@media (max-width: 760px){
	.tabella{
		display: block;
		overflow: visible;
	}

	.tabella tbody{
		display: block;
	}

	.tabella tr{
		display: block;
		margin: 0 0 12px;
		border: 1px solid var(--sns-border);
		border-radius: 10px;
		overflow: hidden;
		box-shadow: 0 6px 18px rgba(24, 63, 86, 0.05);
		background: var(--sns-surface);
	}

	.tabella tr:first-child{
		display: none;
	}

	.tabella td{
		display: grid;
		grid-template-columns: 140px 1fr;
		gap: 10px;
		align-items: start;
		border-left: 0;
		border-top: 1px solid rgba(31, 35, 40, 0.06);
		padding: 10px 12px;
	}

	.tabella td:first-child{
		border-top: 0;
	}

	.tabella td::before{
		font-weight: 700;
		color: var(--sns-accent-dark);
	}

	.tabella td:nth-child(1)::before{ content: "Numero"; }
	.tabella td:nth-child(2)::before{ content: "Data registrazione"; }
	.tabella td:nth-child(3)::before{ content: "Richiedente"; }
	.tabella td:nth-child(4)::before{ content: "Oggetto"; }
	.tabella td:nth-child(5)::before{ content: "Inizio pubblicazione"; }
	.tabella td:nth-child(6)::before{ content: "Fine pubblicazione"; }
	.tabella td:nth-child(7)::before{ content: "Tipologia / Ambito"; }

	.tabella td ul{
		grid-column: 2;
		margin-left: 0;
		padding-left: 16px;
	}
}