/*
Theme Name: Ponto Cultural da Rua Direita
Theme URI: https://pontoculturaldaruadireita.pt
Description: Tema do Ponto Cultural da Rua Direita, child theme do GeneratePress.
Author: Ponto Cultural da Rua Direita
Template: generatepress
Version: 0.4.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: pcrd
*/

/* ==========================================================================
   Variáveis globais
   ========================================================================== */

:root {
	--pcrd-fundo: #0a0a0a;
	--pcrd-fundo-suave: #161616;
	--pcrd-fundo-medio: #1a1a1a;
	--pcrd-texto: #ede4d0;
	--pcrd-texto-suave: #888;
	--pcrd-texto-tenue: #666;
	--pcrd-linha: #1f1f1f;
	--pcrd-linha-hover: #3a3a3a;
	--pcrd-accento: #c8324c;

	--pcrd-pad-h: 3rem;

	--pcrd-font-titulo: 'Fraunces', Georgia, 'Times New Roman', serif;
	--pcrd-font-corpo: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
	--pcrd-font-mono: 'JetBrains Mono', 'SF Mono', Menlo, Consolas, monospace;
}

@media (max-width: 768px) {
	:root {
		--pcrd-pad-h: 1.25rem;
	}
}


/* ==========================================================================
   Reset global do site para dark
   ========================================================================== */

body,
.site,
.site-content,
.content-area,
.inside-article,
.entry-content {
	background: var(--pcrd-fundo);
	color: var(--pcrd-texto);
}

