/* =========================================================================
   Melina Souza — folha de estilos principal
   Sumário:
   1. Reset & tokens
   2. Fade suave de entrada (página + imagens)
   3. Tipografia base
   4. Header & navegação
   5. Hero / carrossel dos últimos posts
   6. Grade de posts & paginação
   7. Barra lateral
   8. Artigo (single) & conteúdo do Elementor
   9. Comentários
   10. Seção do Instagram
   11. Rodapé
   12. Responsivo
   ========================================================================= */

/* ---------- 1. Reset & tokens ---------- */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
	margin: 0;
	background: var(--melina-bg);
	color: var(--melina-text);
	font-family: var(--melina-font-serif);
	font-size: 17px;
	line-height: 1.6;
	-webkit-font-smoothing: antialiased;
}
img { max-width: 100%; display: block; }
a { color: inherit; }
ul { margin: 0; padding: 0; list-style: none; }
button { font: inherit; }
::selection { background: rgba(156, 111, 74, 0.18); }

/* Barra de rolagem da página inteira, nas cores da marca (trilho bege claro, polegar
   na cor mais escura do tema). Firefox usa scrollbar-width/scrollbar-color; Chrome,
   Safari e Edge usam os pseudo-elementos ::-webkit-scrollbar-*. */
html {
	scrollbar-width: thin; /* Firefox */
	scrollbar-color: var(--melina-accent-deep) var(--melina-bg); /* Firefox: polegar / trilho */
}
html::-webkit-scrollbar { width: 14px; }
html::-webkit-scrollbar-track {
	background: var(--melina-bg);
	box-shadow: inset 0 0 6px rgba(40, 28, 18, 0.08);
}
html::-webkit-scrollbar-thumb {
	background: var(--melina-accent-deep);
	border: 3px solid var(--melina-bg);
	border-radius: 999px;
}
html::-webkit-scrollbar-thumb:hover { background: var(--melina-accent); }

:root {
	--melina-accent: #9C6F4A;
	--melina-accent-deep: #6D4827;
	--melina-bg: #F6F1E9;
	--melina-header-bg: #E7DCCC;
	--melina-text: #4D453A;
	--melina-heading: #352F27;
	--melina-muted: #695D4E;
	--melina-muted-2: #827564;
	--melina-muted-3: #9A8B77;
	--melina-border-soft: rgba(109, 72, 39, 0.12);
	--melina-border: rgba(109, 72, 39, 0.22);
	--melina-border-strong: rgba(109, 72, 39, 0.28);
	--melina-input-bg: #FBF7F0;
	--melina-tag-bg: #ECE5DA;
	--melina-tag-text: #665F52;
	--melina-panel: #F1E9DC;
	--melina-dropdown-bg: #F2EADD;
	--melina-mobile-nav-bg: #EEE3D1;
	--melina-avatar-bg: #ECE2D2;
	--melina-thread-line: #E8E0D3;
	--melina-divider: #E3DACE;

	--melina-font-serif: 'EB Garamond', Georgia, serif;
	--melina-font-display: 'Marcellus', Georgia, serif;
	--melina-font-script: 'Pinyon Script', cursive;

	--melina-container: 1240px;
}

.melina-container {
	max-width: var(--melina-container);
	margin: 0 auto;
	padding: 0 36px;
}

.screen-reader-text {
	position: absolute !important;
	width: 1px; height: 1px;
	margin: -1px; padding: 0;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	border: 0;
}

/* ---------- 2. Fade suave de entrada + revelação das imagens ao rolar ---------- */
body.melina-page-fade {
	opacity: 0;
	transition: opacity 0.9s cubic-bezier(0.16, 1, 0.3, 1);
}
body.melina-page-fade.is-loaded { opacity: 1; }

/* Toda imagem do conteúdo (grade de posts, artigo, sidebar) some e sobe suavemente até
   ser revelada — seja na entrada do site (as que já aparecem na tela) ou ao rolar a
   página até ela. */
.melina-reveal {
	opacity: 0;
	transform: translateY(28px);
	transition: opacity 1.1s cubic-bezier(0.16, 1, 0.3, 1), transform 1.1s cubic-bezier(0.16, 1, 0.3, 1);
}
.melina-reveal.is-revealed { opacity: 1; transform: translateY(0); }

@media (prefers-reduced-motion: reduce) {
	body.melina-page-fade,
	.melina-reveal { transition: none; opacity: 1; transform: none; }
}

/* ---------- 3. Tipografia base ---------- */
.melina-eyebrow {
	font-family: var(--melina-font-display);
	font-size: 15px;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	color: var(--melina-muted);
}

.melina-script {
	font-family: var(--melina-font-script);
	color: var(--melina-accent-deep);
	line-height: 1;
}

.melina-btn {
	display: inline-block;
	border: 1px solid var(--melina-accent);
	color: var(--melina-accent-deep);
	font-size: 12px;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	text-decoration: none;
	padding: 13px 30px;
	background: transparent;
	cursor: pointer;
	transition: background 0.25s ease, color 0.25s ease;
}
.melina-btn:hover,
.melina-btn:focus-visible {
	background: var(--melina-accent);
	color: #F7F2EA;
}

