/* =========================================================
   IL LURIDO — app.css
   Tabloid satirico. Leggero, self-hosted, niente CDN.
   ========================================================= */

@font-face {
	font-family: "Anton";
	font-style: normal;
	font-weight: 400;
	font-display: swap;
	src: url("fonts/anton.woff2") format("woff2");
}

:root {
	--rosso: #DD0C11;
	--inchiostro: #111111;
	--carta: #FFFFFF;
	--crema: #F5F2EC;
	--grigio: #6b6b6b;
	--bordo: #e3ddd2;
	--maxw: 1180px;
	--font-titolo: "Anton", Impact, "Arial Narrow Bold", sans-serif;
	--font-corpo: -apple-system, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
}

* { box-sizing: border-box; }

html { -webkit-text-size-adjust: 100%; }

body {
	margin: 0;
	background: var(--crema);
	color: var(--inchiostro);
	font-family: var(--font-corpo);
	font-size: 18px;
	line-height: 1.6;
}

a { color: var(--rosso); text-decoration: none; }
a:hover { text-decoration: underline; }

img { max-width: 100%; height: auto; display: block; }

.screen-reader-text {
	position: absolute !important;
	width: 1px; height: 1px;
	padding: 0; margin: -1px;
	overflow: hidden; clip: rect(0,0,0,0);
	white-space: nowrap; border: 0;
}
.skip-link:focus {
	position: fixed; left: 8px; top: 8px;
	width: auto; height: auto; clip: auto;
	background: var(--inchiostro); color: #fff;
	padding: 8px 14px; z-index: 1000;
}

/* ---------- MASTHEAD ---------- */
.masthead {
	background: var(--rosso);
	color: var(--carta);
	border-bottom: 6px solid var(--inchiostro);
}
.masthead-inner {
	max-width: var(--maxw);
	margin: 0 auto;
	padding: 18px 20px 12px;
	text-align: center;
}
.brand .custom-logo,
.brand img {
	margin: 0 auto;
	max-height: 150px;
	width: auto;
}
.brand-text {
	display: inline-block;
	font-family: var(--font-titolo);
	font-size: clamp(48px, 11vw, 110px);
	line-height: .9;
	letter-spacing: 1px;
	color: var(--carta);
	text-transform: uppercase;
}
.brand-text:hover { text-decoration: none; }
.tagline {
	margin: 6px 0 0;
	font-style: italic;
	font-size: 15px;
	letter-spacing: .3px;
	opacity: .95;
}

/* ---------- NAV RUBRICHE ---------- */
.rubriche {
	background: var(--inchiostro);
}
.rubriche-list,
.rubriche ul {
	list-style: none;
	max-width: var(--maxw);
	margin: 0 auto;
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 2px 0;
}
.rubriche li a {
	display: block;
	color: var(--carta);
	text-transform: uppercase;
	font-weight: 700;
	font-size: 14px;
	letter-spacing: .6px;
	padding: 12px 16px;
}
.rubriche li a:hover { background: var(--rosso); text-decoration: none; }

/* ---------- LAYOUT ---------- */
.wrap {
	max-width: var(--maxw);
	margin: 0 auto;
	padding: 28px 20px 48px;
}
.site-main { min-height: 50vh; }

