/* =============================================================
   Mentes e Leis - main.css (v1.5)
   Paleta: azul (principal) e vermelho (acento)
   Tipografia: Inter (sans-serif)
   ============================================================= */

:root {
	--mel-blue: #1e3a8a;
	--mel-blue-dark: #142a63;
	--mel-blue-light: #3b82f6;
	--mel-blue-50: #eef2ff;
	--mel-red: #c8102e;
	--mel-red-dark: #8a0a1f;
	--mel-red-soft: #fde2e4;
	--mel-ink: #0f172a;
	--mel-muted: #475569;
	--mel-soft: #f4f6fb;
	--mel-line: #e2e8f0;
	--mel-white: #ffffff;
	--mel-radius: 14px;
	--mel-radius-sm: 8px;
	--mel-shadow: 0 10px 30px rgba(20, 42, 99, 0.08);
	--mel-shadow-strong: 0 18px 50px rgba(20, 42, 99, 0.18);
	--mel-container: 1180px;
	--mel-gutter: 1.25rem;
	--mel-font: 'Inter', system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif;
}

/* Reset leve */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
	margin: 0;
	font-family: var(--mel-font);
	color: var(--mel-ink);
	background: var(--mel-white);
	line-height: 1.65;
	font-size: 17px;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}
img, svg { max-width: 100%; height: auto; display: block; }
a { color: var(--mel-blue); text-decoration: none; transition: color .2s ease; }
a:hover, a:focus { color: var(--mel-red); }
h1, h2, h3, h4, h5 { font-family: var(--mel-font); color: var(--mel-ink); margin: 0 0 .6em; line-height: 1.2; font-weight: 700; letter-spacing: -0.01em; }
h1 { font-size: clamp(2rem, 4.6vw, 2.85rem); }
h2 { font-size: clamp(1.6rem, 3.2vw, 2rem); }
h3 { font-size: clamp(1.2rem, 2vw, 1.4rem); }
p { margin: 0 0 1em; }
hr { border: none; border-top: 1px solid var(--mel-line); margin: 2.5rem 0; }
blockquote {
	border-left: 4px solid var(--mel-red);
	background: var(--mel-blue-50);
	padding: 1.1rem 1.4rem;
	margin: 1.6rem 0;
	border-radius: var(--mel-radius-sm);
	color: var(--mel-ink);
	font-style: italic;
}

/* Acessibilidade */
.screen-reader-text { border: 0; clip: rect(1px,1px,1px,1px); -webkit-clip-path: inset(50%); clip-path: inset(50%); height: 1px; margin: -1px; overflow: hidden; padding: 0; position: absolute; width: 1px; word-wrap: normal !important; }
.skip-link { position: absolute; left: -9999px; top: -9999px; background: var(--mel-blue); color: #fff; padding: 12px 16px; border-radius: 0 0 8px 0; z-index: 9999; }
.skip-link:focus { left: 0; top: 0; }

/* Container */
.container { width: 100%; max-width: var(--mel-container); margin: 0 auto; padding: 0 var(--mel-gutter); }

/* ============================================================
   Header GRANDE
   ============================================================ */
.site-header {
	position: sticky;
	top: 0;
	z-index: 50;
	background: rgba(255,255,255,0.97);
	backdrop-filter: saturate(180%) blur(10px);
	-webkit-backdrop-filter: saturate(180%) blur(10px);
	border-bottom: 1px solid var(--mel-line);
	box-shadow: 0 2px 18px rgba(20, 42, 99, 0.04);
}
.site-header__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1.5rem;
	padding: 1.4rem var(--mel-gutter);
	min-height: 140px;
}
.site-branding {
	display: flex;
	align-items: center;
	gap: .9rem;
	min-width: 0;
	color: inherit;
	flex-shrink: 0;
}
.site-branding:hover { color: inherit; }
.site-logo {
	max-height: 130px;
	width: auto;
	display: block;
	object-fit: contain;
	transition: max-height .2s ease;
}
/* Reduz logo no scroll, opcional */
.site-header.is-scrolled .site-logo { max-height: 90px; }
.site-header.is-scrolled .site-header__inner { min-height: 100px; padding-top: 1rem; padding-bottom: 1rem; }

