/* =====================================================================
   DigitalRadar — Components
   Wordmark, botões, switcher, hero radar, cards, CTA, overlays.
   ===================================================================== */

/* ---------- Wordmark / Logo ---------- */
.dr-wordmark {
	display: inline-flex;
	align-items: center;
	gap: .6rem;
	font-family: var(--dr-font-display);
	font-weight: 800;
	font-size: clamp(1.15rem, 1rem + .6vw, 1.5rem);
	letter-spacing: .02em;
	color: var(--dr-heading);
	text-transform: uppercase;
}

.dr-wordmark__text {
	line-height: 1;
}

.dr-wordmark__accent {
	color: var(--dr-neon);
	text-shadow: var(--dr-glow-text);
}

.dr-wordmark__radar {
	position: relative;
	width: 26px;
	height: 26px;
	border-radius: 50%;
	border: 1.5px solid var(--dr-border-neon);
	display: grid;
	place-items: center;
	flex: none;
}

.dr-wordmark__radar::before {
	content: "";
	position: absolute;
	inset: 0;
	border-radius: 50%;
	background: conic-gradient(from 0deg, transparent 0deg, rgba(0, 180, 255, .55) 50deg, transparent 70deg);
	animation: dr-sweep 3.2s linear infinite;
}

.dr-wordmark__dot {
	width: 5px;
	height: 5px;
	border-radius: 50%;
	background: var(--dr-neon);
	box-shadow: var(--dr-glow-sm);
}

@keyframes dr-sweep {
	to {
		transform: rotate(360deg);
	}
}

/* ---------- Logo (imagem) ---------- */
.dr-logo {
	display: inline-flex;
	align-items: center;
	line-height: 0;
}

.dr-logo__img {
	height: 48px;
	width: auto;
	display: block;
	transition: filter var(--dr-dur) var(--dr-ease), transform var(--dr-dur) var(--dr-ease);
}

.dr-logo:hover .dr-logo__img {
	filter: drop-shadow(var(--dr-glow-sm));
	transform: scale(1.03);
}

.dr-footer__brand .dr-logo__img {
	height: 56px;
}

/* WordPress custom-logo, caso seja definido no Personalizar. */
.custom-logo {
	height: 48px;
	width: auto;
}

@media (max-width: 600px) {
	.dr-logo__img {
		height: 40px;
	}
}

/* ---------- Botões ---------- */
.dr-btn {
	--btn-bg: var(--dr-surface-2);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: .5rem;
	font-family: var(--dr-font-alt);
	font-weight: var(--dr-fw-semi);
	font-size: var(--dr-fs-sm);
	line-height: 1;
	padding: .8rem 1.4rem;
	border: 1px solid var(--dr-border-2);
	border-radius: var(--dr-r-pill);
	background: var(--btn-bg);
	color: var(--dr-heading);
	cursor: pointer;
	transition: transform var(--dr-dur-fast) var(--dr-ease), box-shadow var(--dr-dur) var(--dr-ease), background var(--dr-dur) var(--dr-ease), border-color var(--dr-dur) var(--dr-ease);
}

.dr-btn:hover {
	transform: translateY(-2px);
}

.dr-btn:active {
	transform: translateY(0);
}

.dr-btn--lg {
	padding: 1rem 1.8rem;
	font-size: var(--dr-fs-base);
}

.dr-btn--neon {
	background: var(--dr-grad-neon);
	border-color: transparent;
	color: var(--dr-on-neon);
	font-weight: var(--dr-fw-bold);
	box-shadow: var(--dr-glow-sm);
}

.dr-btn--neon:hover {
	box-shadow: var(--dr-glow), 0 8px 24px -8px rgba(0, 180, 255, .7);
	color: var(--dr-on-neon);
}

.dr-btn--ghost {
	background: transparent;
	border-color: var(--dr-border-neon);
	color: var(--dr-text);
}

.dr-btn--ghost:hover {
	border-color: var(--dr-neon);
	color: var(--dr-heading);
	box-shadow: var(--dr-glow-sm);
}