.melina-tag {
	display: inline-block;
	background: var(--melina-tag-bg);
	color: var(--melina-tag-text);
	font-size: 12px;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	text-decoration: none;
	padding: 7px 15px;
	border: none;
	transition: background 0.2s ease, color 0.2s ease;
}
.melina-tag:hover,
.melina-tag:focus-visible { background: var(--melina-accent); color: #F7F2EA; }

.melina-more-link {
	display: inline-block;
	margin-top: 20px;
	font-size: 14px;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--melina-accent);
	text-decoration: none;
	border-bottom: 1px solid rgba(156, 111, 74, 0.4);
	padding-bottom: 3px;
	transition: color 0.2s ease, border-color 0.2s ease;
}
.melina-more-link:hover,
.melina-more-link:focus-visible { color: var(--melina-accent-deep); border-color: var(--melina-accent-deep); }

/* Pílulas com ícone + rótulo (usado na barra lateral: "Me siga por aí") */
.melina-social-pills {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
}
.melina-social-pills a {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font-size: 13px;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--melina-text);
	text-decoration: none;
	border: 1px solid var(--melina-border);
	padding: 8px 14px;
	transition: background 0.2s ease, color 0.2s ease, border-color 0.2s ease;
}
.melina-social-pills a i { font-size: 13px; }
.melina-social-pills a:hover,
.melina-social-pills a:focus-visible {
	background: var(--melina-accent);
	color: #F7F2EA;
	border-color: var(--melina-accent);
}

/* Círculos só com ícone (usado no rodapé, bio da autora e compartilhar do artigo) */
.melina-social-circles { display: flex; gap: 10px; flex-wrap: wrap; }
.melina-social-circles a {
	width: 34px; height: 34px;
	border-radius: 50%;
	border: 1px solid var(--melina-border-strong);
	display: flex; align-items: center; justify-content: center;
	font-size: 13px;
	color: var(--melina-text);
	text-decoration: none;
	transition: background 0.2s ease, color 0.2s ease, border-color 0.2s ease;
}
.melina-social-circles a:hover,
.melina-social-circles a:focus-visible {
	background: var(--melina-accent);
	color: #F7F2EA;
	border-color: var(--melina-accent);
}

/* ---------- 4. Header & navegação ---------- */
.site-header {
	position: sticky;
	top: 0;
	z-index: 50;
	background: var(--melina-header-bg);
	border-bottom: 1px solid var(--melina-border-soft);
}
.site-header__inner {
	max-width: var(--melina-container);
	margin: 0 auto;
	padding: 8px clamp(16px, 4vw, 36px);
	min-height: 78px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 8px 28px;
}
.site-logo { display: flex; align-items: center; text-decoration: none; color: var(--melina-accent-deep); }
.site-logo svg { display: block; width: 172px; height: 46px; }
.site-logo img { max-height: 46px; width: auto; }

.primary-nav { display: flex; flex-wrap: wrap; align-items: center; gap: 20px; }
.primary-nav ul { display: flex; flex-wrap: wrap; align-items: center; gap: 20px; }
.primary-nav .menu-item { position: relative; }
.primary-nav a {
	display: flex; align-items: center; gap: 4px;
	font-size: 13px; letter-spacing: 0.14em; text-transform: uppercase;
	text-decoration: none; padding: 16px 0; white-space: nowrap;
	color: #3F382E;
	transition: color 0.2s ease;
}
.primary-nav a:hover,
.primary-nav a:focus-visible,
.primary-nav .menu-item:hover > a { color: var(--melina-accent-deep); }

.primary-nav .menu-item-has-children > a::after {
	content: '▾';
	font-size: 9px;
	opacity: 0.55;
	transform: translateY(1px);
}
.primary-nav .sub-menu {
	position: absolute;
	top: 100%; left: 50%;
	transform: translateX(-50%);
	min-width: 196px;
	background: var(--melina-dropdown-bg);
	border: 1px solid rgba(109, 72, 39, 0.16);
	box-shadow: 0 16px 38px rgba(40, 28, 18, 0.16);
	padding: 8px 0;
	z-index: 70;
	display: none;
	flex-direction: column;
	gap: 0;
}
.primary-nav .menu-item:hover > .sub-menu,
.primary-nav .menu-item:focus-within > .sub-menu,
.primary-nav .menu-item.is-open > .sub-menu { display: flex; }
.primary-nav .sub-menu a {
	display: block;
	padding: 9px 22px;
	font-size: 12px;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: #443D32;
	white-space: nowrap;
}
.primary-nav .sub-menu a:hover,
.primary-nav .sub-menu a:focus-visible { background: var(--melina-header-bg); color: var(--melina-accent-deep); }

.menu-toggle {
	display: none;
	border: none; background: transparent; cursor: pointer;
	padding: 10px; margin-right: -10px;
	align-items: center; color: #3F382E;
}
.menu-toggle svg { width: 26px; height: 26px; }

.mobile-nav { display: none !important; }

