/**
 * recima21-omp.css
 *
 * Estilos das páginas internas do OMP (catálogo, livro, série, busca, estáticas)
 * no visual do tema RECIMA21. Usa as variáveis --recima21-* definidas em
 * recima21-landing.css, herdando automaticamente o dark mode.
 */

/* ============================================================
   Logo do header maior (mais próximo da landing da revista)
   ============================================================ */
.site-header .logo .logo-img { height: 60px; max-width: 300px; }
@media (min-width: 900px) {
	.site-header .logo .logo-img { height: 72px; max-width: 360px; }
}
/* Header compacto (ao rolar): logo proporcionalmente menor */
.site-header.is-compact .logo .logo-img { height: 48px; }

/* ============================================================
   Banner card-editora (home)
   ============================================================ */
.home-card-editora { margin: 3rem 0 1rem; }
.home-card-editora img {
	display: block;
	width: 100%;
	height: auto;
	border-radius: var(--radius-lg);
	box-shadow: var(--shadow);
}

/* ============================================================
   Wrapper genérico das páginas internas (.page dentro de <main>)
   ============================================================ */
.site-main > .page,
.site-main > .static-page,
.site-main > section.static-page {
	max-width: var(--max-width);
	margin: 0 auto;
	padding: 2.5rem 1.25rem 3.5rem;
}

@media (min-width: 768px) {
	.site-main > .page { padding-left: 2rem; padding-right: 2rem; }
}

.site-main > .page > h1,
.site-main > .page .page-title {
	font-family: var(--font-serif);
	font-size: 2.1rem;
	line-height: 1.15;
	color: var(--recima21-text);
	margin: 0.25rem 0 1.25rem;
}

/* ============================================================
   Breadcrumbs
   ============================================================ */
.cmp_breadcrumbs {
	margin-bottom: 1.25rem;
	font-size: 0.9rem;
}
.cmp_breadcrumbs ol {
	list-style: none;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.4rem;
	padding: 0;
	margin: 0;
}
.cmp_breadcrumbs a {
	color: var(--recima21-primary);
	text-decoration: none;
}
.cmp_breadcrumbs a:hover { text-decoration: underline; }
.cmp_breadcrumbs .separator { color: var(--recima21-text-muted); margin: 0 0.1rem; }
.cmp_breadcrumbs .current span,
.cmp_breadcrumbs li.current { color: var(--recima21-text-muted); }

/* ============================================================
   Contador / mensagens de busca
   ============================================================ */
.monograph_count,
.search_results {
	color: var(--recima21-text-muted);
	font-size: 0.95rem;
	margin-bottom: 1.5rem;
}
.search_results a { color: var(--recima21-primary); }

/* ============================================================
   Grade de livros (catálogo, busca, lançamentos da home)
   ============================================================ */
.cmp_monographs_list {
	display: grid;
	grid-template-columns: 1fr; /* celular: 1 coluna */
	gap: 2.25rem 1.75rem;
	margin: 0 0 2.5rem;
}
@media (min-width: 576px) {
	.cmp_monographs_list { grid-template-columns: repeat(2, 1fr); } /* celular grande/tablet pequeno: 2 colunas */
}
@media (min-width: 768px) {
	.cmp_monographs_list { grid-template-columns: repeat(3, 1fr); } /* tablet/desktop: 3 colunas */
}
/* As <div class="row"> que pareiam os itens não devem quebrar a grade */
.cmp_monographs_list .row { display: contents; }
/* Título de seção opcional (Destacado, Lançamentos) ocupa a linha toda */
.cmp_monographs_list > .title,
.cmp_monographs_list > h2.title,
.cmp_monographs_list > h3.title {
	grid-column: 1 / -1;
	font-family: var(--font-serif);
	font-size: 1.6rem;
	color: var(--recima21-text);
	margin: 0 0 0.25rem;
	padding-bottom: 0.6rem;
	border-bottom: 2px solid var(--recima21-border);
}