body {
	font-family: var(--pcrd-font-corpo);
	font-weight: 400;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

a {
	color: var(--pcrd-texto);
	transition: color 0.2s ease;
}

a:hover,
a:focus {
	color: var(--pcrd-accento);
}

::selection {
	background: var(--pcrd-accento);
	color: var(--pcrd-texto);
}

::-webkit-scrollbar {
	width: 10px;
	height: 10px;
}

::-webkit-scrollbar-track {
	background: var(--pcrd-fundo);
}

::-webkit-scrollbar-thumb {
	background: #2a2a2a;
}

::-webkit-scrollbar-thumb:hover {
	background: var(--pcrd-linha-hover);
}


/* ==========================================================================
   Header
   ========================================================================== */

.site-header {
	background: var(--pcrd-fundo) !important;
	border-bottom: 0.5px solid var(--pcrd-linha);
}

.inside-header {
	padding: 1.5rem var(--pcrd-pad-h) !important;
}

.site-branding .main-title {
	margin: 0;
}

.site-branding .main-title a {
	font-family: var(--pcrd-font-titulo);
	font-size: 22px;
	font-weight: 400;
	color: var(--pcrd-texto) !important;
	text-decoration: none;
	letter-spacing: -0.005em;
	line-height: 1;
}

.site-description {
	color: var(--pcrd-texto-suave) !important;
	font-family: var(--pcrd-font-mono);
	font-size: 11px;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	margin-top: 0.25rem;
}


/* ==========================================================================
   Navegação
   ========================================================================== */

.main-navigation {
	background: var(--pcrd-fundo) !important;
}

.main-navigation .inside-navigation {
	padding: 0 var(--pcrd-pad-h);
	background: transparent !important;
}

.main-navigation .main-nav ul {
	background: transparent;
}

.main-navigation .main-nav ul li a {
	color: var(--pcrd-texto) !important;
	font-family: var(--pcrd-font-mono) !important;
	font-size: 12px !important;
	letter-spacing: 0.15em !important;
	text-transform: uppercase;
	padding: 1.2rem 1.4rem !important;
	background: transparent !important;
	transition: color 0.2s ease;
}

.main-navigation .main-nav ul li:hover > a,
.main-navigation .main-nav ul li.current-menu-item > a,
.main-navigation .main-nav ul li.current-menu-ancestor > a,
.main-navigation .main-nav ul li[class*="current-"] > a:focus,
.main-navigation .main-nav ul li.sfHover > a {
	color: var(--pcrd-accento) !important;
	background: transparent !important;
}


/* ==========================================================================
   Container override — full bleed em toda a homepage e páginas
   ========================================================================== */

.site-content .container.grid-container,
.home .site-content .container.grid-container,
.page-template-default .site-content .container.grid-container {
	max-width: 100%;
	padding-left: 0;
	padding-right: 0;
	background: var(--pcrd-fundo);
}

.inside-article {
	padding: 0;
	background: var(--pcrd-fundo);
}

.home .entry-header {
	display: none;
}

.entry-header {
	padding: 4rem var(--pcrd-pad-h) 2rem;
}

.entry-title {
	font-family: var(--pcrd-font-titulo);
	font-weight: 400;
	color: var(--pcrd-texto);
	font-size: clamp(2rem, 4vw, 3.5rem);
	letter-spacing: -0.015em;
	line-height: 1.05;
	margin: 0;
}

.entry-content > * {
	padding-left: var(--pcrd-pad-h);
	padding-right: var(--pcrd-pad-h);
}

.entry-content > .pcrd-eventos {
	padding-left: 0;
	padding-right: 0;
}


/* ==========================================================================
   Footer
   ========================================================================== */

.site-footer,
.footer-widgets,
.site-info {
	background: var(--pcrd-fundo) !important;
	color: var(--pcrd-texto-suave);
}

.site-info {
	border-top: 0.5px solid var(--pcrd-linha);
	padding: 2rem var(--pcrd-pad-h) !important;
	font-family: var(--pcrd-font-mono);
	font-size: 11px;
	letter-spacing: 0.1em;
	text-transform: uppercase;
}

.site-info .copyright-bar {
	color: var(--pcrd-texto-suave);
}

.site-info a {
	color: var(--pcrd-texto);
	text-decoration: none;
}

.site-info a:hover {
	color: var(--pcrd-accento);
}


/* ==========================================================================
   Eventos — listagem (full bleed)
   ========================================================================== */

.pcrd-eventos {
	width: 100vw;
	position: relative;
	left: 50%;
	margin-left: -50vw;
	margin-right: -50vw;
	max-width: none;
	padding: 4rem var(--pcrd-pad-h) 6rem;
	box-sizing: border-box;
	display: flex;
	flex-direction: column;
	gap: 5rem;
	background: var(--pcrd-fundo);
}


/* ==========================================================================
   Card de evento
   ========================================================================== */

.pcrd-evento {
	display: flex;
	gap: 3rem;
	opacity: 0;
	transform: translateY(20px);
	animation: pcrd-evento-fadein 0.7s ease forwards;
}

.pcrd-evento:nth-child(1) { animation-delay: 0.05s; }
.pcrd-evento:nth-child(2) { animation-delay: 0.18s; }
.pcrd-evento:nth-child(3) { animation-delay: 0.31s; }
.pcrd-evento:nth-child(4) { animation-delay: 0.44s; }
.pcrd-evento:nth-child(n+5) { animation-delay: 0.5s; }

@keyframes pcrd-evento-fadein {
	to {
		opacity: 1;
		transform: translateY(0);
	}
}


/* Imagem */
.pcrd-evento__imagem {
	flex: 0 0 45%;
	background: var(--pcrd-fundo-suave);
	overflow: hidden;
	aspect-ratio: 4 / 3;
}

.pcrd-evento__imagem img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: transform 0.7s ease;
}

.pcrd-evento:hover .pcrd-evento__imagem img {
	transform: scale(1.025);
}

.pcrd-evento__imagem-placeholder {
	width: 100%;
	height: 100%;
	background:
		linear-gradient(135deg, var(--pcrd-fundo-suave) 25%, transparent 25%) -10px 0,
		linear-gradient(225deg, var(--pcrd-fundo-suave) 25%, transparent 25%) -10px 0,
		var(--pcrd-fundo-medio);
	background-size: 20px 20px;
}


/* Conteúdo */
.pcrd-evento__conteudo {
	flex: 1;
	padding: 0.5rem 0;
	display: flex;
	flex-direction: column;
	min-width: 0;
}

.pcrd-evento__associacao {
	font-family: var(--pcrd-font-mono);
	font-size: 12px;
	text-transform: uppercase;
	letter-spacing: 0.15em;
	color: var(--pcrd-texto-suave);
	margin: 0 0 1.4rem;
	font-weight: 400;
}

.pcrd-evento__titulo {
	font-family: var(--pcrd-font-titulo);
	font-size: clamp(2rem, 3.6vw, 4.5rem);
	font-weight: 400;
	line-height: 1.02;
	margin: 0 0 1.6rem;
	color: var(--pcrd-texto);
	letter-spacing: -0.02em;
	font-optical-sizing: auto;
}