/* ---------- 5. Hero / carrossel ---------- */
.melina-hero {
	position: relative;
	height: 86vh;
	min-height: 560px;
	max-height: 820px;
	overflow: hidden;
	background: #5C4D40;
	touch-action: pan-y; /* deixa o swipe horizontal livre pro carrossel, sem brigar com o scroll vertical da página */
	cursor: grab;
}
.melina-hero.is-dragging { cursor: grabbing; }
.melina-hero__slide {
	position: absolute; inset: 0;
	opacity: 0;
	pointer-events: none;
	transition: opacity 1.1s ease;
}
.melina-hero__slide.is-active { opacity: 1; pointer-events: auto; }
.melina-hero__img,
.melina-hero__placeholder {
	position: absolute; inset: 0;
	width: 100%; height: 100%;
	object-fit: cover;
	display: block;
}
/* Plugins de otimização de imagem (Imagify e afins) às vezes trocam a <img> por
   <picture> (pra servir WebP/AVIF) e movem a classe do tema pro <picture> em vez de
   manter na <img> interna. Como <picture> é "inline" por padrão, width/height:100%
   sozinho não é suficiente — isso garante que a <img> de dentro também preencha o slide. */
picture.melina-hero__img img {
	width: 100%; height: 100%;
	object-fit: cover;
	display: block;
}
.melina-hero__placeholder {
	background: repeating-linear-gradient(135deg, #6B5A49 0px, #6B5A49 22px, #61513F 22px, #61513F 44px);
}
.melina-hero__scrim {
	position: absolute; inset: 0;
	background: linear-gradient(180deg, rgba(40,30,22,0.30) 0%, rgba(40,30,22,0.12) 35%, rgba(40,30,22,0.32) 100%);
}
.melina-hero__body {
	position: relative;
	height: 100%;
	display: flex; align-items: center; justify-content: center;
	padding: 24px;
}
.melina-hero__card {
	background: rgba(247,242,234,0.84);
	backdrop-filter: blur(3px);
	-webkit-backdrop-filter: blur(3px);
	padding: clamp(28px, 6vw, 46px) clamp(20px, 7vw, 58px);
	max-width: 460px; width: 100%;
	text-align: center;
	box-shadow: 0 18px 50px rgba(40,28,18,0.18);
}
.melina-hero__eyebrow {
	display: inline-block;
	font-size: 12px; letter-spacing: 0.18em; text-transform: uppercase;
	color: var(--melina-muted); margin-bottom: 14px;
}
.melina-hero__title {
	margin: 0;
	font-family: var(--melina-font-display);
	font-weight: 400;
	font-size: clamp(23px, 5.5vw, 33px);
	letter-spacing: 0.16em;
	text-transform: uppercase;
	color: var(--melina-heading);
}
.melina-hero__excerpt {
	margin: 18px 0 26px;
	font-size: 18px; font-style: italic;
	color: #574C3F; line-height: 1.5;
}
.melina-hero__arrow {
	/* Setas ocultas: a navegação do carrossel agora é por toque (swipe) e pelos pontos abaixo. */
	position: absolute; top: 50%; transform: translateY(-50%);
	z-index: 6;
	width: clamp(38px, 7vw, 48px); height: clamp(38px, 7vw, 48px);
	border-radius: 50%; border: none;
	background: rgba(247,242,234,0.55); color: #352F27;
	font-size: 20px; cursor: pointer;
	display: none; align-items: center; justify-content: center;
	transition: background 0.2s ease;
}
.melina-hero__arrow:hover,
.melina-hero__arrow:focus-visible { background: rgba(247,242,234,0.92); }
.melina-hero__arrow--prev { left: clamp(10px, 2.5vw, 26px); }
.melina-hero__arrow--next { right: clamp(10px, 2.5vw, 26px); }
.melina-hero__dots {
	position: absolute; bottom: 24px; left: 0; right: 0; z-index: 6;
	display: flex; justify-content: center; gap: 12px;
}
.melina-hero__dot {
	width: 10px; height: 10px; border-radius: 999px; border: none; padding: 0;
	background: rgba(247,242,234,0.5); cursor: pointer;
	transition: all 0.4s ease;
}
.melina-hero__dot.is-active { width: 26px; background: #F7F2EA; }

/* ---------- 6. Grade de posts & paginação ---------- */
.melina-layout {
	max-width: var(--melina-container);
	margin: 0 auto;
	padding: 76px 36px 96px;
	display: grid;
	grid-template-columns: minmax(0, 1fr) 326px;
	gap: 70px;
	align-items: start;
}
.melina-layout.no-sidebar { grid-template-columns: minmax(0, 1fr); }

.melina-section-heading {
	display: flex; align-items: center; gap: 18px;
	margin-bottom: 44px;
}
.melina-section-heading h1,
.melina-section-heading .melina-eyebrow {
	margin: 0;
	font-family: var(--melina-font-display);
	font-weight: 400;
	font-size: 15px;
	letter-spacing: 0.26em;
	text-transform: uppercase;
	color: var(--melina-muted);
	white-space: nowrap;
}
.melina-section-heading__line { flex: 1; height: 1px; background: var(--melina-divider); }
.melina-clear-filter {
	border: 1px solid var(--melina-border-strong);
	background: transparent;
	color: var(--melina-accent-deep);
	font-family: inherit; font-size: 12px;
	letter-spacing: 0.14em; text-transform: uppercase;
	padding: 6px 14px; cursor: pointer; text-decoration: none;
	display: inline-block;
	transition: background 0.2s ease, color 0.2s ease;
}
.melina-clear-filter:hover,
.melina-clear-filter:focus-visible { background: var(--melina-accent); color: #F7F2EA; border-color: var(--melina-accent); }

.melina-no-results {
	font-size: 19px; font-style: italic; color: var(--melina-muted-3);
	padding: 40px 0;
}
.melina-search-form--compact { max-width: 420px; }

.melina-grid { display: flex; flex-direction: column; gap: 78px; }

.melina-card__media {
	display: block; position: relative;
	width: 100%; aspect-ratio: 16 / 10;
	overflow: hidden; background: #E9E0D3;
	text-decoration: none;
}
.melina-card__media img { width: 100%; height: 100%; object-fit: cover; }
.melina-card__placeholder { display: block; width: 100%; height: 100%; background: #E9E0D3; }
.melina-card__body { margin-top: 26px; }
.melina-card__title-link { display: block; margin: 20px 0 14px; text-decoration: none; }
.melina-card__title {
	margin: 0;
	font-family: var(--melina-font-display);
	font-weight: 400; font-size: 31px; line-height: 1.22;
	letter-spacing: 0.04em; text-transform: uppercase;
	color: var(--melina-heading);
	transition: color 0.2s ease;
}
.melina-card__title-link:hover .melina-card__title,
.melina-card__title-link:focus-visible .melina-card__title { color: var(--melina-accent-deep); }
.melina-card__meta {
	display: flex; align-items: center; gap: 22px;
	color: var(--melina-muted-2); font-size: 14px; letter-spacing: 0.04em;
	margin-bottom: 16px;
}
.melina-card__meta-item { display: inline-flex; align-items: center; gap: 7px; }
.melina-card__excerpt { margin: 0; font-size: 19px; line-height: 1.62; color: var(--melina-text); max-width: 62ch; }

.melina-pagination {
	display: flex; align-items: center; justify-content: center;
	gap: 12px; margin-top: 80px; flex-wrap: wrap;
}
.melina-pagination__item,
.melina-pagination span.melina-pagination__item,
.melina-pagination .melina-pagination__item.dots {
	min-width: 44px; height: 44px;
	display: inline-flex; align-items: center; justify-content: center;
	border: 1px solid var(--melina-border); background: transparent;
	color: var(--melina-text); text-decoration: none;
	font-family: inherit; font-size: 16px; letter-spacing: 0.05em;
	transition: all 0.2s ease;
}
.melina-pagination a.melina-pagination__item:hover,
.melina-pagination a.melina-pagination__item:focus-visible {
	background: var(--melina-accent); color: #F7F2EA; border-color: var(--melina-accent);
}
.melina-pagination .melina-pagination__item.current {
	border-color: var(--melina-accent); background: var(--melina-accent); color: #F7F2EA;
}
.melina-pagination__next {
	min-width: 44px; height: 44px;
	display: inline-flex; align-items: center; justify-content: center;
	border: 1px solid var(--melina-border-strong); background: transparent;
	color: var(--melina-accent-deep); text-decoration: none; font-size: 17px;
	transition: all 0.2s ease;
}
.melina-pagination__next:hover,
.melina-pagination__next:focus-visible { background: var(--melina-accent); color: #F7F2EA; border-color: var(--melina-accent); }

/* ---------- 7. Barra lateral ---------- */
.site-sidebar { display: flex; flex-direction: column; gap: 52px; position: sticky; top: 110px; }
.site-sidebar > div,
.site-sidebar .widget { margin: 0; }

.melina-search-form { position: relative; }
.melina-search-form input[type="search"],
.melina-search-form input[type="text"] {
	width: 100%;
	border: 1px solid var(--melina-border);
	background: var(--melina-input-bg);
	font-family: inherit; font-size: 17px; color: #3F382E;
	padding: 14px 44px 14px 18px;
	outline: none;
	transition: border-color 0.2s ease;
}
.melina-search-form input:focus-visible { border-color: var(--melina-accent); }
.melina-search-form button {
	position: absolute; right: 16px; top: 50%; transform: translateY(-50%);
	color: var(--melina-accent); display: flex;
	border: none; background: transparent; cursor: pointer; padding: 0;
}

.widget-heading,
.site-sidebar h3,
.widget-title {
	margin: 0 0 20px;
	font-family: var(--melina-font-display);
	font-weight: 400; font-size: 15px;
	letter-spacing: 0.22em; text-transform: uppercase;
	color: var(--melina-muted); text-align: center;
}

.melina-about-avatar {
	width: 138px; height: 138px; border-radius: 50%;
	margin: 0 auto 22px; overflow: hidden; position: relative;
	background-size: cover; background-position: center;
	border: 1px solid var(--melina-border-soft);
}
.melina-about-avatar img { width: 100%; height: 100%; object-fit: cover; }
.melina-about-name { display: block; text-align: center; font-family: var(--melina-font-script); font-size: 30px; color: var(--melina-accent-deep); line-height: 1; }
.melina-about-bio { margin: 16px 0 0; text-align: center; font-size: 17px; line-height: 1.62; color: var(--melina-text); }

.melina-follow .melina-social-pills,
.melina-follow .melina-social-circles { justify-content: center; }

.melina-recent-posts { display: flex; flex-direction: column; gap: 18px; }
.melina-recent-posts a { display: flex; gap: 15px; align-items: center; text-decoration: none; }
.melina-recent-posts img { flex: none; width: 72px; height: 72px; object-fit: cover; display: block; }
.melina-recent-posts__title {
	display: block; font-family: var(--melina-font-display);
	font-size: 16px; line-height: 1.32; letter-spacing: 0.04em;
	text-transform: uppercase; color: var(--melina-heading);
}
.melina-recent-posts__date { display: block; margin-top: 6px; font-size: 13px; color: var(--melina-muted-2); letter-spacing: 0.04em; }

.melina-categories,
.melina-archives { display: flex; flex-direction: column; }

/* Mesmo visual (linha com divisória, mesma fonte/tamanho) tanto nos blocos prontos do
   tema quanto no widget clássico do WordPress e no bloco do editor — assim "Categorias"
   e "Arquivos" sempre ficam iguais, não importa como o widget foi adicionado. */
.melina-categories a,
.melina-categories li,
.melina-archives li,
.widget_categories ul li,
.widget_archive ul li,
.wp-block-categories li,
.wp-block-archives li,
.wp-block-categories-list li,
.wp-block-archives-list li {
	display: flex; align-items: center; justify-content: space-between;
	width: 100%; text-align: left;
	font-family: inherit;
	font-size: 17px; letter-spacing: 0.04em; padding: 12px 4px;
	border: none; border-bottom: 1px solid var(--melina-thread-line);
	color: var(--melina-text);
	transition: color 0.2s ease;
}
.melina-categories a,
.melina-archives li a,
.widget_categories ul li a,
.widget_archive ul li a,
.wp-block-categories li a,
.wp-block-archives li a,
.wp-block-categories-list li a,
.wp-block-archives-list li a {
	color: inherit;
	text-decoration: none;
}
.melina-categories a:hover,
.melina-categories a:focus-visible,
.melina-categories a.is-active,
.melina-archives li a:hover,
.melina-archives li a:focus-visible,
.widget_categories ul li a:hover,
.widget_archive ul li a:hover,
.wp-block-categories li a:hover,
.wp-block-archives li a:hover { color: var(--melina-accent-deep); font-weight: 600; }
.melina-categories .count { color: #B2A48F; font-size: 14px; }

/* Estilo genérico para widgets padrão do WordPress soltos na barra lateral */
.widget select,
.widget input[type="text"],
.widget input[type="email"] {
	width: 100%;
	border: 1px solid var(--melina-border);
	background: var(--melina-input-bg);
	font-family: inherit; font-size: 15px; color: var(--melina-text);
	padding: 10px 12px;
}
.widget ul { display: flex; flex-direction: column; }
.widget ul li { padding: 10px 0; border-bottom: 1px solid var(--melina-thread-line); }
.widget a { color: var(--melina-text); text-decoration: none; }
.widget a:hover, .widget a:focus-visible { color: var(--melina-accent-deep); }

/* Widgets de "Categorias" e "Arquivos": altura fixa de 300px com rolagem própria e
   barra de rolagem colorida, pra sidebar não crescer demais quando a lista é grande.
   A altura/rolagem vai direto no elemento (não num filho), pra evitar duas barras de
   rolagem aninhadas. Cobre: os blocos prontos do tema (.melina-categories/.melina-archives),
   o widget clássico do WordPress (.widget_categories/.widget_archive) e os blocos do
   editor (.wp-block-categories/.wp-block-archives), pra funcionar seja qual for a forma
   usada para adicionar esses widgets na barra lateral. */
.melina-categories,
.melina-archives,
.widget_categories,
.widget_archive,
.wp-block-categories,
.wp-block-archives,
.wp-block-categories-list,
.wp-block-archives-list {
	height: 300px;
	overflow-y: auto;
	padding-right: 10px;
	scrollbar-width: thin; /* Firefox */
	scrollbar-color: var(--melina-accent-deep) var(--melina-tag-bg); /* Firefox: polegar / trilho */
}
.melina-categories::-webkit-scrollbar,
.melina-archives::-webkit-scrollbar,
.widget_categories::-webkit-scrollbar,
.widget_archive::-webkit-scrollbar,
.wp-block-categories::-webkit-scrollbar,
.wp-block-archives::-webkit-scrollbar,
.wp-block-categories-list::-webkit-scrollbar,
.wp-block-archives-list::-webkit-scrollbar { width: 8px; }
.melina-categories::-webkit-scrollbar-track,
.melina-archives::-webkit-scrollbar-track,
.widget_categories::-webkit-scrollbar-track,
.widget_archive::-webkit-scrollbar-track,
.wp-block-categories::-webkit-scrollbar-track,
.wp-block-archives::-webkit-scrollbar-track,
.wp-block-categories-list::-webkit-scrollbar-track,
.wp-block-archives-list::-webkit-scrollbar-track { background: var(--melina-tag-bg); }
.melina-categories::-webkit-scrollbar-thumb,
.melina-archives::-webkit-scrollbar-thumb,
.widget_categories::-webkit-scrollbar-thumb,
.widget_archive::-webkit-scrollbar-thumb,
.wp-block-categories::-webkit-scrollbar-thumb,
.wp-block-archives::-webkit-scrollbar-thumb,
.wp-block-categories-list::-webkit-scrollbar-thumb,
.wp-block-archives-list::-webkit-scrollbar-thumb {
	background: var(--melina-accent-deep);
	border: 2px solid var(--melina-tag-bg);
	border-radius: 999px;
}
.melina-categories::-webkit-scrollbar-thumb:hover,
.melina-archives::-webkit-scrollbar-thumb:hover,
.widget_categories::-webkit-scrollbar-thumb:hover,
.widget_archive::-webkit-scrollbar-thumb:hover,
.wp-block-categories::-webkit-scrollbar-thumb:hover,
.wp-block-archives::-webkit-scrollbar-thumb:hover,
.wp-block-categories-list::-webkit-scrollbar-thumb:hover,
.wp-block-archives-list::-webkit-scrollbar-thumb:hover { background: var(--melina-accent); }

/* ---------- 8. Artigo (single) & conteúdo do Elementor ---------- */
.melina-article { min-width: 0; padding: 4px 0 24px; }
.melina-article__back {
	border: none; background: transparent; cursor: pointer;
	font-family: inherit; font-size: 13px; letter-spacing: 0.14em;
	text-transform: uppercase; color: var(--melina-accent);
	text-decoration: none; padding: 0 0 30px; display: inline-block;
	transition: color 0.2s ease;
}
.melina-article__back:hover,
.melina-article__back:focus-visible { color: var(--melina-accent-deep); }
.melina-article__back--end {
	display: block;
	width: 100%;
	text-align: center;
	margin-top: 56px;
	padding: 30px 0 0;
	border-top: 1px solid var(--melina-divider);
}

.melina-article__header { text-align: center; }
.melina-article__title {
	margin: 26px 0 0;
	font-family: var(--melina-font-display);
	font-weight: 400; font-size: clamp(30px, 7.5vw, 50px);
	line-height: 1.08; letter-spacing: 0.12em; text-transform: uppercase;
	color: var(--melina-heading);
}
.melina-article__meta {
	display: flex; align-items: center; justify-content: center; flex-wrap: wrap;
	gap: 18px; margin-top: 22px; color: var(--melina-muted-2);
	font-size: 14px; letter-spacing: 0.05em;
}
.melina-article__meta .dot { width: 4px; height: 4px; border-radius: 50%; background: #C9BBA6; }

.melina-article__thumb {
	margin-top: 46px; width: 100%; aspect-ratio: 4 / 5;
	overflow: hidden;
}
.melina-article__thumb img { width: 100%; height: 100%; object-fit: cover; }

/* Área editada pelo Elementor: tipografia consistente com o restante do site */
.melina-article__content {
	margin-top: 44px;
	font-size: 19px; line-height: 1.78; color: var(--melina-text);
}
.melina-article__content > *:first-child { margin-top: 0; }
.melina-article__content p { margin: 28px 0 0; }
.melina-article__content p:first-of-type {
	font-size: clamp(19px, 2.5vw, 22px); line-height: 1.7; text-align: center;
}
.melina-article__content img {
	width: 100%;
	height: auto;
	display: block;
	max-width: 100%;
}
.melina-article__content figure { margin: 38px 0 0; max-width: 100%; }
/* O design usa imagens sempre em largura total: neutraliza o alinhamento
   esquerda/direita e qualquer largura fixa que o editor (clássico, blocos ou
   Elementor) tenha aplicado numa imagem específica, senão ela fica menor que
   as outras e desalinhada com o texto/imagens ao redor. */
.melina-article__content .alignleft,
.melina-article__content .alignright,
.melina-article__content .aligncenter,
.melina-article__content .alignnone,
.melina-article__content .wp-caption,
.melina-article__content .elementor-image,
.melina-article__content .elementor-widget-container {
	float: none;
	width: auto;
	max-width: 100%;
	margin-left: 0;
	margin-right: 0;
}
.melina-article__content figcaption {
	margin: 14px 0 0; text-align: center; font-size: 15px;
	font-style: italic; color: var(--melina-muted-2);
}
.melina-article__content blockquote {
	margin: 54px 0; padding: 0 12px; text-align: center;
	font-size: clamp(22px, 4.5vw, 30px); line-height: 1.5; font-style: italic;
	color: var(--melina-accent-deep); border: none;
}
.melina-article__content h2,
.melina-article__content h3 {
	font-family: var(--melina-font-display); font-weight: 400;
	text-transform: uppercase; letter-spacing: 0.08em;
	color: var(--melina-heading); margin: 44px 0 0;
}
.melina-article__content a { color: var(--melina-accent-deep); }

.melina-article__footer {
	display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between;
	gap: 18px; margin-top: 50px; padding-top: 28px; border-top: 1px solid var(--melina-divider);
}
.melina-article__tags { display: flex; flex-wrap: wrap; gap: 8px; }
.melina-article__tags span,
.melina-article__tags a {
	font-size: 13px; letter-spacing: 0.1em; text-transform: uppercase;
	color: var(--melina-muted); border: 1px solid var(--melina-border);
	padding: 6px 13px; text-decoration: none;
}
.melina-article__share { display: flex; align-items: center; gap: 12px; }
.melina-article__share-label { font-size: 13px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--melina-muted-2); }

.melina-author-box {
	text-align: center; margin-top: 48px; padding: 40px 32px; background: var(--melina-panel);
}
.melina-author-box__avatar {
	width: 88px; height: 88px; border-radius: 50%; margin: 0 auto 18px; overflow: hidden;
	background-size: cover; background-position: center; border: 1px solid var(--melina-border-soft);
}
.melina-author-box__avatar img { width: 100%; height: 100%; object-fit: cover; }
.melina-author-box__name { display: block; font-family: var(--melina-font-script); font-size: 32px; color: var(--melina-accent-deep); line-height: 1; }
.melina-author-box__bio { margin: 14px auto 0; max-width: 46ch; font-size: 17px; line-height: 1.6; color: var(--melina-text); }
.melina-author-box .melina-social-circles { justify-content: center; margin-top: 18px; }

/* ---------- 9. Comentários ---------- */
.melina-comments { margin-top: 64px; }
.melina-comments__title {
	margin: 0 0 36px;
	font-family: var(--melina-font-display); font-weight: 400; font-size: 24px;
	letter-spacing: 0.1em; text-transform: uppercase; color: var(--melina-heading);
}
.melina-comments ol.comment-list { display: flex; flex-direction: column; gap: 30px; list-style: none; margin: 0; padding: 0; }
.melina-comments ol.comment-list ol.children { display: flex; flex-direction: column; gap: 22px; margin: 22px 0 0 clamp(8px, 4vw, 42px); padding-left: clamp(12px, 3vw, 20px); border-left: 1px solid var(--melina-thread-line); list-style: none; }
.melina-comment__row { display: flex; gap: 16px; }
.melina-comment__avatar {
	flex: none; width: 46px; height: 46px; border-radius: 50%;
	background: var(--melina-avatar-bg); border: 1px solid var(--melina-border-soft);
	display: flex; align-items: center; justify-content: center;
	font-family: var(--melina-font-display); font-size: 18px; color: var(--melina-accent-deep);
}
.melina-comment__avatar--author { width: 40px; height: 40px; background: var(--melina-accent-deep); border: none; font-size: 15px; color: #F7F2EA; }
.melina-comment__content { flex: 1; }
.melina-comment__meta { display: flex; align-items: baseline; gap: 12px; flex-wrap: wrap; }
.melina-comment__name { font-size: 17px; letter-spacing: 0.03em; color: var(--melina-heading); font-weight: 600; }
.melina-comment__badge { font-size: 12px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--melina-accent); }
.melina-comment__date { font-size: 13px; color: #A99C89; }
.melina-comment__text { margin: 7px 0 0; font-size: 17px; line-height: 1.6; color: var(--melina-text); }
.melina-comment__text p { margin: 0; }
.melina-comment__pending { margin: 7px 0 0; font-size: 14px; font-style: italic; color: var(--melina-muted-2); }
.melina-comment__reply a {
	display: inline-block; margin-top: 8px; font-size: 12px; letter-spacing: 0.12em;
	text-transform: uppercase; color: var(--melina-accent); text-decoration: none;
}
.melina-comment__reply a:hover,
.melina-comment__reply a:focus-visible { color: var(--melina-accent-deep); }

.melina-comment-form { margin-top: 56px; padding-top: 40px; border-top: 1px solid var(--melina-divider); }
.melina-comment-form h3 {
	margin: 0 0 8px; font-family: var(--melina-font-display); font-weight: 400; font-size: 22px;
	letter-spacing: 0.08em; text-transform: uppercase; color: var(--melina-heading);
}
.melina-comment-form .comment-notes,
.melina-comment-form .logged-in-as { margin: 0 0 24px; font-size: 16px; color: var(--melina-muted-2); }
.melina-comment-form .comment-form-author,
.melina-comment-form .comment-form-email {
	display: inline-block; width: calc(50% - 8px);
}
.melina-comment-form .comment-form-author { margin-right: 16px; }
.melina-comment-form p { margin: 0 0 16px; }
.melina-comment-form input[type="text"],
.melina-comment-form input[type="email"],
.melina-comment-form input[type="url"],
.melina-comment-form textarea {
	width: 100%;
	border: 1px solid var(--melina-border);
	background: var(--melina-input-bg);
	font-family: inherit; font-size: 17px; color: var(--melina-text);
	padding: 13px 16px; outline: none;
	transition: border-color 0.2s ease;
}
.melina-comment-form textarea { resize: vertical; }
.melina-comment-form input:focus-visible,
.melina-comment-form textarea:focus-visible { border-color: var(--melina-accent); }
.melina-comment-form .form-submit { margin-top: 2px; }
.melina-comment-form input[type="submit"] {
	border: none; background: var(--melina-accent-deep); color: #F7F2EA;
	font-family: inherit; font-size: 13px; letter-spacing: 0.18em; text-transform: uppercase;
	padding: 14px 30px; cursor: pointer; transition: background 0.2s ease;
}
.melina-comment-form input[type="submit"]:hover,
.melina-comment-form input[type="submit"]:focus-visible { background: var(--melina-accent); }

/* ---------- 10. Seção do Instagram ---------- */
.melina-instagram { padding: 60px 0 0; }
.melina-instagram__head { text-align: center; padding: 0 28px; }
.melina-instagram__head p {
	margin: 0; font-family: var(--melina-font-display); font-size: 22px;
	letter-spacing: 0.18em; text-transform: uppercase; color: var(--melina-heading);
}
.melina-instagram__handle {
	display: inline-block; margin-top: 8px; font-size: 17px; letter-spacing: 0.06em;
	color: var(--melina-accent); text-decoration: none; transition: color 0.2s ease;
}
.melina-instagram__handle:hover,
.melina-instagram__handle:focus-visible { color: var(--melina-accent-deep); }
.melina-instagram__grid {
	display: grid; grid-template-columns: repeat(auto-fill, minmax(105px, 1fr));
	gap: 4px; margin-top: 30px;
}
.melina-instagram__grid > * { aspect-ratio: 1 / 1; overflow: hidden; background: #E4DACB; }
.melina-instagram__empty {
	max-width: 560px; margin: 30px auto 0; text-align: center;
	font-size: 15px; font-style: italic; color: var(--melina-muted-3); padding: 0 28px;
}

/* ---------- 11. Rodapé ---------- */
.site-footer { background: var(--melina-header-bg); border-top: 1px solid var(--melina-border-soft); }
.site-footer__inner {
	max-width: var(--melina-container); margin: 0 auto;
	padding: 40px clamp(20px, 4vw, 36px);
	display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between;
	gap: 26px 32px;
}
.site-footer__text { margin: 0; flex: 1 1 280px; font-size: 14px; line-height: 1.6; color: var(--melina-muted); max-width: 38ch; }
.site-footer__name { font-size: 14px; letter-spacing: 0.32em; text-transform: uppercase; color: var(--melina-muted-3); white-space: nowrap; }

/* ---------- 12. Responsivo ---------- */
@media (max-width: 900px) {
	.site-logo svg,
	.site-logo img { width: 128px; height: 34px; }

	.melina-layout,
	.melina-layout.no-sidebar { grid-template-columns: minmax(0, 1fr); padding: 44px 10px 64px; gap: 56px; }
	.site-sidebar { position: static; }
	/* Sem padding lateral próprio: quem define a margem lateral é o .melina-layout (pai),
	   senão a margem do artigo ficava maior que a da home (10px do layout + 10px daqui). */
	.melina-article { padding: 32px 0 24px; }
	.melina-grid { gap: 56px; }

	.primary-nav { display: none; }
	.menu-toggle { display: flex; }
	.mobile-nav.is-open { display: block !important; border-top: 1px solid var(--melina-border-soft); background: var(--melina-mobile-nav-bg); max-height: calc(100vh - 100px); overflow-y: auto; }
	.mobile-nav .menu-item { border-bottom: 1px solid rgba(109, 72, 39, 0.08); }
	.mobile-nav > ul { display: flex; flex-direction: column; }
	.mobile-nav-toggle {
		width: 100%; display: flex; align-items: center; justify-content: space-between;
		padding: 16px 24px; background: transparent; border: none; cursor: pointer;
		font-family: inherit; font-size: 14px; letter-spacing: 0.14em; text-transform: uppercase; color: #3F382E;
	}
	.mobile-nav-toggle .caret { font-size: 10px; opacity: 0.55; transition: transform 0.2s ease; }
	.mobile-nav .menu-item.is-open .caret { transform: rotate(180deg); }
	.mobile-nav .sub-menu { display: none; flex-direction: column; padding: 0 24px 14px; }
	.mobile-nav .menu-item.is-open .sub-menu { display: flex; }
	.mobile-nav .sub-menu a {
		padding: 10px 0; font-size: 13px; letter-spacing: 0.1em; text-transform: uppercase;
		color: var(--melina-muted); text-decoration: none; border-bottom: 1px dashed rgba(109, 72, 39, 0.12);
	}
	.mobile-nav > ul > .menu-item > a { padding: 16px 24px; display: block; }

	.melina-comment-form .comment-form-author,
	.melina-comment-form .comment-form-email { width: 100%; margin-right: 0; }
}

@media (max-width: 600px) {
	.melina-article__title { letter-spacing: 0.06em; }
	.site-footer__inner { justify-content: center; text-align: center; }
}