.obj_monograph_summary {
	display: flex;
	flex-direction: column;
	background: var(--recima21-surface);
	border: 1px solid var(--recima21-border);
	border-radius: var(--radius);
	overflow: hidden;
	box-shadow: var(--shadow);
	transition: transform var(--transition), box-shadow var(--transition);
}
.obj_monograph_summary:hover {
	transform: translateY(-4px);
	box-shadow: var(--shadow-hover);
}
.obj_monograph_summary .cover {
	display: block;
	background: var(--recima21-bg);
	aspect-ratio: 3 / 4;
	overflow: hidden;
}
.obj_monograph_summary .cover img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}
.obj_monograph_summary .seriesPosition {
	font-size: 0.78rem;
	color: var(--recima21-text-muted);
	padding: 0.5rem 0.85rem 0;
}
.obj_monograph_summary .title {
	margin: 0;
	padding: 0.75rem 0.85rem 0.35rem;
	font-family: var(--font-serif);
	font-size: 1.02rem;
	line-height: 1.25;
	/* Limita o título a 4 linhas com reticências (cards uniformes) */
	display: -webkit-box;
	-webkit-line-clamp: 4;
	line-clamp: 4;
	-webkit-box-orient: vertical;
	overflow: hidden;
}
.obj_monograph_summary .title a {
	color: var(--recima21-text);
	text-decoration: none;
}
.obj_monograph_summary .title a:hover { color: var(--recima21-primary); }
.obj_monograph_summary .author {
	padding: 0 0.85rem;
	font-size: 0.85rem;
	color: var(--recima21-text-muted);
	/* Limita a lista de autores a 4 linhas (livros com dezenas de autores) */
	display: -webkit-box;
	-webkit-line-clamp: 4;
	line-clamp: 4;
	-webkit-box-orient: vertical;
	overflow: hidden;
}
.obj_monograph_summary .date {
	margin-top: auto;
	padding: 0.6rem 0.85rem 0.85rem;
	font-size: 0.8rem;
	color: var(--recima21-text-muted);
}

/* Item em destaque: card horizontal ocupando a linha inteira */
.obj_monograph_summary.is_featured {
	grid-column: 1 / -1;
	flex-direction: row;
	align-items: stretch;
}
.obj_monograph_summary.is_featured .cover {
	flex: 0 0 180px;
	aspect-ratio: 3 / 4;
}
.obj_monograph_summary.is_featured .title { font-size: 1.3rem; padding-top: 1.1rem; }
.obj_monograph_summary.is_featured .title,
.obj_monograph_summary.is_featured .author,
.obj_monograph_summary.is_featured .date { padding-left: 1.25rem; padding-right: 1.25rem; }

@media (max-width: 575px) {
	.cmp_monographs_list { gap: 1.5rem 1rem; }
	.obj_monograph_summary.is_featured { flex-direction: column; }
	.obj_monograph_summary.is_featured .cover { flex-basis: auto; }
}

/* ============================================================
   Paginação
   ============================================================ */
.cmp_pagination {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 1rem;
	margin: 2rem 0;
	color: var(--recima21-text-muted);
	font-size: 0.9rem;
}
.cmp_pagination .prev,
.cmp_pagination .next {
	display: inline-block;
	padding: 0.5rem 1rem;
	border: 1px solid var(--recima21-border);
	border-radius: 999px;
	color: var(--recima21-primary);
	text-decoration: none;
	background: var(--recima21-surface);
	transition: background var(--transition), color var(--transition);
}
.cmp_pagination .prev:hover,
.cmp_pagination .next:hover {
	background: var(--recima21-primary);
	color: #fff;
}

/* ============================================================
   Página do livro (.obj_monograph_full)
   ============================================================ */
.obj_monograph_full > .title {
	font-family: var(--font-serif);
	font-size: 2.2rem;
	line-height: 1.15;
	color: var(--recima21-text);
	margin: 0 0 1.5rem;
}
.obj_monograph_full > .row {
	display: grid;
	grid-template-columns: minmax(0, 1fr) 320px;
	gap: 2.5rem;
	align-items: start;
}
@media (max-width: 767px) {
	.obj_monograph_full > .row { grid-template-columns: 1fr; }
	.obj_monograph_full .entry_details { order: -1; }
}