.pcrd-evento__meta {
	font-family: var(--pcrd-font-mono);
	font-size: clamp(0.85rem, 1.05vw, 1rem);
	letter-spacing: 0.06em;
	color: var(--pcrd-texto);
	margin: 0 0 2.2rem;
	line-height: 1.6;
	text-transform: uppercase;
	font-weight: 400;
}


/* Sinopse */
.pcrd-evento__sinopse {
	margin-bottom: 2rem;
}

.pcrd-evento__sinopse summary {
	list-style: none;
	cursor: pointer;
	user-select: none;
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font-family: var(--pcrd-font-mono);
	font-size: 12px;
	letter-spacing: 0.12em;
	color: var(--pcrd-texto-tenue);
	text-transform: uppercase;
	transition: color 0.2s ease;
}

.pcrd-evento__sinopse summary:hover {
	color: var(--pcrd-texto);
}

.pcrd-evento__sinopse summary::-webkit-details-marker {
	display: none;
}

.pcrd-evento__sinopse summary::before {
	content: '+';
	font-size: 16px;
	font-weight: 300;
	width: 1rem;
	line-height: 1;
	transition: transform 0.2s ease;
}

.pcrd-evento__sinopse[open] summary::before {
	content: '−';
}

.pcrd-evento__sinopse-conteudo {
	margin-top: 1.2rem;
	padding: 1.25rem 0 0;
	font-family: var(--pcrd-font-corpo);
	font-size: 15px;
	line-height: 1.75;
	color: var(--pcrd-texto);
	max-width: 60ch;
	animation: pcrd-sinopse-slide 0.35s ease;
}

@keyframes pcrd-sinopse-slide {
	from { opacity: 0; transform: translateY(-5px); }
	to   { opacity: 1; transform: translateY(0); }
}

.pcrd-evento__sinopse-conteudo p {
	margin: 0 0 0.85rem;
}

.pcrd-evento__sinopse-conteudo p:last-child {
	margin-bottom: 0;
}


/* Rodapé / acção */
.pcrd-evento__rodape {
	margin-top: auto;
}

.pcrd-evento__botao {
	display: inline-block;
	font-family: var(--pcrd-font-mono);
	font-size: 13px;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--pcrd-texto) !important;
	text-decoration: none;
	border-bottom: 0.5px solid var(--pcrd-linha-hover);
	padding-bottom: 4px;
	transition: color 0.2s ease, border-color 0.2s ease;
}

.pcrd-evento__botao:hover,
.pcrd-evento__botao:focus {
	color: var(--pcrd-accento) !important;
	border-bottom-color: var(--pcrd-accento);
}

.pcrd-evento__sem-botao {
	font-family: var(--pcrd-font-mono);
	font-size: 13px;
	letter-spacing: 0.1em;
	color: var(--pcrd-texto-tenue);
	text-transform: uppercase;
}


/* Estado vazio */
.pcrd-eventos-empty {
	text-align: center;
	padding: 5rem 2rem;
	color: var(--pcrd-texto-suave);
	font-family: var(--pcrd-font-mono);
	font-size: 13px;
	letter-spacing: 0.08em;
	text-transform: uppercase;
}


/* ==========================================================================
   Responsive (mobile)
   ========================================================================== */

@media (max-width: 768px) {
	.pcrd-eventos {
		gap: 3rem;
		padding: 2rem var(--pcrd-pad-h) 3rem;
	}

	.pcrd-evento {
		flex-direction: column;
		gap: 1.5rem;
	}

	.pcrd-evento__imagem {
		flex: 0 0 auto;
		width: 100%;
		aspect-ratio: 16 / 10;
	}

	.pcrd-evento__titulo {
		font-size: clamp(1.75rem, 7vw, 2.5rem);
	}

	.pcrd-evento__meta {
		font-size: 12px;
	}

	.inside-header {
		padding: 1.2rem var(--pcrd-pad-h) !important;
	}

	.site-branding .main-title a {
		font-size: 18px;
	}

	.main-navigation .main-nav ul li a {
		padding: 1rem !important;
		font-size: 11px !important;
	}
}