.custom-logo-link img,
.site-branding .custom-logo {
	max-height: 130px;
	width: auto;
}
.site-title { color: var(--mel-blue); font-weight: 800; font-size: 1.6rem; letter-spacing: -0.015em; }

.site-nav { display: flex; align-items: center; }
.primary-menu { list-style: none; display: flex; gap: 2rem; margin: 0; padding: 0; }
.primary-menu > li { position: relative; }
.primary-menu a {
	color: var(--mel-ink);
	font-weight: 600;
	font-size: 1.1rem;
	padding: .5rem 0;
	border-bottom: 3px solid transparent;
	letter-spacing: .01em;
	display: inline-flex;
	align-items: center;
	gap: .35rem;
}
.primary-menu .current-menu-item > a,
.primary-menu a:hover { color: var(--mel-blue); border-bottom-color: var(--mel-red); }

/* Indicador de seta para itens com dropdown */
.primary-menu .menu-item-has-children > a::after {
	content: "";
	width: 8px;
	height: 8px;
	border-right: 2px solid currentColor;
	border-bottom: 2px solid currentColor;
	transform: rotate(45deg) translateY(-2px);
	display: inline-block;
	margin-left: .25rem;
	transition: transform .2s ease;
}
.primary-menu .menu-item-has-children:hover > a::after,
.primary-menu .menu-item-has-children:focus-within > a::after { transform: rotate(225deg) translateY(2px); }

/* Submenu (dropdown no hover) */
.primary-menu .sub-menu {
	list-style: none;
	margin: 0;
	padding: .5rem 0;
	background: var(--mel-white);
	border: 1px solid var(--mel-line);
	border-radius: 12px;
	box-shadow: 0 14px 40px rgba(20, 42, 99, 0.12);
	position: absolute;
	top: calc(100% + 8px);
	left: 0;
	min-width: 240px;
	opacity: 0;
	visibility: hidden;
	transform: translateY(-6px);
	transition: opacity .18s ease, transform .18s ease, visibility .18s;
	z-index: 20;
}
.primary-menu li:hover > .sub-menu,
.primary-menu li:focus-within > .sub-menu { opacity: 1; visibility: visible; transform: translateY(0); }
.primary-menu .sub-menu li { display: block; }
.primary-menu .sub-menu a {
	display: block;
	padding: .55rem 1.2rem;
	font-size: .98rem;
	font-weight: 500;
	color: var(--mel-ink);
	border-bottom: none;
	white-space: nowrap;
}
.primary-menu .sub-menu a:hover { background: var(--mel-blue-50); color: var(--mel-blue); }

.menu-toggle {
	display: none;
	width: 50px; height: 50px;
	background: transparent;
	border: 1px solid var(--mel-line);
	border-radius: 12px;
	cursor: pointer;
	padding: 12px;
	flex-direction: column;
	gap: 5px;
	align-items: center;
	justify-content: center;
}
.menu-toggle__bar { width: 24px; height: 2.5px; background: var(--mel-blue); border-radius: 2px; transition: transform .2s ease, opacity .2s ease; }
.menu-toggle[aria-expanded="true"] .menu-toggle__bar:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.menu-toggle[aria-expanded="true"] .menu-toggle__bar:nth-child(2) { opacity: 0; }
.menu-toggle[aria-expanded="true"] .menu-toggle__bar:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