.obj_monograph_full .item { margin-bottom: 1.75rem; }
.obj_monograph_full .item > .label,
.obj_monograph_full .item > h2.label,
.obj_monograph_full .item > h3.label {
	font-family: var(--font-serif);
	font-size: 1.15rem;
	color: var(--recima21-text);
	margin: 0 0 0.5rem;
}
.obj_monograph_full .item .value { color: var(--recima21-text); }
.obj_monograph_full .item.abstract .value { line-height: 1.7; }
.obj_monograph_full .item.doi .value a,
.obj_monograph_full .item .value a { color: var(--recima21-primary); }
.obj_monograph_full .item.keywords .value { color: var(--recima21-text-muted); }

/* Sidebar de detalhes */
.obj_monograph_full .entry_details {
	background: var(--recima21-surface);
	border: 1px solid var(--recima21-border);
	border-radius: var(--radius-lg);
	padding: 1.5rem;
	box-shadow: var(--shadow);
}
.obj_monograph_full .entry_details .item.cover { text-align: center; margin-bottom: 1.5rem; }
.obj_monograph_full .entry_details .item.cover img {
	max-width: 100%;
	border-radius: var(--radius);
	box-shadow: var(--shadow);
}
.obj_monograph_full .entry_details .item { margin-bottom: 1.25rem; }
.obj_monograph_full .entry_details .label { font-size: 0.95rem; }
.obj_monograph_full .entry_details .sub_item { margin-bottom: 0.75rem; }
.obj_monograph_full .item.categories ul,
.obj_monograph_full .item.series ul { list-style: none; padding: 0; margin: 0; }
.obj_monograph_full .item.categories a { color: var(--recima21-primary); }

/* Capítulos */
.obj_monograph_full .item.chapters > ul { list-style: none; padding: 0; margin: 0; }
.obj_monograph_full .item.chapters > ul > li {
	padding: 1rem 0;
	border-bottom: 1px solid var(--recima21-border);
}
.obj_monograph_full .item.chapters .title {
	font-family: var(--font-serif);
	font-size: 1.05rem;
	color: var(--recima21-text);
}
.obj_monograph_full .item.chapters a { text-decoration: none; }
.obj_monograph_full .item.chapters a:hover .title { color: var(--recima21-primary); }
.obj_monograph_full .item.chapters .authors { font-size: 0.85rem; color: var(--recima21-text-muted); }

/* Botões de download / formatos de publicação */
.cmp_download_link,
.obj_monograph_full .publication_format a {
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
}
.cmp_download_link {
	padding: 0.55rem 1rem;
	margin: 0.3rem 0;
	background: var(--recima21-primary);
	color: #fff !important;
	border-radius: var(--radius);
	text-decoration: none;
	font-weight: 600;
	font-size: 0.9rem;
	transition: background var(--transition);
}
.cmp_download_link:hover { background: var(--recima21-primary-hover); }
.obj_monograph_full .item.files .label { margin-bottom: 0.75rem; }

/* Notificações (preview, versão antiga) */
.cmp_notification {
	padding: 0.85rem 1.1rem;
	border-radius: var(--radius);
	background: var(--recima21-primary-light);
	border: 1px solid var(--recima21-border);
	color: var(--recima21-text);
	margin-bottom: 1.5rem;
}

/* ============================================================
   Formulário de busca
   ============================================================ */
.page_search [id="search-form"] + form,
.page_search form#searchForm,
.page_search .search_form,
.cmp_search {
	margin-top: 2rem;
}
.page_search input[type="search"],
.page_search input[type="text"] {
	padding: 0.7rem 1rem;
	border: 1px solid var(--recima21-border);
	border-radius: var(--radius);
	background: var(--recima21-surface);
	color: var(--recima21-text);
	font-size: 1rem;
	width: 100%;
	max-width: 420px;
}
.cmp_button,
.page_search button[type="submit"],
.page_search input[type="submit"] {
	display: inline-block;
	padding: 0.7rem 1.5rem;
	background: var(--recima21-primary);
	color: #fff;
	border: none;
	border-radius: var(--radius);
	font-weight: 600;
	cursor: pointer;
	text-decoration: none;
	transition: background var(--transition);
}
.cmp_button:hover,
.page_search button[type="submit"]:hover { background: var(--recima21-primary-hover); }