/* ---------- Eyebrow ---------- */
.dr-eyebrow {
	display: inline-flex;
	align-items: center;
	gap: .55rem;
	font-family: var(--dr-font-alt);
	font-size: var(--dr-fs-xs);
	font-weight: var(--dr-fw-semi);
	letter-spacing: var(--dr-tracking-wide);
	text-transform: uppercase;
	color: var(--dr-neon-2);
	padding: .4rem .9rem;
	border: 1px solid var(--dr-border-neon);
	border-radius: var(--dr-r-pill);
	background: var(--dr-neon-soft);
}

.dr-eyebrow__pulse {
	width: 8px;
	height: 8px;
	border-radius: 50%;
	background: var(--dr-neon);
	box-shadow: 0 0 0 0 rgba(0, 180, 255, .7);
	animation: dr-pulse 2s var(--dr-ease) infinite;
}

@keyframes dr-pulse {
	0% {
		box-shadow: 0 0 0 0 rgba(0, 180, 255, .6);
	}

	70% {
		box-shadow: 0 0 0 10px rgba(0, 180, 255, 0);
	}

	100% {
		box-shadow: 0 0 0 0 rgba(0, 180, 255, 0);
	}
}

/* ---------- Switcher de idioma ---------- */
.dr-lang {
	display: inline-flex;
	padding: 3px;
	gap: 2px;
	border: 1px solid var(--dr-border-2);
	border-radius: var(--dr-r-pill);
	background: var(--dr-surface);
}

.dr-lang__btn {
	font-family: var(--dr-font-alt);
	font-size: var(--dr-fs-xs);
	font-weight: var(--dr-fw-semi);
	letter-spacing: .04em;
	color: var(--dr-text-dim);
	padding: .35rem .7rem;
	border-radius: var(--dr-r-pill);
	transition: all var(--dr-dur-fast) var(--dr-ease);
}

.dr-lang__btn.is-current {
	background: var(--dr-grad-neon);
	color: var(--dr-on-neon);
	box-shadow: var(--dr-glow-sm);
}

.dr-lang__btn:not(.is-current):hover {
	color: var(--dr-heading);
	background: var(--dr-surface-3);
}

/* ---------- Busca (toggle + overlay) ---------- */
.dr-search-toggle {
	display: grid;
	place-items: center;
	width: 40px;
	height: 40px;
	border-radius: 50%;
	border: 1px solid var(--dr-border-2);
	background: var(--dr-surface);
	color: var(--dr-text-dim);
	cursor: pointer;
	transition: all var(--dr-dur-fast) var(--dr-ease);
}

.dr-search-toggle:hover {
	color: var(--dr-neon);
	border-color: var(--dr-border-neon);
	box-shadow: var(--dr-glow-sm);
}

.dr-search-overlay {
	position: fixed;
	inset: 0;
	z-index: var(--dr-z-overlay);
	display: grid;
	place-items: start center;
	padding-top: 18vh;
	background: rgba(5, 6, 8, .82);
	backdrop-filter: blur(10px);
	opacity: 0;
	visibility: hidden;
	transition: opacity var(--dr-dur) var(--dr-ease), visibility var(--dr-dur);
}

.dr-search-overlay.is-open {
	opacity: 1;
	visibility: visible;
}

.dr-search-overlay__inner {
	width: min(680px, 90vw);
	position: relative;
}

.dr-search-overlay__close {
	position: absolute;
	top: -3rem;
	right: 0;
	font-size: 2rem;
	line-height: 1;
	background: none;
	border: none;
	color: var(--dr-text-dim);
	cursor: pointer;
}

.dr-search-overlay__close:hover {
	color: var(--dr-neon);
}

.dr-search-overlay__hint {
	margin-top: 1rem;
	color: var(--dr-text-mute);
	font-size: var(--dr-fs-sm);
	text-align: center;
}

.dr-searchform {
	display: flex;
	align-items: center;
	gap: .5rem;
	position: relative;
}

.dr-searchform__icon {
	position: absolute;
	left: 1.1rem;
	color: var(--dr-text-mute);
}

.dr-searchform__input {
	flex: 1;
	padding: 1.1rem 1.2rem 1.1rem 3rem;
	font-family: var(--dr-font-body);
	font-size: var(--dr-fs-md);
	color: var(--dr-heading);
	background: var(--dr-surface);
	border: 1px solid var(--dr-border-neon);
	border-radius: var(--dr-r-pill);
	box-shadow: var(--dr-glow-sm);
}