/* ---------- GRIGLIA CARD ---------- */
.grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 26px;
}
.card {
	position: relative;
	background: var(--carta);
	border: 1px solid var(--bordo);
	display: flex;
	flex-direction: column;
	cursor: pointer;
	transition: transform .12s ease, box-shadow .12s ease;
}
.card:hover { transform: translateY(-3px); box-shadow: 0 10px 24px rgba(0,0,0,.10); }
.card:focus-within { box-shadow: 0 0 0 3px rgba(216,30,30,.35); }
/* titolo = link; lo ::after lo "stira" su tutta la card (stretched-link) */
.card-titlelink { color: var(--inchiostro); text-decoration: none; }
.card-titlelink::after { content: ""; position: absolute; inset: 0; z-index: 1; }
.card:hover .card-titlelink { color: var(--rosso); }
/* il chip categoria resta cliccabile, sopra lo stretched-link */
.card .card-meta .chip { position: relative; z-index: 2; }
.card-body { padding: 22px 22px 24px; display: flex; flex-direction: column; gap: 10px; flex: 1; }
.card-title {
	font-family: var(--font-titolo);
	font-weight: 400;
	text-transform: uppercase;
	line-height: .98;
	letter-spacing: .4px;
	margin: 2px 0 0;
	font-size: clamp(24px, 2.6vw, 32px);
	color: var(--inchiostro);
}
.card-occhiello { margin: 0; color: #555; font-size: 15.5px; line-height: 1.5; }
.card-more { margin-top: auto; padding-top: 8px; color: var(--rosso); font-weight: 800; text-transform: uppercase; font-size: 13px; letter-spacing: .5px; }
.card:hover .card-more { text-decoration: underline; }

/* card HERO: occupa tutta la riga, immagine sopra + titolo grande */
.card--hero { grid-column: 1 / -1; }
.card--hero .card-title { font-size: clamp(34px, 5vw, 64px); }
.card--hero .card-occhiello { font-size: 18px; }

/* ---------- CHIP / META ---------- */
.card-meta { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; }
.chip {
	display: inline-block;
	background: var(--rosso);
	color: var(--carta);
	text-transform: uppercase;
	font-weight: 700;
	font-size: 12px;
	letter-spacing: .6px;
	padding: 4px 10px;
}
.chip:hover { text-decoration: none; background: var(--inchiostro); }
.card-date { color: var(--grigio); font-size: 13px; }

/* ---------- ARCHIVI ---------- */
.archive-head { border-bottom: 4px solid var(--inchiostro); margin-bottom: 26px; padding-bottom: 8px; }
.archive-title {
	font-family: var(--font-titolo);
	font-weight: 400;
	text-transform: uppercase;
	font-size: clamp(34px, 6vw, 60px);
	margin: 0;
}

/* ---------- SINGLE ---------- */
.single .wrap { max-width: 820px; }
.article-head { margin-bottom: 22px; }
.article-title {
	font-family: var(--font-titolo);
	font-weight: 400;
	text-transform: uppercase;
	line-height: .95;
	letter-spacing: .5px;
	margin: 10px 0 0;
	font-size: clamp(40px, 8vw, 86px);
}
.article-occhiello {
	font-size: clamp(18px, 2.4vw, 24px);
	color: var(--grigio);
	font-style: italic;
	margin: 14px 0 0;
}
.article-media { margin: 22px 0; }
.article-body { font-size: 19px; }
.article-body p { margin: 0 0 1.2em; }
.article-body h2, .article-body h3 {
	font-family: var(--font-titolo);
	font-weight: 400;
	text-transform: uppercase;
	letter-spacing: .4px;
	margin-top: 1.6em;
}
.article-body blockquote {
	border-left: 5px solid var(--rosso);
	margin: 1.4em 0;
	padding: .2em 0 .2em 18px;
	font-size: 1.15em;
	font-style: italic;
}

/* box satira */
.satire-notice {
	background: var(--inchiostro);
	color: #f0f0f0;
	padding: 22px 22px 22px 22px;
	margin: 36px 0 0;
	border-left: 8px solid var(--rosso);
	font-size: 16px;
	line-height: 1.6;
	display: flex;
	gap: 16px;
	align-items: flex-start;
}
.satire-notice .satire-badge {
	flex: none;
	background: var(--rosso);
	color: #fff;
	text-transform: uppercase;
	font-weight: 800;
	letter-spacing: 1px;
	font-size: 13px;
	padding: 6px 12px;
	margin-top: 2px;
}
.satire-notice p { margin: 0; }
.satire-notice strong { color: #fff; }

/* ---------- CONDIVISIONE ---------- */
.share {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 10px;
	margin: 34px 0 0;
	padding-top: 22px;
	border-top: 2px solid var(--bordo);
}
.share-label {
	font-weight: 800;
	text-transform: uppercase;
	letter-spacing: .6px;
	font-size: 13px;
	color: var(--inchiostro);
	margin-right: 2px;
}
.share-btn {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 11px 16px;
	border: 0;
	border-radius: 3px;
	cursor: pointer;
	font-family: inherit;
	font-weight: 700;
	font-size: 14px;
	line-height: 1;
	color: #fff;
	text-decoration: none;
	transition: transform .1s ease, opacity .1s ease;
}
.share-btn:hover { opacity: .92; text-decoration: none; transform: translateY(-1px); }
.share-btn svg { width: 18px; height: 18px; fill: currentColor; }
.share-wa { background: #25D366; }
.share-fb { background: #1877F2; }
.share-native { background: var(--rosso); }
.share-copy { background: var(--inchiostro); }
.share-copy.is-done { background: #2a8f3f; }
.article-rubrica { margin: 18px 0 0; color: var(--grigio); font-size: 14px; }

/* nav articoli */
.article-nav { display: flex; justify-content: space-between; gap: 20px; margin-top: 36px; font-weight: 700; }

/* ---------- PAGINAZIONE ---------- */
.pagination { margin-top: 36px; text-align: center; }
.pagination .page-numbers {
	display: inline-block; padding: 8px 14px; margin: 0 3px;
	background: var(--carta); border: 1px solid var(--bordo); color: var(--inchiostro);
}
.pagination .current { background: var(--rosso); color: var(--carta); border-color: var(--rosso); }

/* ---------- PAGINE STATICHE ---------- */
.page .entry-title, .page-title {
	font-family: var(--font-titolo); font-weight: 400; text-transform: uppercase;
	font-size: clamp(34px, 6vw, 60px); margin: 0 0 18px;
}
.page .entry-content { font-size: 18px; }
.page .entry-content h2 { font-family: var(--font-titolo); font-weight: 400; text-transform: uppercase; }

/* ---------- EMPTY ---------- */
.empty { text-align: center; padding: 60px 0; }
.empty h1 { font-family: var(--font-titolo); font-weight: 400; text-transform: uppercase; font-size: clamp(34px, 7vw, 64px); margin: 0 0 10px; }

/* ---------- FOOTER ---------- */
.site-footer {
	background: var(--inchiostro);
	color: #cfcfcf;
	border-top: 6px solid var(--rosso);
	margin-top: 48px;
}
.footer-inner { max-width: var(--maxw); margin: 0 auto; padding: 0 20px 36px; }

/* disclaimer ben visibile (stile "scudo legale") */
.disclaimer-box {
	background: var(--rosso);
	color: #fff;
	margin: 0 0 28px;
	padding: 26px 30px 30px;
	text-align: center;
}
.disclaimer-kicker {
	margin: 0 0 6px;
	text-transform: uppercase;
	letter-spacing: 2px;
	font-size: 13px;
	font-weight: 700;
	opacity: .95;
}
.disclaimer-title {
	font-family: var(--font-titolo);
	font-weight: 400;
	text-transform: uppercase;
	font-size: clamp(26px, 4.5vw, 44px);
	line-height: 1;
	margin: 0 0 14px;
	letter-spacing: .5px;
}
.disclaimer {
	font-size: 15.5px;
	line-height: 1.65;
	max-width: 820px;
	margin: 0 auto;
}
.footer-bottom {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: center;
	gap: 14px;
	padding-top: 6px;
}
.footer-menu { list-style: none; display: flex; flex-wrap: wrap; gap: 18px; padding: 0; margin: 0; }
.footer-menu a { color: #fff; text-transform: uppercase; font-size: 13px; font-weight: 700; }
.copyline { font-size: 13px; color: var(--grigio); margin: 0; }

/* ---------- RESPONSIVE ---------- */
@media (max-width: 900px) {
	.grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px) {
	body { font-size: 17px; }
	.grid { grid-template-columns: 1fr; gap: 18px; }

	/* masthead compatto su mobile */
	.masthead-inner { padding: 14px 16px 10px; }
	.brand .custom-logo, .brand img { max-height: 92px; }

	/* nav rubriche: scroll orizzontale fluido, scrollbar nascosta */
	.rubriche-list, .rubriche ul {
		justify-content: flex-start;
		overflow-x: auto;
		flex-wrap: nowrap;
		-webkit-overflow-scrolling: touch;
		scrollbar-width: none;
	}
	.rubriche-list::-webkit-scrollbar, .rubriche ul::-webkit-scrollbar { display: none; }
	.rubriche li a { white-space: nowrap; padding: 11px 13px; font-size: 13px; }

	.wrap { padding: 20px 15px 36px; }
	.card-body { padding: 18px 18px 20px; }

	/* condivisione: pulsanti grandi, 2 per riga, ben tappabili */
	.share { gap: 8px; }
	.share-label { width: 100%; margin: 0 0 2px; }
	.share-btn { flex: 1 1 calc(50% - 6px); justify-content: center; padding: 13px 10px; font-size: 15px; }

	/* disclaimer / footer adattati */
	.disclaimer-box { padding: 22px 18px 24px; }
	.footer-bottom { flex-direction: column; align-items: flex-start; gap: 12px; }
}