/* ============================================================
   Páginas estáticas / sobre / conteúdo de texto
   ============================================================ */
.site-main > .page p,
.site-main > .page li { line-height: 1.7; }
/* Links apenas na prosa/texto das páginas estáticas (não nos cards de livro) */
.site-main > .page p a,
.site-main > .page li a,
.site-main > .page .static-page-content a,
.static-page-content a { color: var(--recima21-primary); }
.site-main > .page > h2,
.site-main > .page > h3,
.static-page-content h2,
.static-page-content h3 {
	font-family: var(--font-serif);
	color: var(--recima21-text);
	margin-top: 2rem;
}
.site-main > .page img { max-width: 100%; height: auto; }

/* Navegação por séries no catálogo */
.pkp_series_nav_menu ul {
	list-style: none;
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem 1rem;
	padding: 0;
}
.pkp_series_nav_menu a { color: var(--recima21-primary); text-decoration: none; }
.pkp_series_nav_menu a:hover { text-decoration: underline; }

/* ============================================================
   Formulários de conta (login, cadastro, recuperação de senha)
   ============================================================ */
/* Largura da página: estreita p/ login, média p/ cadastro */
.site-main > .page.page_login,
.site-main > .page.page_lostPassword,
.site-main > .page.page_lost_password,
.site-main > .page.page_changePassword,
.site-main > .page.page_change_password { max-width: 480px; }
.site-main > .page.page_register { max-width: 780px; }

.page_login > h1,
.page_register > h1,
.page_lostPassword > h1,
.page_lost_password > h1,
.page_change_password > h1 {
	text-align: center;
	margin-bottom: 0.5rem;
}
.page_login > p,
.page_register > p,
.page_lostPassword > p,
.page_lost_password > p,
.page_change_password > p {
	text-align: center;
	color: var(--recima21-text-muted);
	font-size: 0.9rem;
	margin: 0 auto 1.5rem;
}
.page_login .cmp_breadcrumbs ol,
.page_register .cmp_breadcrumbs ol,
.page_lost_password .cmp_breadcrumbs ol { justify-content: center; }

/* Card do formulário */
.cmp_form {
	background: var(--recima21-surface);
	border: 1px solid var(--recima21-border);
	border-radius: var(--radius-lg);
	box-shadow: var(--shadow);
	padding: 2.25rem;
}

/* Fieldsets e legendas (seções do formulário) */
.cmp_form fieldset {
	border: none;
	padding: 0;
	margin: 0 0 1.75rem;
	min-width: 0;
}
.cmp_form fieldset:last-of-type { margin-bottom: 0; }
.cmp_form legend {
	display: block;
	width: 100%;
	font-family: var(--font-serif);
	font-size: 1.2rem;
	font-weight: 600;
	color: var(--recima21-text);
	padding: 0 0 0.6rem;
	margin-bottom: 1.25rem;
	border-bottom: 1px solid var(--recima21-border);
}

/* Grade de campos: cadastro em 2 colunas, login em 1 coluna */
.cmp_form .fields { display: grid; grid-template-columns: 1fr 1fr; gap: 1.1rem 1.25rem; }
.cmp_form.login .fields,
.cmp_form.lostPassword .fields { grid-template-columns: 1fr; }
/* Campos que ocupam a linha inteira */
.cmp_form .affiliation,
.cmp_form .reviewer_interests,
.cmp_form .reviewer_nocontext_interests,
.cmp_form .remember,
.cmp_form .optin,
.cmp_form .recaptcha,
.cmp_form .g-recaptcha { grid-column: 1 / -1; }
@media (max-width: 575px) {
	.cmp_form .fields { grid-template-columns: 1fr; }
	.cmp_form { padding: 1.5rem; }
}