.dr-searchform__input::placeholder {
	color: var(--dr-text-mute);
}

.dr-searchform__input:focus {
	outline: none;
	border-color: var(--dr-neon);
}

/* ---------- Burger (mobile) ---------- */
.dr-burger {
	display: none;
	flex-direction: column;
	justify-content: center;
	gap: 5px;
	width: 42px;
	height: 42px;
	border: 1px solid var(--dr-border-2);
	border-radius: var(--dr-r-sm);
	background: var(--dr-surface);
	cursor: pointer;
}

.dr-burger span {
	display: block;
	width: 18px;
	height: 2px;
	margin: 0 auto;
	background: var(--dr-heading);
	border-radius: 2px;
	transition: transform var(--dr-dur) var(--dr-ease), opacity var(--dr-dur);
}

.dr-burger[aria-expanded="true"] span:nth-child(1) {
	transform: translateY(7px) rotate(45deg);
}

.dr-burger[aria-expanded="true"] span:nth-child(2) {
	opacity: 0;
}

.dr-burger[aria-expanded="true"] span:nth-child(3) {
	transform: translateY(-7px) rotate(-45deg);
}

/* ---------- HERO ---------- */
.dr-hero {
	position: relative;
	display: grid;
	align-items: center;
	min-height: clamp(520px, 82vh, 820px);
	padding-block: var(--dr-sp-9);
	overflow: hidden;
	isolation: isolate;
}

.dr-hero__bg {
	position: absolute;
	inset: 0;
	z-index: -1;
}