@media (max-width: 900px) {
	.menu-toggle { display: inline-flex; }
	.site-header__inner { min-height: 110px; padding: 1rem var(--mel-gutter); }
	.site-logo { max-height: 90px; }
	.site-nav {
		position: absolute;
		top: 100%; left: 0; right: 0;
		background: var(--mel-white);
		border-bottom: 1px solid var(--mel-line);
		padding: 1rem var(--mel-gutter);
		display: none;
		box-shadow: 0 10px 24px rgba(20,42,99,0.08);
	}
	.site-nav.is-open { display: block; }
	.primary-menu { flex-direction: column; gap: 0; }
	.primary-menu li { border-bottom: 1px solid var(--mel-line); width: 100%; }
	.primary-menu a { display: block; padding: 1rem 0; font-size: 1.05rem; }
	/* Mobile: submenu sempre visivel (recolhido em "indentado") */
	.primary-menu .sub-menu {
		position: static;
		opacity: 1; visibility: visible; transform: none;
		box-shadow: none; border: none; padding: 0 0 .5rem 1rem;
		min-width: 0;
	}
	.primary-menu .menu-item-has-children > a::after { display: none; }
	.primary-menu .sub-menu a { padding: .55rem 0; font-size: .98rem; color: var(--mel-muted); }
}

@media (max-width: 600px) {
	.site-logo { max-height: 70px; }
	.site-header__inner { min-height: 90px; }
}

/* ============================================================
   Botoes
   ============================================================ */
.btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: .55rem;
	padding: .85rem 1.6rem;
	border-radius: 999px;
	font-weight: 600;
	font-size: 1rem;
	line-height: 1;
	border: 2px solid transparent;
	cursor: pointer;
	transition: transform .15s ease, background .2s ease, color .2s ease, border-color .2s ease;
	text-align: center;
}
.btn:hover { transform: translateY(-1px); }
.btn:focus-visible { outline: 3px solid var(--mel-blue-light); outline-offset: 3px; }
.btn--primary { background: var(--mel-blue); color: var(--mel-white); }
.btn--primary:hover { background: var(--mel-blue-dark); color: var(--mel-white); }
.btn--ghost { background: transparent; color: var(--mel-blue); border-color: var(--mel-blue); }
.btn--ghost:hover { background: var(--mel-blue); color: var(--mel-white); }
.btn--whatsapp { background: #25d366; color: #fff; padding: 1rem 1.8rem; font-size: 1.05rem; box-shadow: 0 12px 30px rgba(37, 211, 102, 0.35); }
.btn--whatsapp:hover { background: #1ebe57; color: #fff; }
.btn__icon { width: 22px; height: 22px; }

/* ============================================================
   Conteudo da Home (editavel via Gutenberg)
   ============================================================ */
.home-content { }
.home-content > .alignfull { width: 100%; max-width: none; margin-left: 0; margin-right: 0; }
.home-content > .alignwide { max-width: 1240px; margin-left: auto; margin-right: auto; }
.home-content > *:not(.alignfull):not(.alignwide) { max-width: 800px; margin-left: auto; margin-right: auto; padding-left: var(--mel-gutter); padding-right: var(--mel-gutter); }
.home-content .wp-block-cover { padding: clamp(3rem, 8vw, 6rem) var(--mel-gutter); }
.home-content .wp-block-cover .wp-block-cover__inner-container { max-width: 760px; }
.home-content .wp-block-buttons { gap: 1rem; }
.home-content .wp-block-button__link { padding: .85rem 1.8rem; font-weight: 600; font-size: 1rem; }

/* ============================================================
   Secoes de pagina interna
   ============================================================ */
.page-hero { background: var(--mel-soft); padding: clamp(2.5rem, 6vw, 4.5rem) 0 clamp(1.8rem, 4vw, 3rem); border-bottom: 1px solid var(--mel-line); }
.page-hero__title { color: var(--mel-blue-dark); margin-bottom: .4rem; }
.page-hero__sub { color: var(--mel-muted); font-size: 1.1rem; margin: 0; max-width: 720px; }

.section-header { text-align: center; margin-bottom: 2rem; }
.section-header__title { color: var(--mel-blue-dark); margin-bottom: .35rem; }
.section-header__sub { color: var(--mel-muted); margin: 0; }

.posts-section { padding: clamp(3rem, 6vw, 5rem) 0; background: var(--mel-white); }
.posts-grid-section { padding: clamp(2rem, 5vw, 3.5rem) 0 clamp(3rem, 6vw, 5rem); }
.posts-section__cta { display: flex; justify-content: center; margin-top: 2.5rem; }

/* ============================================================
   Cards de post
   ============================================================ */
.posts-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
	gap: 1.6rem;
}
.card {
	background: var(--mel-white);
	border: 1px solid var(--mel-line);
	border-radius: var(--mel-radius);
	overflow: hidden;
	box-shadow: var(--mel-shadow);
	transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
	display: flex;
	flex-direction: column;
}
.card:hover { transform: translateY(-3px); box-shadow: var(--mel-shadow-strong); border-color: var(--mel-blue); }
.card__link { display: flex; flex-direction: column; height: 100%; color: inherit; }
.card__link:hover { color: inherit; }
.card__media { aspect-ratio: 16/9; overflow: hidden; background: var(--mel-soft); }
.card__img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s ease; }
.card__img--placeholder { display: grid; place-items: center; padding: 1.5rem; }
.card:hover .card__img { transform: scale(1.04); }
.card__body { padding: 1.3rem 1.4rem 1.5rem; display: flex; flex-direction: column; gap: .55rem; flex: 1; }
.card__cat { color: var(--mel-red); font-size: .8rem; font-weight: 700; text-transform: uppercase; letter-spacing: .05em; }
.card__title { color: var(--mel-blue-dark); font-size: 1.2rem; line-height: 1.3; margin: 0 0 .25rem; }
.card__excerpt { color: var(--mel-muted); margin: 0; font-size: .98rem; }
.card__meta { color: var(--mel-muted); font-size: .82rem; margin-top: auto; padding-top: .6rem; }