/* Labels */
.cmp_form label { display: block; }
.cmp_form .label {
	display: block;
	font-weight: 600;
	font-size: 0.88rem;
	color: var(--recima21-text);
	margin-bottom: 0.4rem;
}
.cmp_form .required { color: #dc3545; margin-left: 0.15rem; }

/* Inputs e selects */
.cmp_form input[type="text"],
.cmp_form input[type="email"],
.cmp_form input[type="password"],
.cmp_form input[type="url"],
.cmp_form input[type="tel"],
.cmp_form select,
.cmp_form textarea {
	width: 100%;
	padding: 0.7rem 0.9rem;
	border: 1px solid var(--recima21-border);
	border-radius: var(--radius);
	background: var(--recima21-surface);
	color: var(--recima21-text);
	font-size: 1rem;
	font-family: inherit;
	transition: border-color var(--transition), box-shadow var(--transition);
}
.cmp_form input:focus,
.cmp_form select:focus,
.cmp_form textarea:focus {
	outline: none;
	border-color: var(--recima21-primary);
	box-shadow: 0 0 0 3px var(--recima21-primary-light);
}
.cmp_form select { appearance: auto; }

/* Link "esqueci a senha" dentro do campo de senha */
.cmp_form .password label a {
	display: inline-block;
	margin-top: 0.45rem;
	font-size: 0.85rem;
	color: var(--recima21-primary);
	text-decoration: none;
}
.cmp_form .password label a:hover { text-decoration: underline; }

/* Checkboxes (lembrar, consentimentos, reviewer) */
.cmp_form .checkbox label,
.cmp_form .optin label,
.cmp_form #reviewerOptinGroup label {
	display: flex;
	align-items: flex-start;
	gap: 0.55rem;
	font-size: 0.9rem;
	color: var(--recima21-text-muted);
	line-height: 1.5;
	cursor: pointer;
}
.cmp_form input[type="checkbox"],
.cmp_form input[type="radio"] {
	width: auto;
	margin: 0.2rem 0 0;
	flex: 0 0 auto;
	accent-color: var(--recima21-primary);
}
.cmp_form .checkbox .label,
.cmp_form .optin .label,
.cmp_form .remember .label {
	display: inline;
	font-weight: 400;
	margin: 0;
	font-size: 0.9rem;
	color: var(--recima21-text-muted);
}
.cmp_form .optin label a,
.cmp_form .checkbox label a { color: var(--recima21-primary); }
.cmp_form fieldset.consent,
.cmp_form fieldset.reviewer { margin-top: 0.5rem; }
.cmp_form fieldset.consent .fields,
.cmp_form fieldset.reviewer .fields { gap: 0.85rem; }

/* Botões */
.cmp_form .buttons {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 1rem 1.5rem;
	margin-top: 1.75rem;
	padding-top: 1.5rem;
	border-top: 1px solid var(--recima21-border);
}
.cmp_form .buttons button.submit,
.cmp_form button[type="submit"] {
	background: var(--recima21-primary);
	color: #fff;
	border: none;
	padding: 0.8rem 2.25rem;
	border-radius: var(--radius);
	font-weight: 600;
	font-size: 1rem;
	cursor: pointer;
	transition: background var(--transition), transform var(--transition);
}
.cmp_form .buttons button.submit:hover,
.cmp_form button[type="submit"]:hover { background: var(--recima21-primary-hover); }
.cmp_form .buttons button.submit:active { transform: translateY(1px); }
.cmp_form .buttons a { color: var(--recima21-primary); font-size: 0.92rem; text-decoration: none; }
.cmp_form .buttons a:hover { text-decoration: underline; }

/* Mensagens de erro do formulário */
.cmp_form .pkp_form_error,
.page_login .pkp_form_error,
.cmp_form .error,
.cmp_form ul.errors {
	background: rgba(220, 53, 69, 0.08);
	border: 1px solid rgba(220, 53, 69, 0.3);
	color: #b02a37;
	padding: 0.85rem 1.1rem;
	border-radius: var(--radius);
	margin-bottom: 1.25rem;
	font-size: 0.9rem;
	list-style: none;
}
.cmp_form ul.errors { padding-left: 1.1rem; }