.dr-hero__grid {
	position: absolute;
	inset: 0;
	background-image:
		linear-gradient(rgba(0, 180, 255, .06) 1px, transparent 1px),
		linear-gradient(90deg, rgba(0, 180, 255, .06) 1px, transparent 1px);
	background-size: 46px 46px;
	mask-image: radial-gradient(110% 80% at 50% 30%, #000 30%, transparent 75%);
	-webkit-mask-image: radial-gradient(110% 80% at 50% 30%, #000 30%, transparent 75%);
}

.dr-hero__radar {
	position: absolute;
	top: -20%;
	right: -10%;
	width: min(720px, 80vw);
	aspect-ratio: 1;
	border-radius: 50%;
	background:
		repeating-radial-gradient(circle, rgba(0, 180, 255, .10) 0 1px, transparent 1px 64px),
		conic-gradient(from 0deg, transparent 0deg, rgba(0, 180, 255, .22) 40deg, transparent 80deg);
	animation: dr-sweep 7s linear infinite;
	opacity: .55;
	filter: blur(.3px);
}

.dr-hero__glow {
	position: absolute;
	left: 50%;
	top: 35%;
	width: 60vw;
	height: 60vw;
	transform: translate(-50%, -50%);
	background: radial-gradient(circle, rgba(0, 180, 255, .20), transparent 60%);
	filter: blur(40px);
}

.dr-hero__inner {
	max-width: 820px;
}

.dr-hero__title {
	font-size: var(--dr-fs-3xl);
	font-weight: var(--dr-fw-semi);
	/* Orbitron SemiBold */
	line-height: var(--dr-lh-tight);
	margin-block: var(--dr-sp-5) var(--dr-sp-4);
}

.dr-hero__title .dr-text-gradient {
	display: block;
}

.dr-hero__lead {
	font-size: var(--dr-fs-md);
	color: var(--dr-text-dim);
	max-width: 60ch;
	margin-bottom: var(--dr-sp-6);
}

.dr-hero__cta {
	display: flex;
	flex-wrap: wrap;
	gap: var(--dr-sp-3);
}

/* Reveal sutil na entrada do hero */
.dr-hero__inner>* {
	animation: dr-rise .7s var(--dr-ease-out) both;
}

.dr-hero__inner>*:nth-child(2) {
	animation-delay: .08s;
}

.dr-hero__inner>*:nth-child(3) {
	animation-delay: .16s;
}

.dr-hero__inner>*:nth-child(4) {
	animation-delay: .24s;
}

@keyframes dr-rise {
	from {
		opacity: 0;
		transform: translateY(20px);
	}

	to {
		opacity: 1;
		transform: none;
	}
}

/* ---------- Card de artigo ---------- */
.dr-card {
	display: flex;
	flex-direction: column;
	background: var(--dr-surface);
	border: 1px solid var(--dr-border);
	border-radius: var(--dr-r-lg);
	overflow: hidden;
	transition: transform var(--dr-dur) var(--dr-ease), border-color var(--dr-dur) var(--dr-ease), box-shadow var(--dr-dur) var(--dr-ease);
}

.dr-card:hover {
	transform: translateY(-6px);
	border-color: var(--dr-border-neon);
	box-shadow: var(--dr-shadow), var(--dr-glow-sm);
}

.dr-card__media {
	position: relative;
	display: block;
	aspect-ratio: 16 / 10;
	overflow: hidden;
	background: var(--dr-surface-2);
}

.dr-card__img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform var(--dr-dur-slow) var(--dr-ease);
}

.dr-card:hover .dr-card__img {
	transform: scale(1.06);
}

.dr-card__placeholder {
	position: absolute;
	inset: 0;
	background:
		repeating-radial-gradient(circle at 70% 20%, rgba(0, 180, 255, .10) 0 1px, transparent 1px 40px),
		linear-gradient(135deg, var(--dr-deep-glow), var(--dr-surface-2));
}

.dr-card__tag {
	position: absolute;
	top: .8rem;
	left: .8rem;
	font-family: var(--dr-font-alt);
	font-size: var(--dr-fs-xs);
	font-weight: var(--dr-fw-semi);
	letter-spacing: .04em;
	text-transform: uppercase;
	color: var(--dr-on-neon);
	background: var(--dr-grad-neon);
	padding: .3rem .7rem;
	border-radius: var(--dr-r-pill);
	box-shadow: var(--dr-glow-sm);
}

.dr-card__body {
	display: flex;
	flex-direction: column;
	gap: .65rem;
	padding: 1.25rem 1.3rem 1.4rem;
}

.dr-card__title {
	font-size: var(--dr-fs-lg);
	line-height: 1.25;
}

.dr-card__title a {
	color: var(--dr-heading);
}

.dr-card__title a:hover {
	color: var(--dr-neon);
}

.dr-card__excerpt {
	font-size: var(--dr-fs-sm);
	color: var(--dr-text-dim);
}

.dr-card__meta {
	display: flex;
	align-items: center;
	gap: .5rem;
	margin-top: auto;
	padding-top: .4rem;
	font-size: var(--dr-fs-xs);
	color: var(--dr-text-mute);
}

.dr-card--placeholder {
	opacity: .85;
}

/* ---------- Card de categoria ---------- */
.dr-cat-card {
	position: relative;
	display: flex;
	align-items: center;
	gap: .9rem;
	padding: 1.1rem 1.2rem;
	background: var(--dr-surface);
	border: 1px solid var(--dr-border);
	border-radius: var(--dr-r-md);
	color: var(--dr-text);
	overflow: hidden;
	transition: transform var(--dr-dur) var(--dr-ease), border-color var(--dr-dur) var(--dr-ease), background var(--dr-dur);
}

.dr-cat-card::before {
	content: "";
	position: absolute;
	inset: 0;
	background: var(--dr-grad-surface);
	opacity: 0;
	transition: opacity var(--dr-dur);
}

.dr-cat-card:hover {
	transform: translateY(-3px);
	border-color: var(--dr-border-neon);
	color: var(--dr-heading);
}

.dr-cat-card:hover::before {
	opacity: 1;
}

.dr-cat-card__icon {
	display: grid;
	place-items: center;
	width: 42px;
	height: 42px;
	flex: none;
	border-radius: var(--dr-r-sm);
	color: var(--dr-neon);
	background: var(--dr-neon-soft);
	border: 1px solid var(--dr-border-neon);
}

.dr-cat-card__icon .dr-icon {
	width: 22px;
	height: 22px;
}

.dr-cat-card__name {
	font-family: var(--dr-font-alt);
	font-weight: var(--dr-fw-semi);
	font-size: var(--dr-fs-sm);
}

.dr-cat-card__arrow {
	margin-left: auto;
	color: var(--dr-neon);
	transform: translateX(-4px);
	opacity: 0;
	transition: all var(--dr-dur) var(--dr-ease);
}

.dr-cat-card:hover .dr-cat-card__arrow {
	opacity: 1;
	transform: translateX(0);
}

/* ---------- Faixa CTA ---------- */
.dr-cta-band {
	position: relative;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	gap: var(--dr-sp-5);
	padding: clamp(2rem, 4vw, 3.5rem);
	border: 1px solid var(--dr-border-neon);
	border-radius: var(--dr-r-xl);
	background:
		linear-gradient(135deg, rgba(10, 31, 68, .85), rgba(13, 13, 13, .85));
	overflow: hidden;
	isolation: isolate;
}

.dr-cta-band__glow {
	position: absolute;
	inset: auto -10% -60% auto;
	width: 480px;
	height: 480px;
	background: radial-gradient(circle, rgba(0, 180, 255, .30), transparent 60%);
	filter: blur(30px);
	z-index: -1;
}

.dr-cta-band__content h2 {
	font-size: var(--dr-fs-xl);
}

.dr-cta-band__content p {
	color: var(--dr-text-dim);
	margin-top: .5rem;
	max-width: 46ch;
}

.dr-cta-band__form {
	display: flex;
	gap: .6rem;
	flex: 1 1 320px;
	min-width: 280px;
}

.dr-cta-band__form input {
	flex: 1;
	padding: 1rem 1.2rem;
	color: var(--dr-heading);
	background: var(--dr-bg-2);
	border: 1px solid var(--dr-border-2);
	border-radius: var(--dr-r-pill);
	font-family: var(--dr-font-body);
}

.dr-cta-band__form input:focus {
	outline: none;
	border-color: var(--dr-neon);
	box-shadow: var(--dr-glow-sm);
}

/* ---------- Newsletter rodapé ---------- */
.dr-newsletter-form {
	display: flex;
	gap: .5rem;
	margin-top: .8rem;
}

.dr-newsletter-form input {
	flex: 1;
	min-width: 0;
	padding: .7rem 1rem;
	color: var(--dr-heading);
	background: var(--dr-bg);
	border: 1px solid var(--dr-border-2);
	border-radius: var(--dr-r-pill);
	font-family: var(--dr-font-body);
	font-size: var(--dr-fs-sm);
}

.dr-newsletter-form input:focus {
	outline: none;
	border-color: var(--dr-neon);
}

/* ---------- Footer detalhes ---------- */
.dr-footer__tagline {
	font-family: var(--dr-font-alt);
	color: var(--dr-neon-2);
	font-weight: var(--dr-fw-semi);
	margin-top: .8rem;
}

.dr-footer__about {
	color: var(--dr-text-mute);
	font-size: var(--dr-fs-sm);
	margin-top: .5rem;
	max-width: 42ch;
}

.dr-footer__social {
	display: flex;
	gap: .6rem;
	margin-top: 1rem;
}

.dr-footer__social a {
	display: grid;
	place-items: center;
	width: 40px;
	height: 40px;
	border-radius: 50%;
	border: 1px solid var(--dr-border-2);
	color: var(--dr-text-dim);
	transition: all var(--dr-dur-fast) var(--dr-ease);
}

.dr-footer__social a:hover {
	color: var(--dr-neon);
	border-color: var(--dr-border-neon);
	box-shadow: var(--dr-glow-sm);
	transform: translateY(-2px);
}

.dr-footer__heading {
	font-family: var(--dr-font-alt);
	font-size: var(--dr-fs-sm);
	text-transform: uppercase;
	letter-spacing: .12em;
	color: var(--dr-silver);
	margin-bottom: 1rem;
}

.dr-footer__list,
.dr-footer__legal-list {
	list-style: none;
	padding: 0;
	margin: 0;
	display: grid;
	gap: .6rem;
}

.dr-footer__list a,
.dr-footer__legal-list a {
	color: var(--dr-text-dim);
	font-size: var(--dr-fs-sm);
}

.dr-footer__list a:hover,
.dr-footer__legal-list a:hover {
	color: var(--dr-neon);
}

.dr-footer__newsletter p {
	color: var(--dr-text-mute);
	font-size: var(--dr-fs-sm);
}

.dr-footer__legal {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 1rem;
}

.dr-footer__legal-list {
	grid-auto-flow: column;
	gap: 1.2rem;
}

.dr-footer__cookie-btn {
	font-family: var(--dr-font-body);
	font-size: var(--dr-fs-sm);
	color: var(--dr-text-dim);
	background: none;
	border: none;
	cursor: pointer;
	padding: 0;
	text-decoration: underline;
	text-underline-offset: 3px;
}

.dr-footer__cookie-btn:hover {
	color: var(--dr-neon);
}

.dr-footer__credit {
	width: 100%;
	color: var(--dr-text-mute);
}

.dr-footer__credit strong {
	color: var(--dr-silver);
}
.dr-footer__credit a {
	color: inherit;
	text-decoration: none;
	transition: color var(--dr-dur-fast) var(--dr-ease);
}
.dr-footer__credit a:hover strong { color: var(--dr-neon); }

/* ---------- Voltar ao topo ---------- */
.dr-to-top {
	position: fixed;
	right: 1.5rem;
	bottom: 1.5rem;
	z-index: var(--dr-z-totop);
	display: grid;
	place-items: center;
	width: 46px;
	height: 46px;
	border-radius: 50%;
	border: 1px solid var(--dr-border-neon);
	background: var(--dr-surface);
	color: var(--dr-neon);
	cursor: pointer;
	opacity: 0;
	transform: translateY(12px);
	pointer-events: none;
	transition: all var(--dr-dur) var(--dr-ease);
}

.dr-to-top.is-visible {
	opacity: 1;
	transform: none;
	pointer-events: auto;
}

.dr-to-top:hover {
	box-shadow: var(--dr-glow);
	transform: translateY(-3px);
}

/* ---------- Paginação / Empty ---------- */
.dr-pagination {
	margin-top: var(--dr-sp-7);
	display: flex;
	justify-content: center;
}

.dr-pagination .page-numbers {
	display: inline-grid;
	place-items: center;
	min-width: 42px;
	height: 42px;
	padding: 0 .6rem;
	margin: 0 .2rem;
	border: 1px solid var(--dr-border-2);
	border-radius: var(--dr-r-sm);
	color: var(--dr-text-dim);
	font-family: var(--dr-font-alt);
	font-weight: var(--dr-fw-semi);
}

.dr-pagination .page-numbers.current {
	background: var(--dr-grad-neon);
	color: var(--dr-on-neon);
	border-color: transparent;
	box-shadow: var(--dr-glow-sm);
}

.dr-pagination a.page-numbers:hover {
	border-color: var(--dr-border-neon);
	color: var(--dr-heading);
}

.dr-empty {
	text-align: center;
	padding: var(--dr-sp-8) 0;
	color: var(--dr-text-dim);
}

.dr-empty .dr-searchform {
	max-width: 480px;
	margin: 1.5rem auto 0;
}

/* ---------- Responsivo: nav mobile ---------- */
@media (max-width: 880px) {
	.dr-burger {
		display: flex;
	}

	.dr-nav {
		position: fixed;
		inset: var(--dr-header-h) 0 auto 0;
		background: rgba(7, 8, 9, .97);
		backdrop-filter: blur(16px);
		border-bottom: 1px solid var(--dr-border-neon);
		padding: var(--dr-sp-5) var(--dr-gutter) var(--dr-sp-6);
		transform: translateY(-120%);
		transition: transform var(--dr-dur) var(--dr-ease);
		max-height: calc(100vh - var(--dr-header-h));
		overflow-y: auto;
	}

	.dr-nav.is-open {
		transform: translateY(0);
	}

	.dr-nav__list {
		flex-direction: column;
		align-items: stretch;
		gap: 0;
	}

	.dr-nav__list li {
		border-bottom: 1px solid var(--dr-border);
	}

	.dr-nav__list a {
		display: block;
		padding: .9rem 0;
		font-size: var(--dr-fs-md);
	}

	.dr-nav__list a::after {
		display: none;
	}
}