.no-posts { text-align: center; color: var(--mel-muted); padding: 2rem 0; }

/* ============================================================
   Toolbar do Blog
   ============================================================ */
.blog-toolbar { padding: 1.6rem 0; background: var(--mel-white); border-bottom: 1px solid var(--mel-line); }
.blog-toolbar__inner { display: flex; align-items: center; justify-content: space-between; gap: 1.2rem; flex-wrap: wrap; }
.cat-pills { display: flex; gap: .5rem; flex-wrap: wrap; }
.cat-pill { padding: .5rem 1.1rem; border-radius: 999px; background: var(--mel-soft); color: var(--mel-blue-dark); font-size: .95rem; font-weight: 500; border: 1px solid transparent; transition: all .15s ease; }
.cat-pill:hover { background: var(--mel-blue-50); color: var(--mel-blue); }
.cat-pill.is-active { background: var(--mel-blue); color: var(--mel-white); border-color: var(--mel-blue); }

.search-form { display: flex; align-items: center; background: var(--mel-soft); border-radius: 999px; padding: .35rem .35rem .35rem 1rem; min-width: 280px; border: 1px solid transparent; transition: border-color .2s; }
.search-form:focus-within { border-color: var(--mel-blue); background: var(--mel-white); }
.search-form__input { flex: 1; border: none; background: transparent; padding: .55rem 0; font: inherit; color: var(--mel-ink); outline: none; min-width: 0; }
.search-form__input::placeholder { color: var(--mel-muted); }
.search-form__submit { width: 40px; height: 40px; border-radius: 999px; border: none; background: var(--mel-blue); color: #fff; cursor: pointer; display: inline-grid; place-items: center; }
.search-form__submit:hover { background: var(--mel-red); }

@media (max-width: 720px) {
	.blog-toolbar__inner { flex-direction: column; align-items: stretch; }
	.search-form { min-width: 0; width: 100%; }
}

/* ============================================================
   Pagina padrao (Sobre, etc.)
   ============================================================ */
.page-article { padding-bottom: 4rem; }
.page-article__content { padding: 2.5rem 1.25rem; }
.page-article__content > * { max-width: 800px; margin-left: auto; margin-right: auto; }
.page-article__content > .alignwide { max-width: 1100px; }
.page-article__content > .alignfull { max-width: none; margin-left: calc(50% - 50vw); margin-right: calc(50% - 50vw); }
.page-article__content img { border-radius: var(--mel-radius); }
.page-article__content h2 { color: var(--mel-blue-dark); margin-top: 2.2rem; }
.page-article__content h3 { color: var(--mel-blue); margin-top: 1.6rem; }
.wp-block-columns { gap: 2rem !important; }
.wp-block-column img { border-radius: var(--mel-radius); }

/* ============================================================
   Single post
   ============================================================ */
.single-post__hero { background: var(--mel-soft); padding: clamp(2.5rem, 6vw, 4rem) 0 clamp(1.6rem, 4vw, 2.5rem); border-bottom: 1px solid var(--mel-line); }
.single-post__cat { display: inline-block; color: var(--mel-red); font-size: .85rem; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; margin-bottom: .8rem; }
.single-post__title { color: var(--mel-blue-dark); max-width: 800px; margin: 0 0 .8rem; }
.single-post__meta { color: var(--mel-muted); font-size: .92rem; }
.single-post__sep { margin: 0 .5rem; }
.single-post__cover { margin: -1.5rem auto 0; padding: 0 1.25rem; max-width: 1140px; }
.single-post__cover img { border-radius: var(--mel-radius); box-shadow: var(--mel-shadow-strong); width: 100%; height: auto; }
.single-post__content { padding: 2.5rem 1.25rem; max-width: 800px; margin: 0 auto; }
.single-post__content > .alignwide { max-width: 1100px; }
.single-post__content > .alignfull { margin-left: calc(50% - 50vw); margin-right: calc(50% - 50vw); max-width: none; }
.single-post__content h2 { color: var(--mel-blue-dark); margin-top: 2.2rem; }
.single-post__content h3 { color: var(--mel-blue); margin-top: 1.6rem; }
.single-post__footer { padding: 1rem 1.25rem 2rem; max-width: 800px; margin: 0 auto; }
.single-post__tags-label { color: var(--mel-muted); margin-right: .4rem; font-size: .9rem; }
.single-post__tag { display: inline-block; margin: .25rem .35rem .25rem 0; padding: .3rem .8rem; border-radius: 999px; background: var(--mel-blue-50); color: var(--mel-blue); font-size: .85rem; }
.single-post__tag:hover { background: var(--mel-blue); color: #fff; }

/* ============================================================
   Secao Contato (home)
   ============================================================ */
.contato-section {
	background: linear-gradient(135deg, var(--mel-blue) 0%, var(--mel-blue-dark) 100%);
	color: var(--mel-white);
	padding: clamp(3rem, 7vw, 5rem) 0;
	text-align: center;
	position: relative;
	overflow: hidden;
}
.contato-section::before { content: ""; position: absolute; inset: 0; background: radial-gradient(circle at 80% 20%, rgba(200, 16, 46, 0.25), transparent 60%); pointer-events: none; }
.contato-section__inner { position: relative; max-width: 720px; margin: 0 auto; padding: 0 1.25rem; }
.contato-section__title { color: var(--mel-white); font-size: clamp(1.8rem, 4vw, 2.5rem); margin-bottom: .8rem; }
.contato-section__text { color: #dbeafe; font-size: 1.1rem; margin-bottom: 1.8rem; }
.contato-section__hint { color: #a5b4fc; font-size: .85rem; margin-top: 1rem; }

/* ============================================================
   Pagination
   ============================================================ */
.pagination { display: flex; justify-content: center; margin-top: 2.5rem; }
.pagination .nav-links { display: flex; gap: .35rem; flex-wrap: wrap; align-items: center; }
.pagination .page-numbers { display: inline-grid; place-items: center; min-width: 40px; height: 40px; padding: 0 .85rem; border-radius: 10px; background: var(--mel-soft); color: var(--mel-ink); font-weight: 600; }
.pagination .page-numbers.current { background: var(--mel-blue); color: var(--mel-white); }
.pagination .page-numbers:hover { background: var(--mel-blue); color: var(--mel-white); }

/* ============================================================
   Footer (branco, logo visivel, menu apenas)
   ============================================================ */
.site-footer {
	background: var(--mel-white);
	color: var(--mel-muted);
	border-top: 1px solid var(--mel-line);
}
.site-footer a { color: var(--mel-ink); transition: color .2s ease; }
.site-footer a:hover { color: var(--mel-blue); }
.site-footer__inner {
	display: grid;
	grid-template-columns: 1fr auto;
	gap: 3rem;
	align-items: center;
	padding: clamp(2rem, 5vw, 3.2rem) var(--mel-gutter);
}
.site-footer__brand { display: flex; align-items: center; gap: 1.2rem; flex-wrap: wrap; }
.site-footer__logo {
	max-height: 80px;
	width: auto;
	display: block;
	/* sem filter: logo aparece nas cores originais sobre fundo branco */
}
.site-footer__title { color: var(--mel-blue); font-size: 1.6rem; font-weight: 800; display: block; }
.site-footer__tagline { color: var(--mel-muted); margin: 0; max-width: 320px; font-size: .95rem; }

.site-footer__nav { display: flex; align-items: center; }
.footer-menu {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	gap: 1.8rem;
	align-items: center;
}
.footer-menu a {
	color: var(--mel-ink);
	font-weight: 600;
	font-size: 1rem;
	padding: .4rem 0;
	border-bottom: 2px solid transparent;
}
.footer-menu a:hover { color: var(--mel-blue); border-bottom-color: var(--mel-red); }

.site-footer__bottom {
	background: var(--mel-soft);
	padding: 1rem 0;
	text-align: center;
	font-size: .85rem;
	border-top: 1px solid var(--mel-line);
}
.site-footer__bottom small { color: var(--mel-muted); }

@media (max-width: 760px) {
	.site-footer__inner {
		grid-template-columns: 1fr;
		gap: 1.6rem;
		text-align: center;
		justify-items: center;
	}
	.site-footer__brand { flex-direction: column; gap: .8rem; }
	.site-footer__tagline { margin-left: auto; margin-right: auto; }
	.footer-menu { flex-wrap: wrap; justify-content: center; gap: 1.2rem; }
}

/* ============================================================
   404
   ============================================================ */
.not-found { padding: clamp(4rem, 10vw, 6rem) 0; text-align: center; }
.not-found__code { color: var(--mel-red); font-size: 5rem; font-weight: 800; line-height: 1; margin: 0; }
.not-found__title { color: var(--mel-blue-dark); margin: .8rem 0; }
.not-found__text { color: var(--mel-muted); max-width: 480px; margin: 0 auto 1.5rem; }
.not-found .search-form { max-width: 460px; margin: 0 auto 1.5rem; }
.not-found__back { margin-top: 1.5rem; }

/* ============================================================
   Refinos diversos (Gutenberg)
   ============================================================ */
.wp-block-button__link { border-radius: 999px; padding: .85rem 1.6rem; font-weight: 600; }
.wp-block-image figcaption { color: var(--mel-muted); font-size: .9rem; }
.wp-block-quote { border-left: 4px solid var(--mel-red); padding-left: 1.2rem; }
.wp-block-pullquote { border-top: 3px solid var(--mel-blue); border-bottom: 3px solid var(--mel-blue); color: var(--mel-blue-dark); }
.wp-block-separator { border-color: var(--mel-line); }
.wp-block-table table { border-collapse: collapse; width: 100%; }
.wp-block-table th, .wp-block-table td { border: 1px solid var(--mel-line); padding: .6rem .8rem; }
.wp-block-table thead th { background: var(--mel-blue-50); color: var(--mel-blue-dark); }

:focus-visible { outline: 3px solid var(--mel-blue-light); outline-offset: 3px; border-radius: 4px; }
/* Blog hero (titulo + busca lado a lado) */
.blog-hero__inner { display: flex; align-items: center; justify-content: space-between; gap: 1.5rem; flex-wrap: wrap; }
.blog-hero__search { min-width: 260px; }
@media (max-width: 720px) {
	.blog-hero__inner { flex-direction: column; align-items: stretch; }
	.blog-hero__search { width: 100%; min-width: 0; }
}