/* Spam blockers */
.cmp_form .recaptcha_wrapper,
.cmp_form .altcha_wrapper { margin: 0.5rem 0 0; }

/* ============================================================
   Dropdown de navegação aberto por clique (itens com submenu
   não navegam — ver recima21-landing.js)
   ============================================================ */
@media (min-width: 900px) {
	.nav-list .has-submenu.is-open > .submenu {
		opacity: 1;
		visibility: visible;
		transform: translateY(0);
	}
}
/* Cursor de "expandir" no pai com submenu */
.nav-list .has-submenu > a.nav-link { cursor: pointer; }

/* ============================================================
   Breadcrumb órfão (páginas de conteúdo de item de menu / NMI custom:
   o breadcrumb fica FORA do .page, como filho direto do <main>)
   ============================================================ */
.site-main > .cmp_breadcrumbs {
	max-width: var(--max-width);
	margin: 0 auto;
	padding: 2rem 1.25rem 0;
}
@media (min-width: 768px) {
	.site-main > .cmp_breadcrumbs { padding-left: 2rem; padding-right: 2rem; }
}
/* O .page logo após esse breadcrumb não precisa do padding-top cheio */
.site-main > .cmp_breadcrumbs + .page { padding-top: 0.75rem; }
/* Conteúdo das páginas de NMI: melhor leitura */
.page > .page_title { margin-bottom: 1.25rem; }

/* ============================================================
   URLs longas (DOI, referências, links) não devem estourar o layout
   ============================================================ */
.obj_monograph_full .item .value,
.obj_monograph_full .item.doi,
.obj_monograph_full .item .value a,
.obj_monograph_full .sub_item .value a,
.obj_monograph_full .item.references .value,
.obj_monograph_full .item.chapters .doi a,
.obj_monograph_full a {
	overflow-wrap: anywhere;
	word-break: break-word;
}

/* ============================================================
   Capa na página do livro: ocupar a largura da sidebar (era minúscula —
   o OMP usa thumbnail ~71px; o JS troca pela capa cheia)
   ============================================================ */
.obj_monograph_full .entry_details .item.cover {
	margin-bottom: 1.5rem;
}
.obj_monograph_full .entry_details .item.cover img {
	width: 100%;
	max-width: 100%;
	height: auto;
	border-radius: var(--radius);
	box-shadow: var(--shadow-hover);
	background: var(--recima21-bg);
}

/* ============================================================
   Corrige scroll horizontal fantasma: o submenu (position:fixed) ficava,
   antes do 1º hover, numa posição padrão que estourava à direita.
   Ancoramos o fechado em left:0; o JS reposiciona ao abrir (inline > CSS).
   ============================================================ */
@media (min-width: 900px) {
	.nav-list .submenu { left: 0; }
}

/* ============================================================
   Página de contato — cards lado a lado com ícones
   ============================================================ */
.page_contact .contact_section {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
	gap: 1.5rem;
	margin-top: 1rem;
}
.page_contact .address {
	grid-column: 1 / -1;
	background: var(--recima21-primary-light);
	border: 1px solid var(--recima21-border);
	border-radius: var(--radius);
	padding: 1.1rem 1.4rem;
	color: var(--recima21-text);
	line-height: 1.6;
}
.page_contact .contact {
	background: var(--recima21-surface);
	border: 1px solid var(--recima21-border);
	border-radius: var(--radius-lg);
	box-shadow: var(--shadow);
	padding: 1.75rem;
}
.page_contact .contact h2 {
	font-family: var(--font-serif);
	font-size: 1.3rem;
	color: var(--recima21-text);
	margin: 0 0 1rem;
	padding-bottom: 0.6rem;
	border-bottom: 2px solid var(--recima21-border);
}
.page_contact .contact .name {
	font-weight: 600;
	font-size: 1.05rem;
	color: var(--recima21-text);
	margin-bottom: 0.2rem;
}
.page_contact .contact .title,
.page_contact .contact .affiliation {
	color: var(--recima21-text-muted);
	font-size: 0.92rem;
	margin-bottom: 0.15rem;
}
.page_contact .contact .phone,
.page_contact .contact .email {
	margin-top: 0.85rem;
	display: flex;
	align-items: baseline;
	gap: 0.6rem;
	font-size: 0.95rem;
	color: var(--recima21-text);
}
.page_contact .contact .phone .label { color: var(--recima21-text-muted); margin-right: 0.25rem; }
.page_contact .contact .email a { color: var(--recima21-primary); overflow-wrap: anywhere; }
/* Ícones (FontAwesome 5/6 Free, solid) */
.page_contact .contact .phone::before,
.page_contact .contact .email::before {
	font-family: "Font Awesome 6 Free", "Font Awesome 5 Free";
	font-weight: 900;
	color: var(--recima21-primary);
	flex: 0 0 auto;
	width: 1.1em;
	text-align: center;
}
.page_contact .contact .phone::before { content: "\f095"; }
.page_contact .contact .email::before { content: "\f0e0"; }

/* ============================================================
   Acessibilidade: texto exclusivo p/ leitor de tela.
   O PKP usa .pkp_screen_reader em vários lugares (ex.: o texto "Abrir nova
   página para editar..." ao lado dos títulos editáveis quando logado, e labels
   ocultos na página do livro). Sem esta regra, ele aparece como texto normal.
   ============================================================ */
.pkp_screen_reader {
	position: absolute !important;
	width: 1px !important;
	height: 1px !important;
	padding: 0 !important;
	margin: -1px !important;
	overflow: hidden !important;
	clip: rect(0, 0, 0, 0) !important;
	white-space: nowrap !important;
	border: 0 !important;
}

/* Link "Editar" (visível só p/ gestores) ao lado dos títulos de conteúdo */
.cmp_edit_link {
	display: inline-flex;
	align-items: center;
	gap: 0.3rem;
	margin-left: 0.6rem;
	padding: 0.15rem 0.7rem;
	font-family: var(--font-sans);
	font-size: 0.72rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.02em;
	line-height: 1.6;
	color: var(--recima21-primary);
	background: var(--recima21-primary-light);
	border: 1px solid var(--recima21-border);
	border-radius: 999px;
	text-decoration: none;
	vertical-align: middle;
	white-space: nowrap;
}
.cmp_edit_link:hover { background: var(--recima21-primary); color: #fff; }

/* Página de submissões: seções e títulos consistentes */
.page_submissions h2 {
	font-family: var(--font-serif);
	font-size: 1.5rem;
	color: var(--recima21-text);
	margin: 2rem 0 0.85rem;
}
.page_submissions .author_guidelines,
.page_submissions .submission_checklist,
.page_submissions .privacy_statement { margin-bottom: 1.5rem; }
.page_submissions ul { padding-left: 1.25rem; }
.page_submissions li { margin-bottom: 0.4rem; }

/* ============================================================
   Visualizador de PDF (plugin pdfJsViewer, op "view"): barra fina no topo
   (voltar + título + download) e o visualizador NATIVO do PDF preenchendo abaixo.
   ============================================================ */
body.pkp_op_view {
	margin: 0;
	height: 100vh;
	overflow: hidden;
	display: flex;
	flex-direction: column;
	background: var(--recima21-bg);
}
body.pkp_op_view .header_viewable_file {
	flex: 0 0 auto;
	display: flex;
	align-items: center;
	gap: 1rem;
	height: 52px;
	padding: 0 0.85rem;
	background: var(--recima21-footer-bg);
	color: #fff;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.18);
	z-index: 2;
}
body.pkp_op_view .header_viewable_file .return {
	flex: 0 0 auto;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 38px;
	height: 38px;
	border-radius: 50%;
	color: #fff;
	text-decoration: none;
	transition: background var(--transition);
}
body.pkp_op_view .header_viewable_file .return:hover { background: rgba(255, 255, 255, 0.15); }
body.pkp_op_view .header_viewable_file .return::before {
	font-family: "Font Awesome 6 Free", "Font Awesome 5 Free";
	font-weight: 900;
	content: "\f060"; /* arrow-left */
	font-size: 1rem;
}
body.pkp_op_view .header_viewable_file .title {
	flex: 1 1 auto;
	min-width: 0;
	font-family: var(--font-serif);
	font-size: 1.02rem;
	color: #fff;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}
body.pkp_op_view .header_viewable_file .download {
	flex: 0 0 auto;
	display: inline-flex;
	align-items: center;
	gap: 0.45rem;
	background: var(--recima21-primary);
	color: #fff;
	padding: 0.5rem 1.1rem;
	border-radius: var(--radius);
	text-decoration: none;
	font-weight: 600;
	font-size: 0.85rem;
}
body.pkp_op_view .header_viewable_file .download:hover { background: var(--recima21-primary-hover); }
body.pkp_op_view .header_viewable_file .download::before {
	font-family: "Font Awesome 6 Free", "Font Awesome 5 Free";
	font-weight: 900;
	content: "\f019"; /* download */
}
body.pkp_op_view #pdfCanvasContainer.viewable_file_frame {
	flex: 1 1 auto;
	min-height: 0;
	width: 100%;
	height: auto; /* sobrepõe o height:100vh do #pdfCanvasContainer */
	margin: 0; /* remove o margin-top:30px do #pdfCanvasContainer → barra colada no leitor */
	padding: 0;
	border: 0;
}
body.pkp_op_view .viewable_file_frame iframe {
	display: block;
	width: 100%;
	height: 100%;
	border: 0;
}
/* Aviso de versão desatualizada (quando aplicável) */
body.pkp_op_view .viewable_file_frame_notice {
	background: var(--recima21-primary-light);
	color: var(--recima21-text);
	padding: 0.6rem 1rem;
	font-size: 0.85rem;
	text-align: center;
}

/* ============================================================
   Tela grande (>=900px): centralizar a logo verticalmente na faixa do header.
   No flex original a logo fica na 1ª linha (topo) e a nav na 2ª (embaixo/direita),
   deixando a logo "colada no topo". Aqui usamos grid: logo na coluna esquerda
   ocupando as 2 linhas e centralizada; controles (topo) + nav (baixo) à direita.
   ============================================================ */
@media (min-width: 900px) {
	.site-header .header-inner {
		display: grid;
		grid-template-columns: auto 1fr;
		align-items: center;
		column-gap: 1.5rem;
		row-gap: 0.15rem;
		/* padding horizontal p/ a logo não colar na borda quando a viewport
		   chega perto do max-width (ex.: ~1160px) — alinha com o conteúdo */
		padding-left: 2rem;
		padding-right: 2rem;
	}
	.site-header .header-inner > .nav-toggle { display: none; }
	.site-header .header-inner > .logo {
		grid-column: 1;
		grid-row: 1 / span 2;
		align-self: center;
	}
	.site-header .header-inner > .header-controls {
		grid-column: 2;
		grid-row: 1;
		justify-self: end;
	}
	.site-header .header-inner > .main-nav {
		grid-column: 2;
		grid-row: 2;
	}
	/* Compacto (ao rolar) em tela grande: NÃO mostrar o hambúrguer — manter a nav
	   visível (o tema OJS colapsava p/ hambúrguer em qualquer largura). O hambúrguer
	   só deve aparecer em telas pequenas (< 900px). A logo só encolhe. */
	.site-header.is-compact .nav-toggle { display: none !important; }
	.site-header.is-compact .main-nav { display: flex !important; }
}

/* ============================================================
   Respiro vertical do header em telas pequenas e no estado compacto
   (a logo estava colando na borda inferior da faixa).
   ============================================================ */
@media (max-width: 899px) {
	.site-header .header-inner {
		padding-top: 0.75rem;
		padding-bottom: 0.75rem;
	}
}
.site-header.is-compact .header-inner {
	padding-top: 0.6rem;
	padding-bottom: 0.6rem;
}
