@import url('https://fonts.googleapis.com/css2?family=Alexandria:wght@600&display=swap');

header {
	margin: 0;
	padding: 0
}

nav {
	margin: 0;
	padding: 0
}

main {
	margin: 0;
	padding: 0
}

article {
	margin: 0;
	padding: 0;
	overflow-y: hidden
}

section {
	margin: 0;
	padding: 0
}

aside {
	margin: 0;
	padding: 0
}

footer {
	margin: 0;
	padding: 0
}

@keyframes glitch-hackers {

	0%,
	100% {
		text-shadow: .02em 0 0 rgba(255, 0, 0, .75), -.02em 0 0 rgba(0, 255, 255, .75)
	}

	25% {
		text-shadow: .05em .05em 0 rgba(255, 0, 0, .75), -.05em -.025em 0 rgba(0, 255, 255, .75)
	}

	50% {
		text-shadow: -.025em -.05em 0 rgba(255, 0, 0, .75), .025em .025em 0 rgba(0, 255, 255, .75)
	}

	75% {
		text-shadow: -.05em 0 0 rgba(255, 0, 0, .75), .025em -.05em 0 rgba(0, 255, 255, .75)
	}
}

@keyframes flicker-hackers {

	0%,
	100% {
		opacity: 1
	}

	92% {
		opacity: 1
	}

	92.5% {
		opacity: .9
	}

	93% {
		opacity: 1
	}

	94% {
		opacity: .8
	}

	94.5% {
		opacity: 1
	}
}

.hackers-title-animated {
	animation: glitch-hackers 2s infinite, flicker-hackers 3s infinite;
	color: #0f0;
	text-transform: uppercase;
	letter-spacing: .1em;
	position: relative
}

.hackers-title-animated::before,
.hackers-title-animated::after {
	content: attr(data-text);
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%
}

.hackers-title-animated::before {
	animation: glitch-hackers .5s infinite;
	color: red;
	z-index: -1;
	opacity: .5
}

.hackers-title-animated::after {
	animation: glitch-hackers .3s infinite reverse;
	color: #0ff;
	z-index: -2;
	opacity: .5
}

body {
	overflow-x: hidden
}

.wrapper {
	width: 100%;
	overflow-x: hidden
}

.skip-link {
	position: absolute;
	left: -999px;
	top: auto;
	width: 1px;
	height: 1px;
	overflow: hidden;
	z-index: -999
}

.skip-link:focus {
	left: 0;
	top: 0;
	width: auto;
	height: auto;
	padding: .5rem 1rem;
	background: #fff;
	z-index: 1000
}

:root {
	--background-color-page: #FFFFFF;
	--background-color-sidebar: #f0f0f0;
	--background-color-secondary: #FFFFFF;
	--background-color-hero: #556d8d;
	--background-color-tag: #556d8d;
	--background-color-menus: #FFFFFF;
	--couleur-titre: #e66700;
	--primary-color: #374151;
	--heading-color: #181e2c;
	--box-shadow: rgb(219, 219, 219);
	--link-color: #c75100;
	--button-primary-background: #ff7b10;
	--button-primary-foreground: #FFFFFF;
	--button-secondary-background: #FFFFFF;
	--button-secondary-foreground: #ff7b10;
	--footer-background: #181e2c;
	--footer-text: #FFFFFF;
	--footer-link: #e66700;
	--footer-bottom-text: #8b949e;
	--latest-articles-heading: #d1d5db;
	--article-gradient-from: #eef0f3;
	--article-gradient-to: rgba(238, 240, 243, 0);
	--breakpoint-dark-mode: (prefers-color-scheme: dark);
	--background-color-tertiary: rgba(207, 214, 223, 1);
	--border-radius-base: 8px;
	--card-bg: #FFFFFF;
	--text-color: #374151;
	--text-color-secondary: #4a5568;
	--border-color: #e5e7eb;
	--info-bg: #eff6ff;
	--info-color: #1e40af
}

.force-dark {
	--background-color-page: #000000;
	--background-color-sidebar: #202530;
	--background-color-secondary: #181e2c;
	--background-color-side: #181e2c;
	--background-color-hero: #181e2c;
	--background-color-tag: #ffffff;
	--background-color-menus: #ffffff;
	--primary-color: #FAFAFA;
	--heading-color: #ffffff;
	--box-shadow: rgb(76, 80, 83);
	--link-color: #ff7b10;
	--button-primary-background: #ff7b10;
	--button-primary-foreground: #020000;
	--button-secondary-background: #363537;
	--button-secondary-foreground: var(--primary-color);
	--footer-background: #181e2c;
	--footer-text: #FFFFFF;
	--footer-link: #ff7b10;
	--footer-bottom-text: #8b949e;
	--latest-articles-heading: #ffffff;
	--article-gradient-from: #2a2e37;
	--article-gradient-to: rgba(42, 46, 55, 0);
	--background-color-tertiary: rgba(42, 46, 55, 1);
	--border-radius-base: 8px;
	--card-bg: #181e2c;
	--text-color: #FAFAFA;
	--text-color-secondary: #a0aec0;
	--border-color: #2d3748;
	--info-bg: #1e3a8a;
	--info-color: #bfdbfe
}

.force-dark img {
	filter: brightness(.8);
	transition: filter .3s ease-in-out
}

a,
button {
	transition: transform .3s ease-in-out, opacity .3s ease-in-out
}

.underline-animation {
	position: relative;
	overflow: hidden
}

.underline-animation::after {
	content: '';
	position: absolute;
	bottom: 0;
	left: 0;
	width: 0;
	height: 2px;
	background-color: var(--link-color);
	transition: transform .3s ease-in-out
}

.underline-animation:hover::after {
	transform: scaleX(1)
}

.article-title a {
	text-decoration: none;
	color: var(--heading-color)
}

.article-title a:hover {
	text-decoration: underline;
	text-decoration-color: var(--heading-color)
}

.button,
.cta-button {
	transform: translateY(0);
	box-shadow: 0 2px 5px rgba(0, 0, 0, .1);
	transition: transform .2s ease, box-shadow .2s ease
}

.button:active,
.cta-button:active {
	transform: translateY(2px);
	box-shadow: 0 1px 2px rgba(0, 0, 0, .1)
}

.article-card {
	transition: transform .3s ease, box-shadow .3s ease;
	position: relative
}

.article-card:hover {
	transform: translateY(-5px);
	box-shadow: 0 5px 15px rgba(0, 0, 0, .1)
}

.article-card-badge {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	background: var(--background-color-hero);
	color: rgba(255, 255, 255, .9);
	text-align: center;
	padding: .4rem 0;
	font-size: .85rem;
	letter-spacing: .1em;
	font-weight: 400;
	text-transform: uppercase;
	font-family: -apple-system, BlinkMacSystemFont, segoe ui, Roboto, Oxygen-Sans, Ubuntu, Cantarell, Noto Sans, sans-serif, BlinkMacSystemFont, Helvetica Neue, Arial, Apple Color Emoji, Segoe UI Emoji, Segoe UI Symbol, Noto Color Emoji;
	z-index: 2
}

.visually-hidden {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0
}

.social-links-sidebar .social-links img {
	transition: transform .3s ease
}

.social-links-sidebar .social-links img:hover {
	transform: scale(1.2)
}

.theme-switcher img {
	transition: transform .3s ease
}

.theme-switcher img:hover {
	transform: rotate(180deg)
}

.search-modal img {
	transition: transform .3s ease
}

.search-modal img:hover {
	transform: scale(1.2)
}

.cta-buttons .cta-button {
	transition: transform .3s ease, box-shadow .3s ease
}

.cta-buttons .cta-button:hover {
	transform: translateY(-3px);
	box-shadow: 0 5px 10px rgba(0, 0, 0, .1);
	text-decoration: none
}

img.fade-in {
	opacity: 0;
	transition: opacity .5s ease
}

img.fade-in.loaded {
	opacity: 1
}

.pagination a {
	transition: transform .2s ease
}

.pagination a:hover {
	transform: scale(1.1)
}

.search-form input[type=text] {
	padding: .5rem;
	border: none;
	border-radius: .25rem;
	transition: transform .3s ease-in-out
}

.search-form input[type=text]:focus {
	transform: scale(1.1)
}

.tag {
	transition: background-color .3s ease, color .3s ease
}

.tag:hover {
	background-color: var(--link-color);
	color: var(--background-color-page)
}

html {
	scroll-behavior: smooth
}

body {
	font-family: sans-serif;
	font-size: 1.1rem;
	line-height: 1.5;
	margin: 0;
	padding: 0;
	color: var(--primary-color);
	display: flex;
	flex-direction: column;
	min-height: 100vh;
	background-color: var(--background-color-page)
}

* {
	box-sizing: border-box
}

img,
video {
	max-width: 100%;
	height: auto
}

.article-content .content img {
	max-width: 100%;
	width: auto !important;
	height: auto;
	padding: 1rem 0 2rem;
	object-fit: contain;
	margin-bottom: 1.25rem;
	margin-top: 0;
	display: block;
	margin-left: auto;
	margin-right: auto
}

@media screen and (max-width:768px) {

	.article-content .content img,
	.content img {
		display: block !important;
		margin-left: auto !important;
		margin-right: auto !important;
		max-width: 100% !important;
		width: auto !important;
		height: auto !important
	}

	.article-content,
	.content {
		padding-left: 0;
		padding-right: 0
	}

	.article-content .content figure,
	.article-content .content .wp-block-image {
		margin-left: 0;
		margin-right: 0;
		text-align: center
	}
}

.article-content .content img[width] {
	max-width: min(100%, attr(width px));
	width: auto !important
}

.content video {
	max-width: 100%;
	height: auto;
	padding: 1rem 0 2rem
}

.post-content,
.article-content,
.content {
	overflow-x: hidden;
	width: 100%;
	position: relative;
	overflow-y: hidden
}

.article-content {
	margin-bottom: 0
}

@media screen and (max-width:768px) {

	article .post-content>p>img,
	article .content>p>img,
	.article-content>p>img,
	.post-content>p>img,
	.single-article .content>p>img {
		display: block;
		max-width: 100%;
		width: auto !important;
		height: auto;
		margin-left: auto;
		margin-right: auto;
		transform: none;
		position: relative;
		object-fit: contain;
		padding: .5rem 0 1.5rem
	}

	article .post-content>p,
	article .content>p,
	.article-content>p,
	.post-content>p,
	.single-article .content>p {
		overflow: visible
	}

	.article-content>p:has(img[width]),
	.content>p:has(img[width]) {
		overflow: hidden
	}

	.pub-section img,
	.patreon-banner img,
	.patreon-banner-container img,
	.sidebar img,
	.logo img,
	.avatar img,
	.header img,
	.navigation img,
	.social-icons img,
	.ad-section img,
	.related-posts img,
	[class*=banner] img {
		width: auto;
		max-width: 100%;
		margin-left: auto;
		margin-right: auto;
		transform: none;
		left: auto;
		right: auto;
		position: static
	}

	body,
	main,
	.container,
	.main-container {
		overflow-x: hidden
	}
}

.titre-section {
	color: var(--couleur-titre)
}

.titre-style {
	font-weight: 700;
	color: var(--primary-color);
	position: absolute;
	bottom: 4%;
	left: 35%;
	padding: 5px
}

body.custom-font-dyslexia,
body.custom-font-dyslexia .footer-categories,
body.custom-font-dyslexia footer,
body.custom-font-dyslexia .footer-categories a,
body.custom-font-dyslexia footer a,
body.custom-font-dyslexia h1,
body.custom-font-dyslexia h2,
body.custom-font-dyslexia h3,
body.custom-font-dyslexia h4,
body.custom-font-dyslexia h5,
body.custom-font-dyslexia h6 {
	font-family: Opendyslexic, sans-serif
}

header {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 1.25rem;
	padding-top: 1.8em;
	background-color: var(--background-color-hero)
}

@media screen and (max-width:1100px) and (min-width:769px) {
	header {
		display: grid;
		grid-template-columns: 1fr auto 1fr;
		align-items: center;
		column-gap: .75rem
	}

	.header-logo {
		position: static !important;
		left: auto !important;
		transform: none !important;
		justify-self: center
	}

	header>nav.header-buttons {
		flex: initial;
		justify-self: end
	}

	.cta-buttons {
		flex-wrap: nowrap;
		justify-content: flex-end
	}

	header>nav.header-buttons .cta-button {
		padding: .4rem .75rem;
		font-size: .95rem
	}
}

header>nav.header-buttons {
	display: flex;
	align-items: center;
	flex: 0 0 255px;
	justify-content: flex-end
}

.header-logo {
	flex: initial;
	display: flex;
	justify-content: center;
	align-items: center;
	position: absolute;
	left: 50%;
	transform: translateX(-50%)
}

.header-icons {
	display: flex;
	align-items: center;
	gap: 1.25rem
}

img {
	max-width: 100%;
	height: auto;
	object-fit: cover;
	display: block;
	margin-left: auto;
	margin-right: auto
}

.hamburger-menu,
.theme-switcher,
.search-modal,
.search-link,
.font-switcher {
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	position: relative
}

.font-switcher:hover::after {
	content: "Police dyslexie";
	position: absolute;
	bottom: -35px;
	left: 50%;
	transform: translateX(-50%);
	background: #333;
	color: #fff;
	padding: 5px 10px;
	border-radius: 4px;
	font-size: 12px;
	white-space: nowrap;
	z-index: 1000;
	pointer-events: none
}

body.custom-font-dyslexia .font-switcher {
	background-color: #4caf50;
	border-radius: 50%;
	padding: 5px
}

body.custom-font-dyslexia .font-switcher img {
	filter: brightness(0)invert(1)
}

body.dark-mode .theme-switcher img {
	transform: scaleX(-1)
}

.hamburger-menu img,
.theme-switcher img,
.search-modal img,
.font-switcher img {
	height: 1.875rem;
	width: 1.875rem;
	object-fit: contain
}

.overlay {
	display: none;
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	z-index: 999
}

.modal-close {
	position: absolute;
	top: 20px;
	right: 20px;
	font-size: 24px;
	color: #fff;
	cursor: pointer;
	border-radius: 50%;
	width: 30px;
	height: 30px;
	display: flex;
	justify-content: center;
	align-items: center
}

.search-overlay .search-form {
	display: flex;
	justify-content: center;
	align-items: center;
	height: 100%
}

.logo {
	width: auto;
	max-width: 20rem;
	height: auto;
	margin-left: auto;
	margin-right: auto
}

.cta-buttons {
	display: flex
}

.header-top {
	display: flex;
	justify-content: space-between;
	align-items: center;
	width: 100%
}

.navigation {
	display: block;
	padding: 1.25rem;
	background-color: var(--background-color-hero)
}

.menu {
	display: flex;
	flex-wrap: nowrap;
	justify-content: center;
	list-style: none;
	padding: 0 6rem;
	margin: 0 auto;
	max-width: 1800px;
	font-size: clamp(.8rem, 1.2vw, 1.05rem)
}

@media(max-width:1400px) {
	.menu {
		padding: 0 4rem
	}
}

@media(max-width:1200px) {
	.menu {
		padding: 0 2rem
	}
}

.menu li {
	display: inline-block;
	margin: 0 .1975rem;
	position: relative
}

.menu li:not(:last-child)::after {
	content: '|';
	position: absolute;
	right: -.9375rem
}

.menu a {
	color: var(--button-primary-foreground);
	text-decoration: none;
	text-transform: lowercase;
	font-weight: 700
}

.menu.hidden {
	display: none
}

.submenu-parent {
	position: relative
}

.submenu {
	display: none;
	position: absolute;
	top: 100%;
	background-color: var(--background-color-hero);
	box-shadow: 0 .5rem 1rem rgba(0, 0, 0, .2);
	width: auto;
	padding: .625rem;
	z-index: 1000
}

.submenu li {
	margin: 0
}

.submenu li,
.submenu a {
	width: auto
}

.submenu-parent:hover .submenu,
.submenu-parent:focus-within .submenu {
	display: block
}

.submenu a:hover {
	background-color: #ff7b10;
	color: #fff
}

main {
	flex: 3
}

.main-container {
	margin: 0 auto;
	max-width: 100%;
	overflow-y: hidden;
	padding-top: 0
}

.articles {
	width: 100%;
	margin: 0 auto;
	overflow-x: hidden;
	overflow-y: visible
}

figure.aligncenter,
figure.wp-block-video.aligncenter,
.wp-block-video {
	justify-content: center;
	align-items: center;
	margin: 1em auto;
	width: 100%;
	position: relative;
	height: 100%;
	overflow: hidden;
	max-width: 100%
}

figure.aligncenter img,
figure.wp-block-video.aligncenter video,
.wp-block-video video {
	max-width: 100%;
	height: auto;
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	object-fit: contain
}

.alignwide {
	margin-left: -2.5rem;
	margin-right: -2.5rem;
	width: auto
}

.aligncenter:not(.wp-has-aspect-ratio),
.aligncenter:not(.wp-has-aspect-ratio) * {
	margin-left: auto;
	margin-right: auto
}

article img {
	max-width: 100%;
	margin-bottom: 1rem;
	margin-top: 0;
	height: auto
}

article .content img {
	width: auto !important;
	object-fit: contain
}

h1,
h2,
h3,
h4,
h5 {
	font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Ubuntu, Cantarell, Noto Sans, sans-serif, BlinkMacSystemFont, Helvetica Neue, Arial, Apple Color Emoji, Segoe UI Emoji, Segoe UI Symbol, Noto Color Emoji
}

h1 {
	font-size: clamp(2rem, 5vw, 3rem);
	color: var(--heading-color);
	margin-top: 0
}

h2 {
	font-size: clamp(1.5rem, 4vw, 2.25rem);
	color: var(--heading-color);
	margin-top: 0
}

h3 {
	font-size: clamp(1.25rem, 3.5vw, 2rem);
	color: var(--heading-color);
	margin-top: 0
}

h4 {
	font-size: clamp(1rem, 3vw, 1.75rem);
	color: var(--heading-color);
	margin-top: 0
}

h5 {
	font-size: clamp(.875rem, 2.5vw, 1.5rem);
	color: var(--heading-color);
	margin-top: 0
}

h6 {
	font-size: clamp(.75rem, 2vw, 1.25rem);
	color: var(--heading-color);
	margin-top: 0
}

p {
	color: var(--heading-color);
	margin-top: 0
}

.visually-hidden {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0
}

.card {
	background-color: var(--background-color);
	border-radius: .5rem;
	box-shadow: 0 2px 4px rgba(0, 0, 0, .1);
	padding: 2rem
}

.button {
	display: inline-block;
	background-color: var(--primary-color);
	color: #fff;
	padding: .75rem 1.5rem;
	border-radius: .25rem;
	text-decoration: none
}

.category-link {
	display: inline-block;
	font-size: 14px;
	margin: 5px 0
}

.category-link a {
	color: var(--heading-color);
	text-decoration: underline
}

.category-link a:hover {
	text-decoration: underline
}

.article-grid {
	display: flex;
	flex-wrap: wrap;
	gap: 1rem;
	padding: 1rem
}

.article-card {
	flex: 1 1 calc(33.333% - 1rem);
	min-width: auto;
	border: 1px solid #ddd;
	border-radius: 8px;
	overflow: hidden;
	display: flex;
	flex-direction: column;
	justify-content: space-between
}

.article-card,
.article-title {
	line-height: 1.4;
	margin-bottom: 1.5rem;
	text-decoration: none
}

.article-card h2 {
	font-size: 1.5rem
}

.article-card p {
	font-size: 1rem
}

.article-link {
	text-decoration: none
}

.article-link:hover {
	text-decoration: none
}

.article-card .article-title {
	margin: .5rem 0;
	font-size: 1.1rem;
	line-height: 1.4;
	display: -webkit-box;
	display: box;
	-webkit-line-clamp: 2;
	line-clamp: 2;
	-webkit-box-orient: vertical;
	box-orient: vertical;
	overflow: hidden;
	text-overflow: ellipsis;
	max-height: 3.1rem
}

.article-card,
.article-title a {
	color: var(--text-color)
}

.article-title a {
	display: -webkit-box;
	display: box;
	-webkit-line-clamp: 2;
	line-clamp: 2;
	-webkit-box-orient: vertical;
	box-orient: vertical;
	overflow: hidden;
	text-overflow: ellipsis;
	width: 100%;
	position: relative
}

.pub-section .article-title {
	font-size: 2.25rem;
	color: var(--heading-color);
	margin-top: 0;
	font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Ubuntu, Cantarell, Noto Sans, sans-serif, BlinkMacSystemFont, Helvetica Neue, Arial, Apple Color Emoji, Segoe UI Emoji, Segoe UI Symbol, Noto Color Emoji;
	font-weight: 700;
	display: block;
	margin-bottom: 1rem;
	white-space: normal;
	word-wrap: break-word
}

.article-image {
	position: relative;
	background-color: #f0f0f0;
	width: 600px;
	height: 400px
}

.article-image::before,
.article-image::after {
	content: '';
	position: absolute;
	left: 0;
	right: 0;
	height: 2px;
	background: linear-gradient(to right, transparent, rgba(128, 128, 128, .5), transparent);
	opacity: .7;
	transition: opacity .3s ease
}

.article-image:hover::before,
.article-image:hover::after {
	opacity: 1
}

.article-image::before {
	top: 0
}

.article-image::after {
	bottom: 0
}

.article-image img {
	width: 100%;
	height: 200px;
	object-fit: cover
}

.article-content {
	padding: 15px;
	flex-grow: 1;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	padding: 1.5rem 3rem 0
}

.content a {
	position: relative;
	overflow: visible;
	color: var(--link-color);
	text-decoration: none;
	transition: color .3s ease
}

.content a img {
	position: static
}

.content a::after {
	content: '';
	position: absolute;
	bottom: 0;
	left: 0;
	width: 0;
	height: 2px;
	background-color: var(--link-color);
	transition: transform .3s ease-in-out
}

.content a:hover::after {
	transform: scaleX(1)
}

.content a:hover {
	color: var(--link-color)
}

.content ul {
	list-style-type: none;
	list-style-position: inside;
	padding-left: 1.5em;
	margin-bottom: 1.25rem
}

.content ul li {
	position: relative;
	padding-left: 1.5em;
	margin-bottom: .5em
}

.content ul li::before {
	content: 'â€¢';
	color: var(--link-color);
	position: absolute;
	left: 0;
	top: 0
}

.content ul ul {
	margin-top: .5em;
	margin-bottom: 0
}

.content ul ul li::before {
	content: 'â—¦'
}

.article-footer {
	justify-content: flex-start;
	margin-top: auto;
	text-align: right;
	font-size: 1.5rem;
	padding-right: 2rem
}

.meta,
.categories {
	font-size: .9rem;
	margin-bottom: 10px
}

.read-more {
	display: inline-block;
	margin-top: 10px;
	color: var(--link-color);
	text-decoration: none;
	transition: border-color .3s ease
}

.read-more:hover,
.read-more:focus {
	border-bottom-color: var(--link-color)
}

.read-more:visited {
	color: var(--link-color)
}

.content {
	position: relative
}

.content a {
	position: relative;
	overflow: visible;
	color: var(--link-color);
	text-decoration: none;
	transition: color .3s ease
}

.content a img {
	position: static
}

.content a:hover,
.content a:focus {
	border-bottom-color: var(--link-color)
}

.content a:visited {
	color: var(--link-color)
}

.article-image {
	width: 100%;
	margin-top: 0;
	height: 18rem;
	overflow: hidden
}

.article-image img {
	width: 100%;
	height: 18rem;
	object-fit: cover;
	object-position: center
}

.sidebar {
	display: none
}

.sidebar,
.article-content {
	overflow-y: hidden
}

.article-content {
	position: relative;
	left: 50%;
	transform: translateX(-50%);
	background-color: var(--background-color-secondary);
	padding: 1.25rem;
	border-radius: .9375rem;
	margin-bottom: 0;
	margin-right: 2rem;
	margin-left: 0;
	max-width: 50rem;
	width: 100%;
	box-sizing: border-box
}

.article-content p {
	margin-bottom: 1.25rem;
	text-align: justify;
	clear: both
}

.article-content::before,
.article-content::after {
	--tw-gradient-to: transparent;
	content: '';
	z-index: -1;
	position: absolute
}

.article-content::before,
.article-content::after {
	--tw-gradient-from: var(--article-gradient-from, --article-gradient-to);
	--tw-gradient-stops: var(--tw-gradient-from), var(--article-gradient-to);
	background-image: linear-gradient(180deg, var(--tw-gradient-from));
	background-image: linear-gradient(to bottom, var(--tw-gradient-stops));
	height: 5rem;
	top: 5.5rem;
	width: .0781rem
}

.article-content::before {
	left: -.0781rem
}

.article-content::after {
	right: -.0781rem
}

.meta {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	margin-bottom: 1rem;
	font-size: .9rem;
	padding-bottom: .5rem
}

.meta>* {
	margin-right: .5rem
}

.meta>*:last-child {
	margin-right: 0
}

.date,
.author {
	color: var(--primary-color);
	font-size: .9rem
}

.author a {
	color: var(--link-color);
	text-decoration: none;
	transition: color .3s ease
}

.author a:hover {
	color: var(--button-primary-background);
	text-decoration: underline
}

.tags {
	margin-top: 2.25rem;
	display: flex;
	flex-wrap: wrap
}

.tag-link {
	text-decoration: none;
	color: inherit
}

.tag-link:hover {
	text-decoration: underline
}

aside {
	flex: 1 1 350px;
	min-width: 350px;
	padding: .3rem;
	margin: 0;
	background-color: var(--background-color-sidebar);
	box-shadow: var(--box-shadow)
}

aside img {
	width: 100%;
	height: auto
}

aside>* {
	margin-left: .5rem;
	margin-right: .5rem
}

aside section {
	margin-left: 1rem;
	margin-right: 1rem;
	margin-bottom: 1.25rem
}

.social-links img {
	height: 1.875rem;
	margin-right: .625rem;
	filter: brightness(0)invert(1)
}

.social-links a {
	color: #f0f0f0;
	margin-left: .625rem
}

figure.aligncenter .video-container {
	width: 100%;
	max-width: 300px;
	margin: 0 auto
}

.tags span {
	background-color: var(--background-color-tag);
	color: var(--button-primary-foreground);
	padding: .3125rem .625rem;
	border-radius: .9375rem;
	margin-right: .625rem;
	margin-bottom: .625rem;
	font-size: .8em
}

.search-and-cta {
	display: flex;
	align-items: center;
	gap: 1.25rem;
	margin: 1.25rem
}

.search-form {
	display: flex;
	align-items: center;
	margin: 0 1.25rem
}

.search-form input[type=text] {
	padding: .5rem;
	border: none;
	border-radius: .25rem
}

.search-form button {
	padding: .5rem;
	background-color: var(--button-primary-background);
	color: var(--button-primary-foreground);
	border: none;
	border-radius: .25rem;
	margin-left: .5rem
}

.cta-buttons {
	display: flex;
	gap: .625rem
}

.cta-button {
	padding: .5rem 1rem;
	border-radius: .25rem;
	text-decoration: none;
	font-size: 1rem
}

.cta-button.primary {
	background-color: var(--button-primary-background);
	color: var(--heading-color)
}

.cta-button.secondary {
	background-color: var(--button-secondary-background);
	color: var(--heading-color)
}

footer {
	background-color: var(--footer-background);
	color: var(--footer-text);
	padding: 2rem 1rem;
	display: flex;
	flex-direction: column;
	align-items: center
}

.footer-wrapper {
	display: flex;
	flex-direction: column;
	align-items: center;
	margin-bottom: .75rem;
	gap: .5rem
}

.footer-left,
.footer-center,
.footer-right {
	display: flex;
	flex-direction: column;
	align-items: center;
	width: auto;
	margin-bottom: .5rem
}

.footer-center img {
	height: 8rem;
	width: auto;
	padding: .5rem
}

.footer-left .social-links {
	gap: .625rem;
	padding-inline: .375rem
}

.footer-left .social-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	flex: 0 0 2.5rem;
	width: 2.5rem;
	height: 2.5rem;
	margin: 0;
	padding: .25rem;
	box-sizing: border-box
}

.footer-left .social-links a {
	margin-left: 0
}

.footer-left .social-links img {
	width: 100%;
	height: 100%;
	margin-right: 0;
	object-fit: contain
}

.footer-bottom a {
	color: var(--background-color-menus);
	text-decoration: none;
	font-size: 1em;
	text-transform: uppercase;
	font-weight: 700;
	margin: .5rem 0
}

.footer-right img {
	width: 3rem;
	height: 3rem;
	padding: .625rem;
	object-fit: contain
}

.footer-right .header-icons {
	display: flex;
	justify-content: center;
	gap: 1rem
}

.footer-right .search-link img {
	margin-left: 0
}

.footer-text {
	text-align: center;
	font-size: .875rem;
	font-weight: 700;
	margin-bottom: .25rem;
	color: var(--footer-text)
}

.footer-text p {
	color: var(--footer-text);
	text-decoration: none
}

.footer-text a {
	color: var(--footer-link);
	text-decoration: underline
}

a:hover,
a:focus {
	color: var(--link-hover-color);
	text-decoration: underline
}

.social-icon {
	width: 2rem;
	height: 2rem;
	margin-bottom: .5rem;
	transition: transform .3s ease
}

.social-icon:hover {
	transform: scale(1.2)rotate(10deg)
}

.social-icon img {
	transition: transform .3s ease
}

.social-icon:hover img {
	transform: rotate(-10deg)
}

.social-links {
	display: flex;
	gap: .5rem;
	margin-bottom: .5rem;
	color: var(--button-primary-foreground);
	text-decoration: none;
	font-size: 1.2em;
	text-transform: lowercase;
	font-weight: 700;
	flex-wrap: wrap;
	justify-content: center;
	line-height: 2rem
}

.footer-socials {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center
}

.social-group {
	display: flex;
	justify-content: center;
	margin-bottom: .5rem
}

.social-icon {
	margin: 0 .5rem
}

.subscribe-link {
	display: inline-block;
	background-color: var(--button-primary-background);
	color: var(--button-primary-foreground);
	padding: .3125rem .625rem;
	border-radius: .375rem;
	text-decoration: none;
	margin-bottom: .625rem
}

.footer-bottom {
	text-align: center;
	font-size: .75rem;
	color: var(--footer-bottom-text)
}

.hamburger-menu {
	margin-top: auto;
	margin-bottom: auto;
	display: none
}

.hamburger-menu {
	display: none
}

.hamburger-menu:hover>label>img {
	transform: rotate(90deg)
}

.hamburger-menu label {
	display: block
}

.hamburger-menu label img {
	display: block;
	cursor: pointer
}

label[for=menu-toggle] img {
	display: block
}

.search-overlay .modal-close {
	position: absolute;
	top: .625rem;
	left: .625rem;
	cursor: pointer;
	display: none
}

.search-link img {
	transition: transform .3s ease;
	margin-left: .6rem
}

.search-link img:hover {
	transform: scale(1.1)
}

.menu-overlay {
	display: none;
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	width: 100%;
	height: 100vh;
	z-index: 1000;
	box-sizing: border-box
}

label[for=menu-toggle] img {
	display: block
}

.header-bottom {
	width: 100%;
	background-color: var(--background-color-hero);
	padding: .625rem 0
}

.navigation .menu {
	list-style: none;
	display: flex;
	flex-wrap: wrap;
	padding: 0;
	margin: 0 auto
}

.navigation .menu li {
	margin: 0;
	padding: 0 10px;
	position: relative
}

.navigation .menu li:not(:last-child)::after {
	content: '|';
	position: absolute;
	right: -2px;
	color: #fff
}

.navigation .menu a {
	text-decoration: none;
	color: var(--background-color-menus);
	font-weight: 700
}

.navigation .menu a:hover {
	color: var(--button-primary-background)
}

.header-top {
	display: flex;
	justify-content: space-between;
	align-items: center;
	width: 100%
}

.footer-right .header-icons .font-switcher img,
.footer-right .header-icons .theme-switcher img,
.footer-right .header-icons .search-modal img {
	width: 3rem;
	height: auto
}

.pagination {
	display: flex;
	justify-content: center;
	align-items: center;
	margin-top: 2rem;
	margin-bottom: 2rem;
	flex-wrap: wrap
}

.pagination a,
.pagination span {
	color: var(--primary-color);
	border-radius: 4px;
	text-decoration: none;
	transition: background-color .3s ease, color .3s ease;
	padding: .75rem 1rem;
	margin: 0 .25rem
}

.pagination a:hover,
.pagination span:hover {
	background-color: var(--link-color);
	color: #f0f0f0;
	transform: translateY(-2px);
	box-shadow: 0 2px 4px rgba(0, 0, 0, .1)
}

.pagination .page.active {
	background-color: var(--link-color);
	color: var(--button-primary-foreground)
}

.pagination .prev,
.pagination .next {
	font-weight: 700;
	text-transform: uppercase
}

.pagination .disabled {
	color: var(--footer-bottom-text);
	cursor: not-allowed;
	background-color: var(--background-color-secondary)
}

.pagination .ellipsis {
	background: 0 0;
	color: var(--primary-color)
}

.categories {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
	gap: 1rem
}

.category {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-decoration: none;
	color: var(--primary-color);
	margin-bottom: 1rem
}

.category img {
	width: 100%;
	height: auto;
	border-radius: var(--border-radius-base);
	margin-bottom: .625rem
}

.category h2 {
	font-size: var(--font-size-h3);
	text-align: center;
	margin-bottom: .5rem
}

.category p {
	text-align: center;
	margin-bottom: 0
}

.categories {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
	gap: 1rem
}

.related-posts-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 1rem;
	padding-bottom: 1rem
}

.related-post-item {
	display: flex;
	flex-direction: column;
	height: 100%
}

.related-post-link {
	display: flex;
	flex-direction: column;
	height: 100%;
	text-decoration: none;
	background-color: var(--background-color-secondary);
	border-radius: .625rem;
	overflow: hidden;
	transition: transform .3s ease
}

.related-post-link:hover {
	transform: translateY(-5px)
}

.related-post-image {
	position: relative;
	padding-top: 56.25%;
	overflow: hidden
}

.related-post-image img {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	object-fit: cover
}

.related-post-title {
	padding: 1rem;
	margin: 0;
	color: var(--primary-color);
	font-size: 1rem;
	line-height: 1.4;
	flex-grow: 1;
	display: flex;
	align-items: center
}

@media(prefers-color-scheme:dark) {

	.article-content::before,
	.article-content::after {
		display: none
	}
}

.force-dark .article-content::before,
.force-dark .article-content::after {
	display: none
}

.pub-section {
	display: flex;
	flex-direction: column;
	align-items: center;
	width: 100%;
	max-width: 100%;
	overflow-x: hidden
}

.pub-section-band {
	--tw-bg-opacity: 1;
	background-color: var(--background-color-tertiary);
	padding: .5rem 0;
	min-height: 100px
}

.pub-section h3 {
	margin-bottom: .9375rem
}

.pub-section img {
	max-width: 100%;
	height: auto;
	display: block
}

.sticky-ad {
	position: sticky;
	top: 20px;
	will-change: transform;
	transition: transform .2s ease
}

.sticky-ad.sticky-bottom {
	position: relative;
	bottom: 0
}

.sticky {
	position: -webkit-sticky;
	position: sticky;
	top: 0;
	z-index: 1000
}

.join-community {
	text-align: center;
	padding: 1.25rem;
	margin-bottom: 1.25rem;
	background-color: var(--background-color-secondary);
	border-radius: 0;
	box-sizing: border-box;
	min-width: 0;
	overflow: hidden
}

.join-community h3 {
	margin-bottom: .9375rem;
	font-size: clamp(.95rem, 2.5vw, 1.25rem);
	word-wrap: break-word;
	overflow-wrap: break-word;
	hyphens: auto;
	line-height: 1.3
}

.join-community img {
	width: clamp(4rem, 15vw, 6.25rem);
	height: auto;
	max-width: 100%
}

.personal-pages {
	padding: 1.25rem;
	margin-bottom: 1.25rem;
	background-color: var(--background-color-secondary);
	border-radius: 0;
	box-sizing: border-box
}

.personal-pages h3 {
	margin-bottom: 1rem;
	font-size: 1.1rem;
	color: var(--heading-color)
}

.personal-links {
	list-style: none;
	padding: 0;
	margin: 0
}

.personal-links li {
	margin-bottom: .75rem
}

.personal-links li:last-child {
	margin-bottom: 0
}

.personal-links a {
	display: flex;
	align-items: center;
	gap: .5rem;
	padding: .5rem .75rem;
	text-decoration: none;
	color: var(--primary-color);
	background-color: var(--background-color-sidebar);
	border-radius: .25rem;
	transition: all .2s ease
}

.personal-links a:hover {
	background-color: var(--link-color);
	color: #fff;
	transform: translateX(3px)
}

.personal-links .icon {
	font-size: 1.2rem
}

.top-tags {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	margin: 2rem
}

.tag-item {
	background-color: #f0f0f0;
	padding: 5px 10px;
	border-radius: 5px
}

.tag-link {
	text-decoration: none
}

.tag-count {
	font-size: .8em;
	color: #666
}

.group:hover .group-hover\:-rotate-6 {
	--tw-rotate: -6deg
}

.group:hover .group-hover\:-translate-x-3 {
	--tw-translate-x: -0.75rem
}

.transition-transform {
	transition-duration: .15s;
	transition-property: transform;
	transition-timing-function: cubic-bezier(.4, 0, .2, 1)
}

.transform {
	--tw-translate-x: 0;
	--tw-translate-y: 0;
	--tw-rotate: 0;
	--tw-skew-x: 0;
	--tw-skew-y: 0;
	--tw-scale-x: 1;
	--tw-scale-y: 1;
	transform: translateX(var(--tw-translate-x))translateY(var(--tw-translate-y))rotate(var(--tw-rotate))skewX(var(--tw-skew-x))skewY(var(--tw-skew-y))scaleX(var(--tw-scale-x))scaleY(var(--tw-scale-y))
}

.social-links-sidebar {
	text-align: center;
	padding: 1rem 0
}

.social-links-sidebar h3 {
	margin-bottom: 1rem;
	font-size: 1.5rem;
	color: var(--heading-color)
}

.social-links-sidebar .social-links a {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 40px;
	background-color: var(--background-color-sidebar);
	border-radius: 50%;
	transition: transform .3s ease, background-color .3s ease
}

.social-links-sidebar .social-links a:hover {
	transform: scale(1.1);
	background-color: var(--hover-background-color)
}

.social-links-sidebar .social-links img {
	max-width: 100%;
	height: auto
}

.social-links-sidebar .social-links img {
	filter: brightness(0)saturate(100%)
}

.force-dark .social-links-sidebar .social-links img {
	filter: brightness(0)saturate(100%)invert(1)
}

.social-links-sidebar .social-links a {
	display: inline-block;
	color: var(--primary-color)
}

.social-links-sidebar .social-links a svg {
	width: 1.5rem;
	height: 1.5rem;
	fill: currentColor
}

.latest-articles .titre-section {
	text-align: center;
	font-size: 2rem;
	margin-bottom: 2rem;
	color: var(--heading-color)
}

.latest-articles ul {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-wrap: wrap;
	gap: 1rem
}

.latest-articles ul li {
	width: 100%;
	height: 100%;
	box-sizing: border-box
}

.latest-articles ul li a {
	display: flex;
	width: 100%;
	height: 100%;
	position: relative;
	overflow: hidden;
	border-radius: .625rem;
	text-decoration: none;
	transition: transform .3s ease
}

.latest-articles ul li a:hover {
	transform: translateY(-5px)
}

.latest-articles ul li a img {
	width: 100%;
	height: 200px;
	object-fit: cover;
	transition: transform .3s ease;
	border-bottom-left-radius: .625rem;
	border-bottom-right-radius: .625rem
}

.latest-articles ul li a:hover img {
	transform: scale(1.05)
}

.latest-articles ul li a h4 {
	position: absolute;
	bottom: 0;
	left: 0;
	width: 100%;
	margin: 0;
	padding: .75rem 1rem;
	background: rgba(0, 0, 0, .7);
	color: #fff;
	font-size: .95rem;
	line-height: 1.3;
	box-sizing: border-box;
	display: -webkit-box;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 3;
	line-clamp: 3;
	overflow: hidden;
	text-overflow: ellipsis;
	transition: font-size .3s ease
}

.bg-primary {
	--tw-bg-opacity: 0.2;
	background-color: #556d8d;
	background-color: rgba(85, 109, 141, var(--tw-bg-opacity));
	border-bottom-left-radius: .625rem;
	border-bottom-right-radius: .625rem
}

.hover\:bg-neutral-darkest:hover {
	--tw-bg-opacity: 0.5;
	background-color: #2a2e37;
	background-color: rgba(42, 46, 55, var(--tw-bg-opacity))
}

.transition-colors {
	transition-duration: .15s;
	transition-property: background-color, border-color, color, fill, stroke;
	transition-timing-function: cubic-bezier(.4, 0, .2, 1)
}

.w-full {
	width: 100%
}

.h-40 {
	height: 7rem
}

.block {
	display: block
}

.mb-2 {
	margin-bottom: .5rem
}

.relative {
	position: relative
}

.multiply {
	mix-blend-mode: multiply
}

.text-white {
	color: #fff
}

.text-right {
	text-align: right
}

.p-8 {
	padding: 2rem
}

.flex {
	display: flex
}

.items-center {
	align-items: center
}

.text-left {
	text-align: left
}

.font-switcher img {
	transition: transform .3s ease
}

.font-switcher img:hover {
	transform: scale(1.2)
}

.embed {
	position: relative;
	margin-bottom: 2rem;
	height: 100%;
	overflow: hidden;
	max-width: 100%
}

.embed iframe {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%
}

.banner {
	margin-bottom: .5rem
}

.banner-band {
	margin-bottom: 0;
	width: 100%;
	overflow: hidden;
	display: flex;
	justify-content: center;
	align-items: center
}

#bottom-post-banner {
	background-color: var(--background-color-secondary);
	border-radius: .5rem;
	padding: 1.5rem;
	margin-top: 3rem;
	box-shadow: 0 2px 4px rgba(0, 0, 0, .1)
}

#bottom-post-banner p {
	margin-bottom: 1rem;
	line-height: 1.5
}

#bottom-post-banner a {
	color: var(--heading-color);
	text-decoration: none;
	transition: color .3s ease
}

#bottom-post-banner a:hover {
	color: var(--button-primary-background)
}

#bottom-post-banner .text-center {
	text-align: center
}

#bottom-post-banner .text-center a {
	font-size: 1.5rem;
	font-weight: 700;
	color: var(--link-color);
	text-decoration: none;
	transition: color .3s ease
}

#bottom-post-banner .text-center a:hover {
	color: var(--link-hover-color)
}

#bottom-post-banner img {
	max-width: 70%;
	height: auto;
	display: block;
	margin: 0 auto
}

.pub-section {
	text-align: center;
	border-radius: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-wrap: nowrap;
	backdrop-filter: blur(5px);
	max-width: 100%;
	margin: 0 auto;
	padding: 0 15px
}

.pub-section span {
	color: var(--primary-color);
	font-size: .8em;
	white-space: nowrap
}

.pub-section .offer-text {
	font-size: 1.2em;
	font-weight: 700;
	white-space: normal;
	word-wrap: break-word
}

.pub-section .cta-button {
	display: inline-block;
	padding: .25rem .5rem;
	background-color: var(--button-primary-background);
	color: var(--heading-color);
	text-decoration: none;
	border-radius: .25rem;
	font-weight: 700;
	font-size: .8em;
	white-space: nowrap;
	margin: 0 .5rem;
	transition: transform .3s ease, opacity .3s ease;
	box-shadow: 0 2px 4px rgba(0, 0, 0, .2)
}

.pub-section .cta-button:hover {
	animation: rotate .6s ease-in-out;
	transform-origin: center
}

@keyframes rotate {
	0% {
		transform: rotate(0)
	}

	25% {
		transform: rotate(-5deg)
	}

	75% {
		transform: rotate(5deg)
	}

	100% {
		transform: rotate(0)
	}
}

.pub-section span:last-child {
	font-size: .9rem
}

.guardia-articles {
	padding: 2rem 0
}

.guardia-articles ul {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: .5rem
}

.guardia-articles ul li {
	width: 100%;
	box-sizing: border-box
}

.guardia-articles ul,
.guardia-articles ul li {
	list-style: none;
	list-style-type: none;
	padding: 0;
	margin: 0
}

.guardia-articles ul,
.guardia-articles ul li {
	list-style: none;
	list-style-type: none
}

.guardia-articles ul li a {
	display: block;
	width: 100%;
	position: relative;
	overflow: hidden;
	border-radius: .625rem;
	text-decoration: none;
	transition: transform .3s ease
}

.guardia-articles ul li a:hover {
	transform: translateY(-5px)
}

.guardia-articles ul li a img {
	width: 100%;
	height: 200px;
	object-fit: cover;
	transition: transform .3s ease;
	border-bottom-left-radius: .625rem;
	border-bottom-right-radius: .625rem
}

.guardia-articles ul li a:hover img {
	transform: scale(1.05)
}

.guardia-articles ul li a .titre-style {
	position: absolute;
	bottom: 0;
	left: 0;
	width: 100%;
	margin: 0;
	padding: .5rem 1rem;
	background: rgba(0, 0, 0, .5);
	color: #fff;
	font-size: 1rem;
	text-align: center;
	box-sizing: border-box;
	line-height: 1.2;
	transition: font-size .3s ease
}

#search-box {
	margin-bottom: 2rem;
	width: 80%
}

#search-container {
	width: 100%;
	max-width: 800px;
	margin: 0 auto;
	padding: 1rem;
	box-sizing: border-box
}

#search-input {
	width: 100%;
	max-width: 100%;
	box-sizing: border-box;
	padding: .75rem;
	font-size: 1rem;
	border: 1px solid var(--border-color);
	border-radius: var(--border-radius-base);
	background-color: var(--background-color-secondary);
	color: var(--primary-color)
}

#search-input:focus {
	outline: none;
	box-shadow: 0 0 0 2px var(--link-color)
}

#search {
	width: 100%
}

.pagefind-ui {
	--pagefind-ui-scale: 1;
	--pagefind-ui-primary: var(--link-color);
	--pagefind-ui-text: var(--primary-color);
	--pagefind-ui-background: var(--background-color-secondary);
	--pagefind-ui-border: var(--border-color);
	--pagefind-ui-tag: var(--background-color-tertiary);
	--pagefind-ui-border-width: 1px;
	--pagefind-ui-border-radius: var(--border-radius-base);
	--pagefind-ui-font: var(--font-base)
}

.pagefind-ui__search-input {
	background-color: var(--background-color-secondary) !important;
	color: var(--primary-color) !important;
	border-color: var(--border-color) !important
}

.pagefind-ui__search-input::placeholder {
	color: var(--primary-color);
	opacity: .6
}

.pagefind-ui__result {
	padding: 1rem 0;
	border-bottom: 1px solid var(--border-color)
}

.pagefind-ui__result-link {
	color: var(--heading-color) !important;
	font-weight: 600
}

.pagefind-ui__result-link:hover {
	color: var(--link-color) !important
}

.pagefind-ui__result-excerpt {
	color: var(--primary-color);
	font-size: .9rem;
	line-height: 1.5
}

.pagefind-ui__result-excerpt mark {
	background-color: var(--link-color);
	color: var(--button-primary-foreground);
	padding: .1em .2em;
	border-radius: 2px
}

.pagefind-ui__message {
	color: var(--primary-color);
	font-style: italic
}

.pagefind-ui__button {
	background-color: var(--link-color) !important;
	color: var(--button-primary-foreground) !important;
	border-radius: var(--border-radius-base) !important
}

.pagefind-ui__button:hover {
	opacity: .9
}

figure.aligncenter,
figure.wp-block-video.aligncenter,
.wp-block-video {
	justify-content: center;
	align-items: center;
	margin: 1em auto;
	width: 100%;
	position: relative;
	height: 100%;
	overflow: hidden;
	max-width: 100%
}

figure.aligncenter img,
figure.wp-block-video.aligncenter video,
.wp-block-video video {
	max-width: 100%;
	height: auto;
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	object-fit: contain
}

figure.aligncenter,
figure.wp-block-video.aligncenter,
.wp-block-video {
	position: relative;
	width: 100%;
	height: 100%;
	overflow: hidden
}

figure.aligncenter video,
figure.wp-block-video.aligncenter video,
.wp-block-video video {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	object-fit: contain
}

figure {
	margin: 1em auto;
	width: 100%;
	max-width: 900px
}

figure video {
	width: 100%;
	height: auto;
	max-width: 100%;
	display: block
}

.content .highlight,
.content .chroma,
.article-content .highlight,
.article-content .chroma {
	background-color: var(--background-color-tertiary);
	color: var(--primary-color);
	padding: 1rem;
	border-radius: .5rem;
	overflow-x: auto;
	margin-bottom: 1.5rem;
	max-width: 100%;
	position: relative;
	display: block
}

.content .highlight pre,
.content .chroma pre,
.article-content .highlight pre,
.article-content .chroma pre {
	background-color: var(--background-color-tertiary);
	color: var(--primary-color);
	background: 0 0;
	padding: 0;
	margin: 0;
	overflow-x: visible;
	white-space: pre;
	word-wrap: normal;
	tab-size: 4;
	-moz-tab-size: 4;
	-o-tab-size: 4
}

.content .highlight code,
.content .chroma code,
.article-content .highlight code,
.article-content .chroma code {
	background-color: var(--background-color-tertiary);
	color: var(--primary-color);
	background: 0 0;
	color: inherit;
	font-size: .9em;
	font-family: monospace, courier new, Courier, monospace;
	display: block
}

.content {
	max-width: 100%
}

.article-content {
	max-width: 90%
}

.subcategory-title {
	font-size: 2.5em;
	color: var(--primary-color);
	margin-bottom: .5em;
	text-align: center
}

.subcategory-description {
	font-size: .9rem;
	line-height: 1.6;
	color: var(--text-color);
	margin-bottom: 2em;
	text-align: justify;
	margin: 2rem auto;
	padding-left: 6rem;
	padding-right: 6rem;
	max-width: 1800px
}

@media(max-width:1400px) {
	.subcategory-description {
		padding-left: 4rem;
		padding-right: 4rem
	}
}

@media(max-width:1200px) {
	.subcategory-description {
		padding-left: 4rem;
		padding-right: 4rem
	}
}

@media(max-width:992px) {
	.subcategory-description {
		padding-left: 2rem;
		padding-right: 2rem
	}
}

@media(max-width:768px) {
	.subcategory-description {
		padding-left: 2rem;
		padding-right: 2rem;
		margin: 1rem
	}
}

@media(max-width:576px) {
	.subcategory-description {
		padding-left: 1rem;
		padding-right: 1rem;
		margin: .5rem
	}
}

.subcategory-description .article-link {
	color: var(--primary-color);
	text-decoration: none;
	font-weight: 700;
	transition: color .3s ease
}

.subcategory-description .article-link:hover {
	color: var(--secondary-color);
	text-decoration: underline
}

.author-title {
	font-size: 2.5rem;
	color: var(--heading-color);
	margin-bottom: 1.5rem;
	text-align: center
}

.author-title .h1 {
	padding: 0;
	margin: 0
}

#author-profile {
	background-color: var(--background-color-secondary);
	margin-bottom: 2rem
}

.author-profile-content {
	display: flex;
	flex-direction: column;
	align-items: center
}

.author-avatar {
	width: 150px;
	height: 150px;
	border-radius: 50%;
	object-fit: cover;
	margin-bottom: 1rem
}

.author-bio {
	text-align: justify;
	margin-bottom: 1rem;
	line-height: 1.6;
	margin: 0 1.25rem 1.25rem;
	padding: 0 1.25rem
}

.author-website {
	font-style: italic
}

.author-website a {
	color: var(--link-color);
	text-decoration: none;
	transition: color .3s ease
}

.author-website a:hover {
	color: var(--button-primary-background)
}

.author-articles {
	margin-top: 3rem
}

.author-articles h2 {
	font-size: 1.5rem;
	color: var(--heading-color);
	margin-bottom: 1.5rem;
	text-align: center
}

.authors-list {
	max-width: 1200px;
	padding: 2rem
}

.wp-block-image.aligncenter {
	display: flex;
	justify-content: center
}

.wp-block-image.aligncenter img {
	display: block;
	margin: 0 auto
}

.wp-block-image.aligncenter img[style*=width] {
	width: auto;
	max-width: 100%
}

.video-container {
	position: relative;
	width: 100%;
	height: 100%;
	overflow: hidden;
	max-width: 100%;
	margin-bottom: 1rem;
	display: block;
	clear: both
}

.vimeo-container,
.dailymotion-container,
.spotify-container,
.soundcloud-container,
.tiktok-container {
	margin-bottom: 1.5rem;
	display: block;
	clear: both
}

.video-container video {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%
}

figure.wp-block-video,
figure.aligncenter {
	margin: 1em auto;
	width: 100%;
	max-width: 900px
}

figure.wp-block-video video,
figure.aligncenter video {
	width: 100%;
	height: auto;
	max-width: 100%;
	display: block
}

.wp-block-embed.aligncenter {
	text-align: center
}

.breadcrumb-nav {
	margin-right: 1rem;
	margin-bottom: 0
}

.breadcrumb {
	padding: 0;
	margin: 0
}

.breadcrumb li {
	display: inline
}

.breadcrumb a {
	color: var(--text-color-secondary);
	text-decoration: none;
	transition: color .3s ease
}

.breadcrumb a:hover {
	color: var(--link-color)
}

.breadcrumb li:last-child {
	color: var(--text-color);
	font-weight: 600
}

.header-icons {
	display: flex;
	justify-content: flex-end;
	align-items: center;
	flex-wrap: nowrap;
	margin-right: 6%
}

.hamburger-menu,
.theme-switcher,
.search-modal,
.font-switcher {
	margin-left: .5rem
}

@media screen and (min-width:1920px) {
	.article-content {
		max-width: 60%
	}
}

@media screen and (max-width:767px) {
	body {
		overflow-x: hidden
	}

	.latest-articles h5 {
		top: 0
	}

	.latest-articles {
		width: 100%
	}

	.main-container {
		flex-direction: column
	}

	.articles {
		width: 100%;
		max-width: 100%
	}

	aside {
		width: 100%;
		max-width: none;
		margin-left: 0;
		height: auto;
		position: static
	}

	aside img {
		max-width: 100%;
		height: auto
	}

	aside a {
		display: block;
		width: 100%;
		margin-bottom: .5rem;
		color: var(--link-color);
		text-decoration: none;
		word-wrap: break-word
	}

	.article-content {
		width: 90%
	}

	.latest-articles ul {
		display: grid;
		grid-template-columns: repeat(2, 1fr);
		gap: .5rem;
		width: 98%
	}

	.social-links-sidebar .social-links {
		justify-content: center
	}

	.join-community,
	.support-section {
		max-width: min(80%, 400px);
		margin-left: auto;
		margin-right: auto;
		padding: 1rem
	}

	.join-community h3 {
		font-size: 1rem
	}
}

@media screen and (max-width:600px) {
	body {
		overflow-x: hidden
	}

	.article-content {
		padding: 1rem;
		margin: 0
	}

	#search-container {
		padding: .5rem
	}

	#search-input {
		font-size: .875rem;
		padding: .5rem
	}
}

.no-js {
	visibility: hidden
}

@media(max-width:1200px) {
	body {
		overflow-x: hidden
	}

	.latest-articles ul li {
		flex: 1 1 calc(33.333% - 1rem);
		height: 100%
	}

	.latest-articles ul li a img {
		height: 180px
	}

	.latest-articles ul li a h4 {
		font-size: .95rem
	}
}

@media(max-width:992px) {
	body {
		overflow-x: hidden
	}

	.latest-articles ul li {
		flex: 1 1 calc(50% - 1rem);
		height: 100%
	}

	.latest-articles ul li a img {
		height: 160px
	}

	.latest-articles ul li a h4 {
		font-size: .9rem
	}
}

@media(max-width:768px) {
	body {
		overflow-x: hidden
	}

	.latest-articles {
		margin-left: 0;
		margin-right: 0
	}

	.latest-articles ul {
		flex-direction: column;
		align-items: center;
		display: flex;
		width: 100%
	}

	.latest-articles ul li {
		flex: 1 1 100%;
		max-width: 100%;
		height: auto
	}

	.latest-articles ul li a {
		height: auto
	}

	.latest-articles ul li a img {
		height: 200px
	}

	.latest-articles ul li a h4 {
		font-size: 1rem
	}

	.pub-section {
		width: 100%;
		padding: 0 10px
	}
}

@media(max-width:576px) {
	body {
		overflow-x: hidden
	}

	.latest-articles ul li a h4 {
		font-size: .9rem
	}
}

@media(min-width:1024px) {
	body {
		overflow-x: hidden
	}

	.alignwide {
		margin-left: -5rem;
		margin-right: -5rem
	}
}

@media screen and (min-width:769px) {
	header>nav.header-buttons {
		display: flex !important
	}

	header>nav.header-buttons .cta-buttons {
		display: flex !important
	}

	.hamburger-menu {
		display: none !important
	}
}

@media screen and (max-width:480px) {
	body {
		overflow-x: hidden
	}

	.related-posts-grid {
		grid-template-columns: 1fr
	}
}

@media screen and (max-width:768px) {
	body {
		overflow-x: hidden
	}

	header {
		display: flex;
		justify-content: space-between;
		align-items: center;
		padding: .75rem;
		padding-top: .75rem
	}

	header>nav.header-buttons {
		display: none
	}

	.related-posts-grid {
		grid-template-columns: repeat(2, 1fr)
	}

	.main-container {
		display: flex;
		flex-direction: column;
		width: 100%;
		padding-top: 0
	}

	.article-card {
		flex: 1 1 100%
	}

	aside,
	main {
		max-width: 100%;
		order: 2
	}

	.article-content {
		width: 90%
	}

	.article-content p {
		text-align: left
	}

	.header-top {
		justify-content: space-between
	}

	.header-logo {
		flex: initial;
		display: flex;
		justify-content: flex-start;
		align-items: center;
		align-self: center;
		min-width: 0;
		position: static !important;
		left: auto !important;
		transform: none !important
	}

	.logo {
		text-align: left;
		width: auto;
		max-width: clamp(9rem, 42vw, 13rem);
		margin: 0
	}

	.logo img {
		width: 100%;
		height: auto;
		max-height: clamp(2.75rem, 12vw, 3.75rem)
	}

	.header-icons {
		justify-content: flex-end;
		align-self: center;
		width: auto;
		padding: 0 .5rem;
		gap: 0;
		flex-shrink: 0;
		margin-right: 0
	}

	.hamburger-menu,
	.theme-switcher,
	.search-modal,
	.search-link,
	.font-switcher {
		margin: 0 .25rem
	}

	.header-icons img {
		width: 1.25rem;
		height: auto
	}

	.header-bottom,
	.cta-buttons {
		display: none
	}

	footer {
		padding: 3.125rem;
		flex-wrap: nowrap
	}

	.footer-links a,
	.social-links a {
		display: inline-block;
		margin: 0 .625rem;
		color: var(--footer-link)
	}

	.social-links {
		flex-wrap: wrap;
		flex-direction: row
	}

	.footer-bottom {
		font-size: .9em;
		padding: 1.25rem 0
	}

	.footer-socials {
		text-align: center;
		padding-bottom: 1.25rem
	}

	.footer-socials img {
		width: 1.5rem;
		height: 1.5rem;
		margin: .3125rem auto;
		display: block;
		filter: brightness(0)invert(1)
	}

	.footer-right .header-icons {
		flex-wrap: wrap;
		align-items: center;
		padding-top: 1.25rem;
		width: 100%
	}

	.footer-right .header-icons img {
		width: 3rem;
		height: 3rem;
		margin-bottom: .625rem
	}

	.author-title {
		font-size: 2rem
	}

	.author-articles h2 {
		font-size: 1.5rem
	}

	.hamburger-menu,
	.theme-switcher,
	.search-modal,
	.font-switcher {
		margin: .5rem
	}

	.hamburger-menu {
		display: block
	}

	.hamburger-menu input[type=checkbox] {
		display: none
	}

	.menu-icon {
		cursor: pointer;
		display: inline-block
	}

	#menu-toggle:checked~.menu-overlay {
		display: block
	}

	.navigation {
		display: none
	}

	.latest-articles ul {
		flex-direction: column;
		align-items: center
	}

	.latest-articles ul li {
		flex: 1 1 100%;
		max-width: 100%
	}

	.latest-articles ul li a h4 {
		font-size: 1rem
	}
}

@media screen and (max-width:480px) {
	body {
		overflow-x: hidden
	}

	.related-posts-grid {
		grid-template-columns: 1fr
	}
}

@media screen and (max-width:414px) {
	body {
		overflow-x: hidden
	}

	header {
		padding: .5rem;
		display: flex;
		justify-content: space-between;
		align-items: center
	}

	.header-icons {
		display: flex;
		justify-content: flex-end;
		align-items: center;
		width: auto;
		padding: 0 .5rem;
		flex-wrap: nowrap;
		flex-shrink: 0;
		margin-right: 0
	}

	.hamburger-menu,
	.theme-switcher,
	.search-modal,
	.font-switcher {
		margin-right: .25rem;
		flex: none
	}

	.hamburger-menu img,
	.theme-switcher img,
	.search-modal img,
	.font-switcher img {
		height: 1.25rem;
		width: 1.25rem
	}

	.header-logo {
		flex: initial;
		display: flex;
		justify-content: flex-start;
		align-items: center;
		min-width: 0;
		position: static !important;
		left: auto !important;
		transform: none !important
	}

	.logo {
		text-align: left;
		width: auto;
		max-width: clamp(8rem, 48vw, 12rem);
		margin: 0
	}

	.logo img {
		width: 100%;
		height: auto;
		max-height: clamp(2.25rem, 14vw, 3.25rem)
	}

	.header-top {
		flex-wrap: nowrap
	}
}

@media screen and (min-aspect-ratio:13/9) {
	body {
		overflow-x: hidden
	}

	.menu-overlay {
		max-width: 100vw;
		margin: 0 auto
	}
}

.page-title {
	font-size: 1.1rem;
	margin: 0;
	color: rgba(255, 255, 255, .8);
	text-align: center;
	background: var(--background-color-hero);
	padding: .5rem 0;
	width: 100%;
	letter-spacing: .1em;
	font-weight: 400;
	text-transform: uppercase;
	font-family: -apple-system, BlinkMacSystemFont, segoe ui, Roboto, Oxygen-Sans, Ubuntu, Cantarell, Noto Sans, sans-serif, BlinkMacSystemFont, Helvetica Neue, Arial, Apple Color Emoji, Segoe UI Emoji, Segoe UI Symbol, Noto Color Emoji
}

.content .highlight,
.content .chroma,
.article-content .highlight,
.article-content .chroma {
	background-color: var(--background-color-tertiary);
	color: var(--primary-color);
	padding: 1rem;
	border-radius: .5rem;
	overflow-x: auto;
	overflow-y: hidden;
	margin-bottom: 1.5rem;
	font-family: monaco, consolas, monospace;
	font-size: .9rem;
	line-height: 1.5;
	border: 1px solid rgba(0, 0, 0, .1);
	max-width: 100%;
	position: relative
}

.content .highlight pre,
.content .chroma pre,
.article-content .highlight pre,
.article-content .chroma pre {
	background-color: transparent;
	color: var(--primary-color);
	padding: 0;
	margin: 0;
	overflow-x: auto;
	white-space: pre;
	word-wrap: normal;
	max-width: 100%
}

.content .highlight code,
.content .chroma code,
.article-content .highlight code,
.article-content .chroma code {
	background-color: transparent;
	color: var(--primary-color);
	display: block;
	tab-size: 4;
	max-width: 100%
}

.language-javascript .highlight,
.language-js .highlight {
	border-left: 4px solid var(--link-color)
}

.highlight .kd,
.highlight .k {
	color: #569cd6
}

.highlight .s,
.highlight .s1,
.highlight .s2 {
	color: #ce9178
}

.highlight .nx,
.highlight .na {
	color: #9cdcfe
}

.highlight .o {
	color: #000
}

.highlight .p {
	color: #000
}

.highlight .c1,
.highlight .cm {
	color: #6a9955;
	font-style: italic
}

.highlight .l,
.highlight .m,
.highlight .s .sl,
.highlight code span:not([class]) {
	color: #000
}

@media(prefers-color-scheme:dark) {

	.highlight,
	.chroma {
		border-color: rgba(255, 255, 255, .1)
	}
}

:not(pre)>code {
	background-color: var(--background-color-tertiary);
	color: var(--primary-color);
	padding: .2em .4em;
	border-radius: .3em;
	font-size: .9em;
	font-family: monaco, consolas, monospace
}

@media screen and (max-width:768px) {

	.article-card .article-title,
	.article-title a {
		-webkit-line-clamp: unset;
		line-clamp: unset;
		max-height: none;
		display: block
	}
}

@media screen and (max-width:1100px) {
	.sidebar {
		display: none
	}

	.article-content {
		margin-right: auto
	}
}

.wp-block-group {
	margin: 1.5rem 0;
	padding: 1rem;
	border-radius: .375rem
}

.wp-block-group.has-background {
	border: 1px solid rgba(0, 0, 0, .1)
}

.has-pale-cyan-blue-background-color {
	background-color: #8ed1fc !important;
	color: #333 !important
}

.has-light-gray-background-color {
	background-color: #f7f7f7 !important;
	color: #333 !important
}

.has-very-light-gray-background-color {
	background-color: #eee !important;
	color: #333 !important
}

.has-cyan-bluish-gray-background-color {
	background-color: #abb8c3 !important;
	color: #fff !important
}

.has-white-background-color {
	background-color: #fff !important;
	color: #333 !important
}

.has-pale-pink-background-color {
	background-color: #f78da7 !important;
	color: #fff !important
}

.has-vivid-red-background-color {
	background-color: #cf2e2e !important;
	color: #fff !important
}

.has-luminous-vivid-orange-background-color {
	background-color: #ff6900 !important;
	color: #fff !important
}

.has-luminous-vivid-amber-background-color {
	background-color: #fcb900 !important;
	color: #333 !important
}

.has-light-green-cyan-background-color {
	background-color: #7bdcb5 !important;
	color: #333 !important
}

.has-vivid-green-cyan-background-color {
	background-color: #00d084 !important;
	color: #fff !important
}

.has-vivid-cyan-blue-background-color {
	background-color: #0693e3 !important;
	color: #fff !important
}

.has-vivid-purple-background-color {
	background-color: #9b51e0 !important;
	color: #fff !important
}

:root {
	--wp--preset--spacing--20: 1.25rem;
	--wp--preset--spacing--30: 1.875rem;
	--wp--preset--spacing--40: 2.5rem;
	--wp--preset--spacing--50: 3.125rem;
	--wp--preset--spacing--60: 3.75rem;
	--wp--preset--spacing--70: 4.375rem;
	--wp--preset--spacing--80: 5rem
}

.hacker-banner-wrapper {
	width: 100%;
	max-width: 100%;
	margin: 0;
	padding: 0;
	overflow-x: hidden
}

.hacker-banner-link {
	display: block;
	text-decoration: none;
	cursor: pointer
}

.hacker-banner {
	position: relative;
	background: #000;
	padding: 20px;
	overflow: hidden;
	min-height: 90px;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	box-sizing: border-box
}

.scanlines {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	pointer-events: none;
	background: linear-gradient(to bottom, transparent 50%, rgba(0, 255, 0, 3%) 51%);
	background-size: 100% 4px;
	animation: scanlines 8s linear infinite
}

@keyframes scanlines {
	0% {
		transform: translateY(0)
	}

	100% {
		transform: translateY(10px)
	}
}

.hacker-content {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 30px;
	z-index: 2;
	position: relative
}

.hack-text {
	flex-shrink: 0
}

.separator {
	color: #0f0;
	font-size: 2.5rem;
	opacity: .5;
	animation: pulse-separator 2s ease-in-out infinite
}

@keyframes pulse-separator {

	0%,
	100% {
		opacity: .3
	}

	50% {
		opacity: .8
	}
}

.message-text {
	display: flex;
	flex-direction: column;
	gap: 5px;
	align-items: flex-start
}

.hack-info {
	color: red;
	font-size: 1.1rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 2px;
	text-shadow: 0 0 10px red
}

.cta-text {
	color: #0f0;
	font-size: 1.2rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 1px;
	text-shadow: 0 0 10px #0f0;
	transition: all .3s ease
}

.hacker-banner-link:hover .cta-text {
	text-shadow: 0 0 20px #0f0;
	letter-spacing: 2px
}

@keyframes flicker {

	0%,
	100% {
		opacity: 1
	}

	50% {
		opacity: .8
	}
}

.hacker-message {
	display: flex;
	align-items: center;
	gap: 10px;
	font-size: 1rem
}

.big-glitch {
	position: relative;
	font-size: 3rem;
	font-weight: 900;
	color: #0f0;
	text-transform: uppercase;
	letter-spacing: 5px;
	animation: glitch-text 3s infinite
}

.big-glitch::before,
.big-glitch::after {
	content: attr(data-text);
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%
}

.big-glitch::before {
	animation: glitch-1 .3s cubic-bezier(.25, .46, .45, .94)both infinite;
	color: red;
	z-index: -1
}

.big-glitch::after {
	animation: glitch-2 .3s cubic-bezier(.25, .46, .45, .94)reverse both infinite;
	color: #0ff;
	z-index: -2
}

@keyframes glitch-text {

	0%,
	100% {
		text-shadow: 0 0 10px #0f0, 0 0 20px #0f0, 0 0 30px #0f0
	}

	20% {
		text-shadow: -2px 0 red, 2px 0 #0ff, 0 0 10px #0f0
	}

	40% {
		text-shadow: 2px 0 red, -2px 0 #0ff, 0 0 10px #0f0
	}
}

@keyframes glitch-1 {

	0%,
	100% {
		clip-path: inset(40% 0 60% 0);
		transform: translate(-2px, -1px)
	}

	20% {
		clip-path: inset(20% 0 30% 0);
		transform: translate(2px, 1px)
	}

	40% {
		clip-path: inset(60% 0 20% 0);
		transform: translate(-1px, 2px)
	}

	60% {
		clip-path: inset(10% 0 80% 0);
		transform: translate(1px, -2px)
	}

	80% {
		clip-path: inset(70% 0 15% 0);
		transform: translate(-2px, 1px)
	}
}

@keyframes glitch-2 {

	0%,
	100% {
		clip-path: inset(25% 0 70% 0);
		transform: translate(2px, 1px)
	}

	20% {
		clip-path: inset(70% 0 20% 0);
		transform: translate(-1px, -2px)
	}

	40% {
		clip-path: inset(5% 0 90% 0);
		transform: translate(1px, 2px)
	}

	60% {
		clip-path: inset(80% 0 5% 0);
		transform: translate(-2px, -1px)
	}

	80% {
		clip-path: inset(30% 0 60% 0);
		transform: translate(2px, -1px)
	}
}

.typing-text {
	color: #0f0;
	font-size: .9rem;
	opacity: 0;
	animation: typing 2s steps(30).5s forwards;
	white-space: nowrap
}

@keyframes typing {
	to {
		opacity: 1
	}
}

.blink {
	animation: blink-animation 1s infinite;
	color: #0f0;
	font-weight: 700;
	margin-right: 15px
}

@keyframes blink-animation {

	0%,
	49% {
		opacity: 1
	}

	50%,
	100% {
		opacity: 0
	}
}

.arrow-hack {
	color: #0f0;
	font-weight: 700;
	font-size: 1.2rem;
	margin: 0 5px
}

.summer-series {
	color: #ff0;
	font-weight: 700;
	text-shadow: 0 0 5px #ff0;
	white-space: nowrap;
	font-size: 1.1rem;
	text-transform: uppercase
}

@media screen and (max-width:768px) {
	.hacker-banner-wrapper {
		width: 100%;
		max-width: 100%;
		overflow-x: hidden
	}

	.hacker-banner {
		padding: 15px 10px;
		min-height: 70px;
		width: 100%;
		max-width: 100%
	}

	.hacker-content {
		gap: 15px;
		width: 100%;
		max-width: 100%;
		padding: 0 5px
	}

	.big-glitch {
		font-size: 2rem;
		letter-spacing: 3px
	}

	.separator {
		font-size: 1.8rem
	}

	.hack-info {
		font-size: .85rem;
		letter-spacing: 1px
	}

	.cta-text {
		font-size: .9rem
	}
}

@media screen and (max-width:480px) {
	.hacker-content {
		flex-direction: column;
		gap: 10px;
		width: 100%;
		overflow-wrap: break-word
	}

	.separator {
		display: none
	}

	.message-text {
		align-items: center;
		text-align: center;
		width: 100%;
		padding: 0 10px
	}

	.hack-info,
	.cta-text {
		white-space: normal;
		word-wrap: break-word;
		max-width: 100%
	}
}

.subcategory-title .collection-glitch {
	position: relative;
	display: inline-block;
	font-weight: inherit;
	color: inherit;
	animation: glitch-text-subtle 4s infinite
}

.subcategory-title .collection-glitch::before,
.subcategory-title .collection-glitch::after {
	content: attr(data-text);
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%
}

.subcategory-title .collection-glitch::before {
	animation: glitch-1-subtle .5s cubic-bezier(.25, .46, .45, .94)both infinite;
	color: #ff0060;
	z-index: -1;
	opacity: .8
}

.subcategory-title .collection-glitch::after {
	animation: glitch-2-subtle .5s cubic-bezier(.25, .46, .45, .94)reverse both infinite;
	color: #0ff;
	z-index: -2;
	opacity: .8
}

@keyframes glitch-text-subtle {

	0%,
	100% {
		text-shadow: none
	}

	20% {
		text-shadow: -1px 0 #ff0060, 1px 0 #0ff
	}

	40% {
		text-shadow: 1px 0 #ff0060, -1px 0 #0ff
	}
}

@keyframes glitch-1-subtle {

	0%,
	100% {
		clip-path: inset(40% 0 60% 0);
		transform: translate(-1px, 0)
	}

	20% {
		clip-path: inset(20% 0 30% 0);
		transform: translate(1px, 0)
	}

	40% {
		clip-path: inset(60% 0 20% 0);
		transform: translate(-1px, 0)
	}

	60% {
		clip-path: inset(10% 0 80% 0);
		transform: translate(1px, 0)
	}

	80% {
		clip-path: inset(70% 0 15% 0);
		transform: translate(-1px, 0)
	}
}

@keyframes glitch-2-subtle {

	0%,
	100% {
		clip-path: inset(25% 0 70% 0);
		transform: translate(1px, 0)
	}

	20% {
		clip-path: inset(70% 0 20% 0);
		transform: translate(-1px, 0)
	}

	40% {
		clip-path: inset(5% 0 90% 0);
		transform: translate(1px, 0)
	}

	60% {
		clip-path: inset(80% 0 5% 0);
		transform: translate(-1px, 0)
	}

	80% {
		clip-path: inset(30% 0 60% 0);
		transform: translate(1px, 0)
	}
}

:root {
	--font-body: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, Cantarell, 'Open Sans', 'Helvetica Neue', sans-serif;
	--border-radius-base: 12px;
	--border-radius-large: 16px;
	--border-radius-pill: 9999px;
	--box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
	--box-shadow-hover: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04)
}

body {
	font-family: var(--font-body);
	line-height: 1.6;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale
}

.force-dark {
	--background-color-page: #0f172a;
	--background-color-sidebar: #1e293b;
	--background-color-secondary: #1e293b;
	--background-color-side: #1e293b;
	--background-color-hero: #1e293b;
	--card-bg: #1e293b;
	--border-color: #334155;
	--heading-color: #f1f5f9;
	--text-color: #cbd5e1;
	--box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.3), 0 2px 4px -1px rgba(0, 0, 0, 0.2)
}

.article-card,
.card,
.patreon-card,
.twitch-card,
.edito-card,
.matos-card {
	border: 1px solid rgba(229, 231, 235, .5);
	transition: all .3s cubic-bezier(.4, 0, .2, 1) !important;
	border-radius: var(--border-radius-large) !important;
	overflow: hidden
}

.force-dark .article-card,
.force-dark .card,
.force-dark .patreon-card,
.force-dark .twitch-card {
	border: 1px solid rgba(255, 255, 255, 5%)
}

.article-card:hover,
.card:hover {
	transform: translateY(-5px)scale(1.01) !important;
	box-shadow: var(--box-shadow-hover) !important;
	border-color: var(--link-color)
}

.article-card img,
.card img {
	transition: transform .5s ease
}

.article-card:hover img {
	transform: scale(1.05)
}

.button,
.cta-button,
input[type=submit] {
	border-radius: var(--border-radius-pill) !important;
	font-weight: 600;
	letter-spacing: .025em;
	padding: .6rem 1.5rem !important;
	text-transform: none !important;
	white-space: nowrap;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	line-height: 1.2;
	min-height: 44px
}

pre {
	background: #1e293b !important;
	border-radius: var(--border-radius-base);
	position: relative;
	padding-top: 2.5rem !important;
	border: 1px solid rgba(255, 255, 255, .1);
	box-shadow: var(--box-shadow);
	overflow: hidden
}

pre::before {
	content: "â—  â—  â—";
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 2rem;
	background: rgba(255, 255, 255, 5%);
	border-bottom: 1px solid rgba(255, 255, 255, 5%);
	color: rgba(255, 255, 255, .2);
	font-size: 10px;
	line-height: 2rem;
	padding-left: 1rem;
	letter-spacing: 4px;
	text-align: left
}

code {
	font-family: fira code, consolas, monaco, courier new, monospace;
	font-size: .9em
}

blockquote {
	border-left: 4px solid var(--link-color);
	background: rgba(125, 125, 125, 5%);
	margin: 1.5rem 0;
	padding: 1rem 1.5rem;
	border-radius: 0 var(--border-radius-base)var(--border-radius-base)0;
	font-style: italic;
	color: var(--text-color)
}

.content h2 {
	position: relative;
	display: inline-block;
	margin-top: 2.5rem;
	margin-bottom: 1rem
}

.content h2::after {
	content: '';
	display: block;
	width: 40px;
	height: 3px;
	background: var(--link-color);
	margin-top: .5rem;
	border-radius: 2px;
	opacity: .7
}

table {
	width: 100%;
	border-collapse: separate;
	border-spacing: 0;
	border-radius: var(--border-radius-base);
	overflow: hidden;
	margin: 2rem 0;
	box-shadow: var(--box-shadow);
	border: 1px solid var(--border-color)
}

th {
	background: var(--background-color-hero);
	color: #fff;
	padding: 1rem;
	font-weight: 600;
	text-align: left
}

td {
	padding: .8rem 1rem;
	border-bottom: 1px solid var(--border-color)
}

tr:last-child td {
	border-bottom: none
}

tr:nth-child(even) {
	background-color: rgba(125, 125, 125, 3%)
}

.pagination {
	display: flex;
	justify-content: center;
	gap: .5rem;
	margin-top: 3rem
}

.pagination .page-item a {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 40px;
	border-radius: 50%;
	background: var(--card-bg);
	border: 1px solid var(--border-color);
	color: var(--text-color);
	text-decoration: none;
	font-weight: 600;
	transition: all .2s ease
}

.pagination .page-item.active a,
.pagination .page-item a:hover {
	background: var(--link-color);
	color: #fff;
	border-color: var(--link-color);
	transform: translateY(-2px);
	box-shadow: 0 4px 10px rgba(255, 123, 16, .3)
}

footer {
	margin-top: 4rem;
	border-top: 1px solid var(--border-color);
	padding-top: 3rem
}

.recent-articles-section {
	background: 0 0 !important;
	padding-top: 1rem !important;
	padding-bottom: 1rem !important
}

.recent-article-card {
	background: 0 0 !important;
	box-shadow: none !important;
	border: none !important;
	padding: 0 !important
}

.recent-article-card:hover {
	transform: none !important;
	box-shadow: none !important;
	background: 0 0 !important
}

.recent-article-title {
	color: var(--heading-color) !important;
	margin-bottom: .2rem !important
}

.recent-article-card:hover .recent-article-title {
	color: var(--link-color) !important
}

.recent-article-thumbnail {
	border-radius: var(--border-radius-base) !important;
	box-shadow: var(--box-shadow) !important
}

.recent-article-card:hover .recent-article-thumbnail img {
	transform: scale(1.05);
	transition: transform .3s ease
}

.meta {
	font-family: var(--font-body) !important;
	font-size: .85rem !important;
	text-transform: uppercase !important;
	letter-spacing: 1px !important;
	color: #6c757d !important;
	font-weight: 600 !important;
	display: flex !important;
	align-items: center !important;
	flex-wrap: wrap !important;
	gap: 0 !important;
	margin-bottom: 1.5rem !important
}

.meta a,
.meta time,
.meta span {
	color: inherit !important;
	text-decoration: none !important
}

.meta a:hover {
	color: var(--heading-color) !important
}

.meta-separator {
	color: #ccc !important;
	padding: 0 10px !important;
	font-weight: 400 !important
}

.meta .reading-time svg {
	opacity: .7;
	margin-right: 4px !important;
	vertical-align: -2px !important
}

.meta .breadcrumb-nav {
	display: inline-block !important
}

.meta .breadcrumb {
	display: inline-block !important;
	margin: 0 !important;
	padding: 0 !important
}

@media(prefers-color-scheme:dark) {
	.meta {
		color: #a0a0a0 !important
	}

	.meta a:hover {
		color: #fff !important
	}

	.meta-separator {
		color: #666 !important
	}
}

.force-dark .meta {
	color: #a0a0a0 !important
}

.force-dark .meta a:hover {
	color: #fff !important
}

.force-dark .meta-separator {
	color: #666 !important
}

.featured-article-container {
	width: 100%;
	margin: 1.5rem 0;
	padding-left: 4rem;
	padding-right: 4rem;
	max-width: 1800px;
	margin-left: auto;
	margin-right: auto
}

.featured-article-container .article-card-featured {
	width: 100%;
	min-height: 500px
}

.featured-article-container .article-card-featured .article-card-image {
	height: 400px
}

.articles-grid {
	display: grid;
	grid-template-columns: repeat(6, 1fr);
	gap: 1rem;
	margin: 1.5rem 0;
	width: 100%;
	padding-left: 4rem;
	padding-right: 4rem;
	max-width: 1800px;
	margin-left: auto;
	margin-right: auto
}

.articles-grid>.article-card {
	grid-column: span 2
}

.articles-grid>.article-card:last-child:nth-child(3n+1) {
	grid-column: 1/-1
}

.articles-grid>.article-card:nth-last-child(2):nth-child(3n+1) {
	grid-column: span 3
}

.articles-grid>.article-card:last-child:nth-child(3n+2) {
	grid-column: span 3
}

.banner-band+.articles-grid {
	margin-top: 2rem
}

.banner-band {
	width: 100%;
	margin: 0
}

.article-card {
	background-color: var(--background-color-secondary);
	border-radius: var(--border-radius-base);
	overflow: hidden;
	box-shadow: 0 4px 6px rgba(0, 0, 0, .1);
	transition: transform .3s ease, box-shadow .3s ease, outline .2s ease;
	display: flex;
	flex-direction: column;
	position: relative;
	cursor: pointer;
	outline: 2px solid transparent;
	outline-offset: 4px;
	min-height: 480px
}

.article-card:focus {
	outline: 2px solid var(--link-color, #007bff);
	outline-offset: 4px
}

.article-card:focus:not(:focus-visible) {
	outline: none
}

.article-card:focus-visible {
	outline: 3px solid var(--link-color, #007bff);
	outline-offset: 4px;
	box-shadow: 0 0 0 6px rgba(0, 123, 255, .1)
}

.article-card-content a:focus {
	outline: 2px solid var(--link-color, #007bff);
	outline-offset: 2px;
	border-radius: 2px
}

.article-card-featured {
	grid-column: 1/-1;
	grid-row: span 1;
	min-height: 400px
}

.article-card-featured .article-card-image {
	height: 25rem !important
}

.article-card-featured .article-card-title {
	font-size: 2.2rem;
	line-height: 1.25;
	font-weight: 700;
	min-height: auto
}

.article-card-featured .article-card-description,
.article-card-featured .article-card-summary {
	line-height: 1.6;
	margin-bottom: 1rem;
	display: -webkit-box;
	-webkit-line-clamp: 4;
	line-clamp: 4;
	-webkit-box-orient: vertical;
	overflow: hidden
}

.article-card:hover {
	transform: translateY(-4px);
	box-shadow: 0 8px 12px rgba(0, 0, 0, .15)
}

.article-card-image {
	width: 100%;
	height: 280px;
	overflow: hidden;
	position: relative;
	flex-shrink: 0
}

.article-card-image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform .3s ease
}

.article-card:hover .article-card-image img {
	transform: scale(1.05)
}

.article-card-image a {
	display: block;
	width: 100%;
	height: 100%;
	text-decoration: none
}

.article-card-content {
	padding: 1.5rem;
	flex: 1;
	display: flex;
	flex-direction: column;
	overflow: hidden
}

.article-card-title {
	font-size: 1.1rem;
	margin-bottom: .75rem;
	line-height: 1.35;
	font-weight: 600;
	min-height: 2.8rem;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
	text-overflow: ellipsis
}

.article-card-title a {
	color: var(--heading-color);
	text-decoration: none;
	display: block
}

.article-card-title a:hover {
	color: var(--link-color)
}

.article-card-meta {
	font-size: .875rem;
	color: var(--primary-color);
	opacity: .7;
	margin-bottom: 1rem;
	display: flex;
	flex-wrap: wrap;
	gap: .5rem;
	align-items: baseline;
	line-height: 1.5
}

.article-card-meta time,
.article-card-meta .author,
.article-card-meta .category-link {
	display: inline-block
}

.article-card-meta .separator {
	margin: 0 .25rem;
	color: var(--primary-color);
	opacity: .5
}

.article-card-meta .category-link a {
	color: var(--link-color);
	text-decoration: none
}

.article-card-meta .category-link a:hover {
	text-decoration: underline
}

.article-card-description {
	margin-bottom: .75rem;
	color: var(--heading-color);
	text-align: justify
}

.article-card-summary {
	color: var(--primary-color);
	font-size: .9rem;
	line-height: 1.5;
	margin-bottom: 0;
	text-align: justify
}

.article-summary {
	color: var(--primary-color);
	font-size: .9rem;
	line-height: 1.5;
	margin-bottom: 0
}

.article-summary p {
	margin: 0
}

.articles .pub-section:not(.pub-section-band) {
	padding-left: 2rem;
	padding-right: 2rem
}

@media(max-width:640px) {
	.articles .pub-section:not(.pub-section-band) {
		padding-left: 1rem;
		padding-right: 1rem
	}
}

@media(min-width:1920px) {

	.articles-grid,
	.featured-article-container {
		padding-left: 6rem;
		padding-right: 6rem;
		max-width: 1800px
	}
}

@media(min-width:1400px) and (max-width:1919px) {

	.articles-grid,
	.featured-article-container {
		padding-left: 4rem;
		padding-right: 4rem
	}
}

@media(min-width:1024px) and (max-width:1399px) {

	.articles-grid,
	.featured-article-container {
		padding-left: 8rem;
		padding-right: 8rem
	}
}

@media(min-width:768px) and (max-width:1023px) {

	.articles-grid,
	.featured-article-container {
		padding-left: 2rem;
		padding-right: 2rem;
		gap: 1.5rem
	}

	.article-card-featured {
		grid-column: 1/-1
	}
}

@media(max-width:767px) {

	.articles-grid,
	.featured-article-container {
		grid-template-columns: 1fr;
		gap: 1.2rem;
		padding-left: 1rem;
		padding-right: 1rem
	}

	.article-card {
		min-height: 440px
	}

	.article-card-image {
		height: 240px
	}

	.article-card-featured .article-card-image {
		height: 200px
	}

	.article-card-featured .article-card-title {
		font-size: 1.8rem
	}

	.featured-article-container {
		padding-left: 0;
		padding-right: 0
	}

	.featured-article-container .article-card-featured {
		min-height: auto;
		border-radius: 0
	}

	.featured-article-container .article-card-featured .article-card-image {
		height: 250px
	}

	.featured-article-container .article-card-featured .article-card-content {
		padding: 1rem;
		overflow: visible
	}
}

.glitch-wrap {
	position: relative;
	display: inline-block;
	isolation: isolate;
	transition: transform .3s ease
}

.glitch-wrap>img {
	display: block;
	position: relative;
	z-index: 1
}

.article-card-image .glitch-wrap {
	display: block;
	width: 100%;
	height: 100%
}

.article-card:hover .article-card-image .glitch-wrap {
	transform: scale(1.05)
}

.article-card:hover .article-card-image .glitch-wrap>img {
	transform: none
}

.glitch-wrap::before,
.glitch-wrap::after {
	content: "";
	position: absolute;
	inset: 0;
	z-index: 2;
	background-image: var(--glitch-src);
	background-repeat: no-repeat;
	pointer-events: none;
	opacity: 0
}

.glitch-wrap[data-glitch-mode=cover]::before,
.glitch-wrap[data-glitch-mode=cover]::after {
	background-size: cover;
	background-position: 50%
}

.glitch-wrap[data-glitch-mode=contain]::before,
.glitch-wrap[data-glitch-mode=contain]::after {
	background-size: contain;
	background-position: 50%
}

.glitch-wrap.is-glitching::before {
	opacity: .7;
	mix-blend-mode: screen;
	animation: korben-glitch-a 520ms steps(2, end);
	transform: translate3d(2px, 0, 0);
	filter: hue-rotate(20deg)saturate(1.2)contrast(1.05)
}

.glitch-wrap.is-glitching::after {
	opacity: .65;
	mix-blend-mode: lighten;
	animation: korben-glitch-b 520ms steps(2, end);
	transform: translate3d(-2px, 0, 0);
	filter: hue-rotate(-20deg)saturate(1.2)contrast(1.05)
}

@keyframes korben-glitch-a {
	0% {
		clip-path: inset(0 0 85% 0)
	}

	20% {
		clip-path: inset(15% 0 55% 0)
	}

	40% {
		clip-path: inset(45% 0 35% 0)
	}

	60% {
		clip-path: inset(10% 0 70% 0)
	}

	80% {
		clip-path: inset(65% 0 10% 0)
	}

	100% {
		clip-path: inset(0 0 0 0)
	}
}

@keyframes korben-glitch-b {
	0% {
		clip-path: inset(80% 0 0 0)
	}

	25% {
		clip-path: inset(50% 0 25% 0)
	}

	50% {
		clip-path: inset(25% 0 55% 0)
	}

	75% {
		clip-path: inset(5% 0 75% 0)
	}

	100% {
		clip-path: inset(0 0 0 0)
	}
}

.patreon-card {
	background: linear-gradient(135deg, #ff424d 0%, #ff6b73 100%);
	border: none;
	position: relative;
	overflow: hidden;
	min-height: 480px;
	height: auto;
	border-radius: var(--border-radius-base);
	display: flex;
	flex-direction: column;
	box-shadow: 0 4px 6px rgba(0, 0, 0, .1)
}

.patreon-card::before {
	content: '';
	position: absolute;
	top: -50%;
	right: -50%;
	width: 200%;
	height: 200%;
	background: radial-gradient(circle, rgba(255, 255, 255, .1) 0%, transparent 70%);
	animation: shimmer 3s ease-in-out infinite
}

@keyframes shimmer {

	0%,
	100% {
		transform: translate(-50%, -50%)scale(1);
		opacity: 0
	}

	50% {
		transform: translate(-50%, -50%)scale(1.2);
		opacity: 1
	}
}

.patreon-card .article-card-link {
	color: #fff;
	text-decoration: none
}

.patreon-card .article-card-image {
	position: relative;
	background: rgba(0, 0, 0, .1);
	height: 280px;
	flex-shrink: 0
}

.patreon-card .article-card-image img {
	object-fit: cover;
	width: 100%;
	height: 100%
}

.patreon-card .article-card-content {
	background: 0 0;
	color: #fff !important;
	position: relative;
	z-index: 1;
	padding: 1.5rem;
	display: flex;
	flex-direction: column;
	justify-content: flex-start;
	flex: 1;
	gap: 1rem
}

.patreon-card .article-card-title {
	color: #fff !important;
	font-weight: 700;
	text-shadow: 0 2px 4px rgba(0, 0, 0, .2);
	font-size: 1.3rem;
	line-height: 1.3;
	margin: 0
}

.patreon-card .article-card-excerpt {
	color: rgba(255, 255, 255, .95) !important;
	font-size: 1rem;
	line-height: 1.5;
	margin: .5rem 0;
	text-align: justify
}

.patreon-card .article-card-cta {
	display: inline-flex;
	align-items: center;
	align-self: center;
	background: rgba(255, 255, 255, .2);
	color: #fff;
	padding: .75rem 1.5rem;
	border-radius: 25px;
	font-weight: 600;
	font-size: 1.05rem;
	transition: all .3s ease;
	backdrop-filter: blur(10px);
	border: 1px solid rgba(255, 255, 255, .3);
	gap: .5rem;
	text-decoration: none
}

.patreon-card:hover .article-card-cta {
	background: rgba(255, 255, 255, .3);
	transform: scale(1.05);
	gap: .75rem
}

.patreon-card:hover {
	transform: translateY(-8px);
	box-shadow: 0 12px 24px rgba(255, 66, 77, .3)
}

.patreon-card:focus-within {
	outline-color: #ff424d
}

@media screen and (max-width:768px) {
	.patreon-card {
		min-height: 440px
	}

	.patreon-card .article-card-image {
		height: 240px
	}

	.patreon-card .article-card-content {
		padding: 1.25rem
	}

	.patreon-card .article-card-title {
		font-size: 1.2rem
	}

	.patreon-card .article-card-excerpt {
		font-size: .95rem
	}

	.patreon-card .article-card-cta {
		font-size: 1rem;
		padding: .65rem 1.25rem
	}
}

@media screen and (max-width:600px) {
	.patreon-card {
		min-height: 440px
	}

	.patreon-card .article-card-image {
		height: 240px
	}

	.patreon-card .article-card-content {
		padding: 1rem;
		gap: .75rem
	}

	.patreon-card .article-card-title {
		font-size: 1.1rem
	}

	.patreon-card .article-card-excerpt {
		font-size: .9rem;
		line-height: 1.4
	}

	.patreon-card .article-card-cta {
		font-size: .95rem;
		padding: .6rem 1.1rem
	}
}

@media screen and (max-width:480px) {
	.patreon-card {
		min-height: 440px
	}

	.patreon-card .article-card-image {
		height: 240px
	}

	.patreon-card .article-card-content {
		padding: .9rem;
		gap: .6rem
	}

	.patreon-card .article-card-title {
		font-size: 1.05rem
	}

	.patreon-card .article-card-excerpt {
		font-size: .85rem;
		line-height: 1.35;
		margin: .3rem 0
	}

	.patreon-card .article-card-cta {
		font-size: .9rem;
		padding: .5rem 1rem
	}
}

.twitch-card {
	background: linear-gradient(135deg, #9146ff 0%, #6441a5 100%);
	border: none;
	position: relative;
	overflow: hidden;
	box-shadow: 0 4px 6px rgba(0, 0, 0, .1)
}

.twitch-card::before {
	content: '';
	position: absolute;
	top: -50%;
	right: -50%;
	width: 200%;
	height: 200%;
	background: radial-gradient(circle, rgba(255, 255, 255, .1) 0%, transparent 70%);
	animation: twitch-shimmer 10s ease-in-out infinite
}

@keyframes twitch-shimmer {

	0%,
	100% {
		transform: rotate(0)scale(1);
		opacity: .3
	}

	50% {
		transform: rotate(180deg)scale(1.1);
		opacity: .6
	}
}

.twitch-card .article-card-link {
	position: relative;
	z-index: 1;
	text-decoration: none !important
}

.twitch-card .article-card-link:hover {
	text-decoration: none !important
}

.twitch-card .article-card-image {
	background: rgba(255, 255, 255, .15);
	display: flex;
	align-items: center;
	justify-content: center;
	height: 280px;
	flex-shrink: 0
}

.twitch-card .twitch-logo {
	margin-bottom: 0 !important;
	transition: transform .3s ease;
	filter: drop-shadow(0 4px 8px rgba(0, 0, 0, .2))
}

.twitch-card:hover .twitch-logo {
	transform: scale(1.1)rotate(-5deg)
}

.twitch-card .article-card-content {
	background: 0 0;
	color: #fff
}

.twitch-card .article-card-title {
	color: #fff;
	font-size: 1.4rem;
	font-weight: 700;
	margin-bottom: 0;
	text-shadow: 0 2px 4px rgba(0, 0, 0, .1)
}

.twitch-card .article-card-excerpt {
	color: rgba(255, 255, 255, .95);
	line-height: 1.6;
	margin-bottom: 1.2rem;
	text-shadow: 0 1px 2px rgba(0, 0, 0, .1)
}

.twitch-card .article-card-excerpt a {
	text-decoration: none !important;
	color: inherit
}

.twitch-card .article-card-excerpt a:hover {
	text-decoration: none !important
}

.twitch-card .article-card-cta {
	display: inline-flex;
	align-items: center;
	align-self: center;
	background: rgba(255, 255, 255, .2);
	color: #fff;
	padding: .75rem 1.5rem;
	border-radius: 25px;
	font-weight: 600;
	font-size: 1.05rem;
	transition: all .3s ease;
	backdrop-filter: blur(10px);
	border: 1px solid rgba(255, 255, 255, .3);
	gap: .5rem;
	text-decoration: none
}

.twitch-card:hover .article-card-cta {
	background: rgba(255, 255, 255, .3);
	transform: scale(1.05);
	gap: .75rem
}

@media(max-width:768px) {
	.twitch-card .article-card-image {
		height: 240px
	}

	.twitch-card .article-card-title {
		font-size: 1.2rem
	}

	.twitch-card .article-card-cta {
		font-size: 1rem;
		padding: .65rem 1.25rem
	}
}

@media(max-width:480px) {
	.twitch-card .article-card-image {
		height: 240px
	}

	.twitch-card .article-card-title {
		font-size: 1.1rem
	}

	.twitch-card .article-card-excerpt {
		font-size: .9rem
	}

	.twitch-card .article-card-cta {
		font-size: .9rem;
		padding: .5rem 1rem
	}
}

@media(prefers-color-scheme:dark) {
	.twitch-card {
		background: linear-gradient(135deg, #7c3fc7 0%, #5528a3 100%)
	}
}

.edito-card {
	background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
	border: none;
	position: relative;
	overflow: hidden;
	min-height: 480px;
	height: auto;
	border-radius: var(--border-radius-base);
	display: flex;
	flex-direction: column;
	box-shadow: 0 4px 6px rgba(0, 0, 0, .1)
}

.edito-card::before {
	content: '';
	position: absolute;
	top: -50%;
	right: -50%;
	width: 200%;
	height: 200%;
	background: radial-gradient(circle, rgba(255, 255, 255, .1) 0%, transparent 70%);
	animation: shimmer 3s ease-in-out infinite
}

.edito-card .article-card-link {
	color: #fff;
	text-decoration: none
}

.edito-card .article-card-image {
	position: relative;
	background: rgba(0, 0, 0, .1);
	height: 280px;
	flex-shrink: 0;
	display: flex;
	align-items: center;
	justify-content: center
}

.edito-card .article-card-image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	margin: 0
}

.edito-card .edito-icon {
	width: auto;
	height: 150px;
	max-width: 80%;
	filter: drop-shadow(0 4px 8px rgba(0, 0, 0, .2));
	color: #fff
}

.edito-card .article-card-content {
	background: 0 0;
	color: #fff !important;
	position: relative;
	z-index: 1;
	padding: 1.5rem;
	display: flex;
	flex-direction: column;
	justify-content: flex-start;
	flex: 1;
	gap: 1rem
}

.edito-card .article-card-title {
	color: #fff !important;
	font-weight: 700;
	text-shadow: 0 2px 4px rgba(0, 0, 0, .2);
	font-size: 1.3rem;
	line-height: 1.3;
	margin: 0;
	margin-bottom: 0 !important
}

.edito-card .article-card-excerpt {
	color: rgba(255, 255, 255, .95) !important;
	font-size: 1rem;
	line-height: 1.5;
	margin: .5rem 0;
	text-align: justify
}

.edito-card .article-card-cta {
	display: inline-flex;
	align-items: center;
	align-self: center;
	background: rgba(255, 255, 255, .2);
	color: #fff;
	padding: .75rem 1.5rem;
	border-radius: 25px;
	font-weight: 600;
	font-size: 1.05rem;
	transition: all .3s ease;
	backdrop-filter: blur(10px);
	border: 1px solid rgba(255, 255, 255, .3);
	gap: .5rem;
	text-decoration: none
}

.edito-card:hover .article-card-cta {
	background: rgba(255, 255, 255, .3);
	transform: scale(1.05);
	gap: .75rem
}

.edito-card:hover {
	transform: translateY(-8px);
	box-shadow: 0 12px 24px rgba(102, 126, 234, .3)
}

.edito-card:focus-within {
	outline-color: #667eea
}

@media screen and (max-width:768px) {
	.edito-card {
		min-height: 440px
	}

	.edito-card .article-card-image {
		height: 240px
	}

	.edito-card .edito-icon {
		height: 120px
	}

	.edito-card .article-card-content {
		padding: 1.25rem
	}

	.edito-card .article-card-title {
		font-size: 1.2rem
	}

	.edito-card .article-card-excerpt {
		font-size: .95rem
	}

	.edito-card .article-card-cta {
		font-size: 1rem;
		padding: .65rem 1.25rem
	}
}

@media screen and (max-width:600px) {
	.edito-card {
		min-height: 440px
	}

	.edito-card .article-card-image {
		height: 240px
	}

	.edito-card .article-card-content {
		padding: 1rem;
		gap: .75rem
	}

	.edito-card .article-card-title {
		font-size: 1.1rem
	}

	.edito-card .article-card-excerpt {
		font-size: .9rem;
		line-height: 1.4
	}

	.edito-card .article-card-cta {
		font-size: .95rem;
		padding: .6rem 1.1rem
	}
}

@media screen and (max-width:480px) {
	.edito-card {
		min-height: 440px
	}

	.edito-card .article-card-image {
		height: 240px
	}

	.edito-card .edito-icon {
		height: 100px
	}

	.edito-card .article-card-content {
		padding: .9rem;
		gap: .6rem
	}

	.edito-card .article-card-title {
		font-size: 1.05rem
	}

	.edito-card .article-card-excerpt {
		font-size: .85rem;
		line-height: 1.35;
		margin: .3rem 0
	}

	.edito-card .article-card-cta {
		font-size: .9rem;
		padding: .5rem 1rem
	}
}

.matos-card {
	background: linear-gradient(135deg, #f093fb 0%, #f5576c 100%);
	border: none;
	position: relative;
	overflow: hidden;
	min-height: 480px;
	height: auto;
	border-radius: var(--border-radius-base);
	display: flex;
	flex-direction: column;
	box-shadow: 0 4px 6px rgba(0, 0, 0, .1)
}

.matos-card::before {
	content: '';
	position: absolute;
	top: -50%;
	right: -50%;
	width: 200%;
	height: 200%;
	background: radial-gradient(circle, rgba(255, 255, 255, .1) 0%, transparent 70%);
	animation: shimmer 3s ease-in-out infinite
}

.matos-card .article-card-link {
	color: #fff;
	text-decoration: none
}

.matos-card .article-card-image {
	position: relative;
	background: rgba(0, 0, 0, .1);
	height: 280px;
	flex-shrink: 0;
	display: flex;
	align-items: center;
	justify-content: center
}

.matos-card .article-card-image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	margin: 0
}

.matos-card .matos-icon {
	width: auto;
	height: 150px;
	max-width: 80%;
	filter: drop-shadow(0 4px 8px rgba(0, 0, 0, .2));
	color: #fff
}

.matos-card .article-card-content {
	background: 0 0;
	color: #fff !important;
	position: relative;
	z-index: 1;
	padding: 1.5rem;
	display: flex;
	flex-direction: column;
	justify-content: flex-start;
	flex: 1;
	gap: 1rem
}

.matos-card .article-card-title {
	color: #fff !important;
	font-weight: 700;
	text-shadow: 0 2px 4px rgba(0, 0, 0, .2);
	font-size: 1.3rem;
	line-height: 1.3;
	margin: 0;
	margin-bottom: 0 !important
}

.matos-card .article-card-excerpt {
	color: rgba(255, 255, 255, .95) !important;
	font-size: 1rem;
	line-height: 1.5;
	margin: .5rem 0;
	text-align: justify
}

.matos-card .article-card-cta {
	display: inline-flex;
	align-items: center;
	align-self: center;
	background: rgba(255, 255, 255, .2);
	color: #fff;
	padding: .75rem 1.5rem;
	border-radius: 25px;
	font-weight: 600;
	font-size: 1.05rem;
	transition: all .3s ease;
	backdrop-filter: blur(10px);
	border: 1px solid rgba(255, 255, 255, .3);
	gap: .5rem;
	text-decoration: none
}

.matos-card:hover .article-card-cta {
	background: rgba(255, 255, 255, .3);
	transform: scale(1.05);
	gap: .75rem
}

.matos-card:hover {
	transform: translateY(-8px);
	box-shadow: 0 12px 24px rgba(240, 147, 251, .3)
}

.matos-card:focus-within {
	outline-color: #f093fb
}

@media screen and (max-width:768px) {
	.matos-card {
		min-height: 440px
	}

	.matos-card .article-card-image {
		height: 240px
	}

	.matos-card .matos-icon {
		height: 120px
	}

	.matos-card .article-card-content {
		padding: 1.25rem
	}

	.matos-card .article-card-title {
		font-size: 1.2rem
	}

	.matos-card .article-card-excerpt {
		font-size: .95rem
	}

	.matos-card .article-card-cta {
		font-size: 1rem;
		padding: .65rem 1.25rem
	}
}

@media screen and (max-width:600px) {
	.matos-card {
		min-height: 440px
	}

	.matos-card .article-card-image {
		height: 240px
	}

	.matos-card .article-card-content {
		padding: 1rem;
		gap: .75rem
	}

	.matos-card .article-card-title {
		font-size: 1.1rem
	}

	.matos-card .article-card-excerpt {
		font-size: .9rem;
		line-height: 1.4
	}

	.matos-card .article-card-cta {
		font-size: .95rem;
		padding: .6rem 1.1rem
	}
}

@media screen and (max-width:480px) {
	.matos-card {
		min-height: 440px
	}

	.matos-card .article-card-image {
		height: 240px
	}

	.matos-card .matos-icon {
		height: 100px
	}

	.matos-card .article-card-content {
		padding: .9rem;
		gap: .6rem
	}

	.matos-card .article-card-title {
		font-size: 1.05rem
	}

	.matos-card .article-card-excerpt {
		font-size: .85rem;
		line-height: 1.35;
		margin: .3rem 0
	}

	.matos-card .article-card-cta {
		font-size: .9rem;
		padding: .5rem 1rem
	}
}

.patreon-banner-sidebar {
	margin: 2rem 1rem;
	border-radius: var(--border-radius-base, 12px);
	overflow: hidden;
	background: linear-gradient(135deg, #ff424d 0%, #ff6b73 100%);
	box-shadow: 0 4px 12px rgba(255, 66, 77, .2);
	transition: transform .3s ease, box-shadow .3s ease;
	position: relative
}

.patreon-banner-sidebar::before {
	content: '';
	position: absolute;
	top: -50%;
	right: -50%;
	width: 200%;
	height: 200%;
	background: radial-gradient(circle, rgba(255, 255, 255, .1) 0%, transparent 70%);
	animation: shimmer 3s ease-in-out infinite;
	pointer-events: none
}

.patreon-banner-sidebar:hover {
	transform: translateY(-3px);
	box-shadow: 0 8px 20px rgba(255, 66, 77, .3)
}

.patreon-banner-link {
	display: block;
	text-decoration: none !important;
	color: #fff;
	cursor: pointer
}

.patreon-banner-link:hover {
	text-decoration: none !important
}

.patreon-banner-content {
	padding: 2rem;
	text-align: center;
	position: relative;
	z-index: 1
}

.patreon-banner-image {
	width: 120px;
	height: 120px;
	border-radius: 50%;
	object-fit: cover;
	margin: 0 auto 1.25rem;
	display: block;
	border: 4px solid rgba(255, 255, 255, .3);
	box-shadow: 0 4px 12px rgba(0, 0, 0, .2)
}

.patreon-banner-title {
	font-size: 1.3rem;
	font-weight: 700;
	margin: 0 0 .75rem;
	color: #fff;
	text-shadow: 0 2px 4px rgba(0, 0, 0, .2);
	line-height: 1.3
}

.patreon-banner-text {
	font-size: 1.05rem;
	margin: 0 0 1.25rem;
	color: rgba(255, 255, 255, .95);
	line-height: 1.5
}

.patreon-banner-cta {
	display: inline-flex;
	align-items: center;
	background: rgba(255, 255, 255, .2);
	color: #fff;
	padding: .75rem 1.5rem;
	border-radius: 25px;
	font-weight: 600;
	font-size: 1.05rem;
	transition: all .3s ease;
	backdrop-filter: blur(10px);
	border: 1px solid rgba(255, 255, 255, .3);
	gap: .5rem;
	pointer-events: none
}

.patreon-banner-link:hover .patreon-banner-cta {
	background: rgba(255, 255, 255, .3);
	transform: scale(1.05);
	gap: .75rem
}

@media(prefers-color-scheme:dark) {
	.patreon-banner-sidebar {
		box-shadow: 0 4px 12px rgba(255, 66, 77, .3)
	}
}

.patreon-support-banner {
	margin: 3rem 0;
	padding: 2rem;
	background: linear-gradient(135deg, #ff424d 0%, #ff6b6b 100%);
	border-radius: 16px;
	box-shadow: 0 10px 30px rgba(255, 66, 77, .2);
	position: relative;
	overflow: hidden;
	animation: fadeInUp .6s ease-out
}

.patreon-support-banner::before {
	content: '';
	position: absolute;
	top: -50%;
	right: -10%;
	width: 300px;
	height: 300px;
	background: radial-gradient(circle, rgba(255, 255, 255, .1) 0%, transparent 70%);
	border-radius: 50%;
	pointer-events: none
}

.patreon-support-content {
	position: relative;
	z-index: 1;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 2rem;
	flex-wrap: wrap
}

.patreon-support-text {
	display: flex;
	align-items: center;
	gap: 1.5rem;
	flex: 1;
	min-width: 280px
}

.patreon-support-avatar {
	width: 64px;
	height: 64px;
	border-radius: 50%;
	border: 3px solid #fff;
	flex-shrink: 0;
	box-shadow: 0 4px 12px rgba(0, 0, 0, .2);
	animation: pulse 3s ease-in-out infinite;
	align-self: center;
	margin-top: 3.5rem
}

.patreon-support-message {
	color: #fff;
	flex: 1
}

.patreon-support-message strong {
	font-weight: 600;
	display: block;
	margin-bottom: .5rem;
	font-size: 2rem;
	line-height: 1.2
}

.patreon-support-message p {
	margin: 0;
	font-size: 1rem;
	line-height: 1.5;
	opacity: .95;
	color: #fff
}

.patreon-support-cta {
	display: inline-flex;
	align-items: center;
	gap: .75rem;
	background: #fff;
	color: #ff424d;
	padding: 1rem 2rem;
	border-radius: 50px;
	text-decoration: none;
	font-weight: 600;
	font-size: 1.1rem;
	transition: all .3s ease;
	box-shadow: 0 4px 15px rgba(0, 0, 0, .1);
	white-space: nowrap
}

.patreon-support-cta:hover {
	transform: translateY(-2px);
	box-shadow: 0 6px 20px rgba(0, 0, 0, .15);
	gap: 1rem;
	background: #fff;
	color: #ff424d
}

.patreon-support-arrow {
	width: 20px;
	height: 20px;
	transition: transform .3s ease
}

.patreon-support-cta:hover .patreon-support-arrow {
	transform: translateX(3px)
}

@keyframes fadeInUp {
	from {
		opacity: 0;
		transform: translateY(20px)
	}

	to {
		opacity: 1;
		transform: translateY(0)
	}
}

@keyframes pulse {
	0% {
		transform: scale(1)
	}

	50% {
		transform: scale(1.05)
	}

	100% {
		transform: scale(1)
	}
}

@media(prefers-color-scheme:dark) {
	.patreon-support-banner {
		background: linear-gradient(135deg, #ff424d 0%, #ff5757 100%);
		box-shadow: 0 10px 30px rgba(255, 66, 77, .3)
	}

	.patreon-support-cta {
		background: rgba(255, 255, 255, .95)
	}

	.patreon-support-cta:hover {
		background: #fff
	}
}

@media(max-width:768px) {
	.patreon-support-banner {
		padding: 1.5rem;
		margin: 2rem 0
	}

	.patreon-support-content {
		flex-direction: column;
		text-align: center;
		gap: 1.5rem
	}

	.patreon-support-text {
		flex-direction: column;
		text-align: center;
		gap: 1rem
	}

	.patreon-support-message {
		font-size: 2rem
	}

	.patreon-support-message strong {
		font-size: 2rem
	}

	.patreon-support-cta {
		width: 100%;
		justify-content: center;
		padding: .875rem 1.5rem;
		font-size: 1rem
	}

	.patreon-support-avatar {
		width: 120px;
		height: 120px
	}
}

.reading-list-button {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 6px 12px;
	background: 0 0;
	border: 1px solid var(--color-border, #ddd);
	border-radius: 6px;
	color: var(--color-text, #333);
	font-size: 14px;
	font-family: inherit;
	cursor: pointer;
	transition: all .2s ease;
	white-space: nowrap
}

.reading-list-button:hover {
	background: var(--color-bg-hover, #f5f5f5);
	border-color: var(--color-primary, #e8415c);
	color: var(--color-primary, #e8415c);
	transform: translateY(-1px)
}

.reading-list-button:active {
	transform: translateY(0)
}

.reading-list-button:focus {
	outline: 2px solid var(--color-primary, #e8415c);
	outline-offset: 2px
}

.reading-list-icon {
	flex-shrink: 0;
	transition: opacity .2s ease;
	width: 20px;
	height: 20px
}

.reading-list-icon-outline {
	display: block
}

.reading-list-icon-filled {
	display: none
}

.reading-list-button.is-saved {
	background: var(--color-primary, #e8415c);
	border-color: var(--color-primary, #e8415c);
	color: #fff
}

.reading-list-button.is-saved .reading-list-icon-outline {
	display: none
}

.reading-list-button.is-saved .reading-list-icon-filled {
	display: block
}

.reading-list-button.is-saved:hover {
	background: var(--color-primary-dark, #d73851)
}

.reading-list-button.is-processing {
	opacity: .6;
	pointer-events: none
}

.reading-list-button.is-animating {
	animation: readingListPulse .3s ease
}

@keyframes readingListPulse {

	0%,
	100% {
		transform: scale(1)
	}

	50% {
		transform: scale(1.1)
	}
}

.reading-list-text-saved {
	display: none
}

.reading-list-button.is-saved .reading-list-text-save {
	display: none
}

.reading-list-button.is-saved .reading-list-text-saved {
	display: inline
}

.reading-list-button-wrapper {
	display: inline-flex;
	margin-left: auto
}

.reading-list-button-wrapper .reading-list-button {
	padding: 6px 8px;
	font-size: 0;
	min-width: auto;
	gap: 0
}

.reading-list-button-wrapper .reading-list-text {
	display: none
}

.reading-list-button-wrapper .reading-list-icon {
	margin: 0
}

.reading-list-button-container {
	display: inline-flex;
	margin-left: 8px;
	vertical-align: middle
}

@media(max-width:768px) {
	.reading-list-button {
		font-size: 0;
		padding: 8px
	}

	.reading-list-text {
		display: none
	}

	.reading-list-button-container .reading-list-button {
		padding: 8px
	}
}

.reading-list-page .articles-grid {
	padding-left: 0 !important;
	padding-right: 0 !important;
	margin-top: 20px
}

.reading-list-page {
	max-width: 1200px;
	margin: 0 auto;
	padding: 40px 20px;
	background: var(--background-color-sidebar, #f0f0f0);
	min-height: 100vh
}

.reading-list-header {
	text-align: center;
	margin-bottom: 40px;
	background: var(--background-color-hero, #556d8d);
	padding: 40px 20px;
	color: #fff
}

.reading-list-title {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 12px;
	font-size: 2rem;
	font-weight: 600;
	color: #fff;
	margin: 0 0 12px
}

.reading-list-title svg {
	color: #fff
}

.reading-list-description {
	font-size: 1rem;
	color: rgba(255, 255, 255, .9);
	max-width: 600px;
	margin: 0 auto
}

.reading-list-message {
	text-align: center;
	padding: 60px 20px;
	border-radius: 12px;
	background: var(--color-bg-alt, #f9f9f9)
}

.reading-list-message svg {
	color: var(--color-primary, #e8415c);
	margin-bottom: 20px
}

.reading-list-message h2 {
	font-size: 1.8rem;
	margin: 0 0 16px;
	color: var(--color-text, #333)
}

.reading-list-message p {
	font-size: 1.1rem;
	color: var(--color-text-light, #666);
	margin: 0 0 12px;
	max-width: 600px;
	margin-left: auto;
	margin-right: auto
}

.reading-list-loading {
	background: var(--color-bg-alt, #f9f9f9)
}

.spinner {
	display: inline-block;
	width: 40px;
	height: 40px;
	border: 4px solid var(--color-border, #ddd);
	border-top-color: var(--color-primary, #e8415c);
	border-radius: 50%;
	animation: spin .8s linear infinite;
	margin-bottom: 20px
}

@keyframes spin {
	to {
		transform: rotate(360deg)
	}
}

.reading-list-error svg {
	color: #f59e0b
}

.reading-list-cta {
	display: flex;
	gap: 16px;
	justify-content: center;
	flex-wrap: wrap;
	margin-top: 24px
}

.reading-list-toolbar {
	display: flex;
	align-items: center;
	gap: 20px;
	padding: 20px;
	background: var(--background-color-page, #FFFFFF);
	border-radius: 12px;
	margin-bottom: 30px;
	flex-wrap: wrap;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 8%)
}

.reading-list-stats {
	display: flex;
	gap: 20px;
	align-items: center
}

.stat {
	font-size: .95rem;
	color: var(--color-text-light, #666)
}

.stat strong {
	color: var(--color-text, #333);
	font-size: 1.2rem;
	font-weight: 700
}

.reading-list-filters {
	display: flex;
	gap: 8px;
	margin-left: auto
}

.filter-btn {
	padding: 8px 16px;
	background: #fff;
	border: 1px solid var(--color-border, #ddd);
	border-radius: 6px;
	color: var(--color-text, #333);
	font-size: .9rem;
	font-family: inherit;
	cursor: pointer;
	transition: all .2s ease
}

.filter-btn:hover {
	background: var(--color-bg-hover, #f5f5f5);
	border-color: var(--color-primary, #e8415c)
}

.filter-btn.active {
	background: var(--button-primary-background, #ff7b10);
	border-color: var(--button-primary-background, #ff7b10);
	color: #fff;
	box-shadow: 0 4px 12px rgba(255, 123, 16, .3)
}

.reading-list-sort {
	display: flex;
	align-items: center;
	gap: 8px;
	font-size: .9rem;
	color: var(--color-text-light, #666)
}

.reading-list-sort select {
	padding: 8px 12px;
	border: 1px solid var(--color-border, #ddd);
	border-radius: 6px;
	background: #fff;
	font-family: inherit;
	font-size: .9rem;
	cursor: pointer
}

.reading-list-actions {
	display: flex;
	gap: 8px
}

.reading-list-empty {
	text-align: center;
	padding: 80px 20px
}

.reading-list-empty svg {
	color: var(--color-border, #ddd);
	margin-bottom: 20px
}

.reading-list-empty h2 {
	font-size: 1.5rem;
	color: var(--color-text, #333);
	margin: 0 0 12px
}

.reading-list-empty p {
	font-size: 1rem;
	color: var(--color-text-light, #666);
	margin: 0 0 24px
}

.reading-list-empty svg[width="16"] {
	display: inline;
	margin: 0
}

.article-card-actions {
	display: flex;
	gap: 8px
}

.mark-read-btn .text-read {
	display: none
}

.mark-read-btn.is-read {
	background: var(--color-success, #28a745);
	border-color: var(--color-success, #28a745);
	color: #fff
}

.mark-read-btn.is-read .text-unread {
	display: none
}

.mark-read-btn.is-read .text-read {
	display: inline
}

.mark-read-btn.is-read:hover {
	background: var(--color-success-dark, #218838);
	border-color: var(--color-success-dark, #218838)
}

.reading-list-article-card[data-read-status=read] {
	opacity: .7
}

.reading-list-article-card[data-read-status=read]:hover {
	opacity: 1
}

.btn {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 12px 24px;
	border-radius: 8px;
	font-size: 1rem;
	font-weight: 600;
	font-family: inherit;
	text-decoration: none;
	cursor: pointer;
	transition: all .2s ease;
	border: none
}

.btn-primary {
	background: var(--color-primary, #e8415c);
	color: #fff
}

.btn-primary:hover {
	background: var(--color-primary-dark, #d73851);
	transform: translateY(-2px);
	box-shadow: 0 4px 12px rgba(232, 65, 92, .3)
}

.btn-secondary {
	background: 0 0;
	color: var(--color-primary, #e8415c);
	border: 2px solid var(--color-primary, #e8415c)
}

.btn-secondary:hover {
	background: var(--color-primary, #e8415c);
	color: #fff;
	transform: translateY(-2px)
}

.btn-small {
	padding: 8px 16px;
	font-size: .9rem;
	background: #fff;
	color: var(--color-text, #333);
	border: 1px solid var(--color-border, #ddd)
}

.btn-small:hover {
	background: var(--color-bg-hover, #f5f5f5);
	border-color: var(--color-primary, #e8415c);
	color: var(--color-primary, #e8415c)
}

.btn-danger {
	color: #dc3545
}

.btn-danger:hover {
	background: #dc3545;
	color: #fff;
	border-color: #dc3545
}

.btn.is-animating {
	animation: btnPulse .3s ease
}

@keyframes btnPulse {

	0%,
	100% {
		transform: scale(1)
	}

	50% {
		transform: scale(.95)
	}
}

@media(max-width:1024px) {}

@media(max-width:768px) {
	.reading-list-page {
		padding: 20px 16px
	}

	.reading-list-title {
		font-size: 2rem
	}

	.reading-list-toolbar {
		flex-direction: column;
		align-items: stretch
	}

	.reading-list-filters {
		margin-left: 0;
		width: 100%;
		justify-content: center
	}

	.reading-list-sort {
		width: 100%
	}

	.reading-list-sort select {
		flex: 1
	}

	.reading-list-actions {
		width: 100%
	}

	.reading-list-actions button {
		flex: 1
	}

	.reading-list-cta {
		flex-direction: column
	}

	.reading-list-cta .btn {
		width: 100%;
		justify-content: center
	}
}

@media(max-width:480px) {
	.reading-list-title {
		font-size: 1.5rem
	}

	.filter-btn {
		flex: 1;
		font-size: .85rem;
		padding: 6px 12px
	}

	.btn-small svg {
		display: none
	}
}

@media(prefers-color-scheme:dark) {
	body.dark-mode .reading-list-article-card {
		background: #1a1a1a;
		border-color: #333
	}

	body.dark-mode .reading-list-button {
		background: #1a1a1a;
		border-color: #333;
		color: #fff
	}

	body.dark-mode .reading-list-button:hover {
		background: #2a2a2a
	}

	body.dark-mode .reading-list-toolbar {
		background: #1a1a1a
	}

	body.dark-mode .filter-btn {
		background: #2a2a2a;
		border-color: #333;
		color: #fff
	}

	body.dark-mode .btn-small {
		background: #2a2a2a;
		border-color: #333;
		color: #fff
	}
}

.force-dark .reading-list-button {
	background: #1a1a1a;
	border-color: #333;
	color: #fff
}

.force-dark .reading-list-button:hover {
	background: #2a2a2a;
	border-color: var(--color-primary, #e8415c)
}

.force-dark .reading-list-button.is-saved {
	background: var(--color-primary, #e8415c);
	border-color: var(--color-primary, #e8415c);
	color: #fff
}

.code-block-wrapper {
	position: relative;
	margin: 0;
	border-radius: 8px;
	overflow: hidden
}

.code-block-wrapper pre {
	margin: 0;
	padding: 1rem !important;
	border: none !important;
	background: #1e1e1e !important;
	border-radius: 8px;
	overflow-x: auto
}

.code-block-wrapper pre code {
	padding: 0 !important;
	background: 0 0 !important;
	border: none !important;
	font-size: 14px;
	line-height: 1.6
}

.copy-code-button {
	position: absolute;
	top: 8px;
	right: 8px;
	padding: 6px 12px;
	background: rgba(0, 0, 0, .7);
	border: 1px solid rgba(255, 255, 255, .2);
	border-radius: 6px;
	color: #fff;
	font-size: 13px;
	font-family: -apple-system, BlinkMacSystemFont, segoe ui, Roboto, Oxygen, Ubuntu, Cantarell, sans-serif;
	cursor: pointer;
	display: flex;
	align-items: center;
	gap: 6px;
	transition: all .2s ease;
	opacity: 0;
	z-index: 10;
	line-height: 1
}

.code-block-wrapper:hover .copy-code-button {
	opacity: 1
}

.copy-code-button:hover {
	background: rgba(0, 0, 0, .85);
	border-color: rgba(255, 255, 255, .3);
	transform: scale(1.05)
}

.copy-code-button:active {
	transform: scale(.95)
}

.copy-code-button svg {
	width: 16px;
	height: 16px;
	flex-shrink: 0
}

.copy-code-button.copied {
	background: #22c55e;
	border-color: #16a34a
}

.copy-code-button .copy-text {
	font-weight: 500;
	white-space: nowrap
}

@media(max-width:768px) {
	.copy-code-button {
		opacity: .8;
		font-size: 12px;
		padding: 5px 10px;
		top: 6px;
		right: 6px
	}

	.copy-code-button .copy-text {
		display: none
	}

	.code-block-wrapper:hover .copy-code-button {
		opacity: 1
	}
}

.dark-mode .code-block-wrapper pre {
	background: #0d1117 !important
}

.dark-mode .copy-code-button {
	background: rgba(255, 255, 255, .1);
	border-color: rgba(255, 255, 255, .15);
	color: #fff
}

.dark-mode .copy-code-button:hover {
	background: rgba(255, 255, 255, .15);
	border-color: rgba(255, 255, 255, .25)
}

.dark-mode .copy-code-button.copied {
	background: #22c55e;
	border-color: #16a34a
}

body:not(.dark-mode) .code-block-wrapper pre {
	background: #f6f8fa !important;
	color: #24292f !important
}

.code-block-wrapper pre {
	padding: 1rem 80px 1rem 1rem !important
}

@media(max-width:768px) {
	.code-block-wrapper pre {
		padding: .75rem 50px .75rem .75rem !important
	}
}

@keyframes fadeIn {
	from {
		opacity: 0;
		transform: translateY(-5px)
	}

	to {
		opacity: 1;
		transform: translateY(0)
	}
}

.code-block-wrapper:hover .copy-code-button {
	animation: fadeIn .2s ease
}

.inline-code-wrapper {
	position: relative;
	display: inline-flex;
	align-items: center;
	gap: 4px;
	vertical-align: baseline
}

.inline-code-wrapper code {
	display: inline
}

.inline-copy-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 2px;
	background: 0 0;
	border: 1px solid transparent;
	border-radius: 4px;
	color: #6b7280;
	cursor: pointer;
	opacity: 0;
	transition: all .2s ease;
	vertical-align: middle;
	line-height: 1;
	flex-shrink: 0
}

.inline-code-wrapper:hover .inline-copy-icon {
	opacity: 1
}

.inline-copy-icon:hover {
	background: rgba(0, 0, 0, 5%);
	border-color: rgba(0, 0, 0, .1);
	color: #374151
}

.inline-copy-icon:active {
	transform: scale(.9)
}

.inline-copy-icon.copied {
	color: #22c55e;
	opacity: 1
}

.inline-copy-icon svg {
	width: 12px;
	height: 12px;
	display: block
}

.dark-mode .inline-copy-icon {
	color: #9ca3af
}

.dark-mode .inline-copy-icon:hover {
	background: rgba(255, 255, 255, .1);
	border-color: rgba(255, 255, 255, .15);
	color: #d1d5db
}

.dark-mode .inline-copy-icon.copied {
	color: #22c55e
}

@media(max-width:768px) {
	.inline-copy-icon {
		opacity: .6
	}

	.inline-code-wrapper:hover .inline-copy-icon {
		opacity: 1
	}
}

.meta .p-author.h-card {
	display: inline
}

.meta .p-author.h-card .p-name {
	display: inline
}

.meta .p-author.h-card::after {
	content: none
}

.meta .p-author a {
	color: var(--link-color);
	text-decoration: none;
	transition: color .3s ease
}

.meta .p-author a:hover {
	color: var(--button-primary-background);
	text-decoration: underline
}

.article-content .content img {
	display: block;
	margin-left: auto;
	margin-right: auto;
	max-width: 100%;
	height: auto
}

.article-content .content img[width] {
	width: auto !important;
	max-width: min(100%, var(--img-width))
}

.article-content .content img[width="712"] {
	--img-width: 712px
}

.article-content .content img[width="640"] {
	--img-width: 640px
}

.article-content .content img[width="800"] {
	--img-width: 800px
}

.article-content .content img[width="1024"] {
	--img-width: 1024px
}

.article-content .content img[width="1200"] {
	--img-width: 1200px
}

.article-content .content img.natural-width {
	max-width: 100%;
	width: auto !important
}

@media screen and (max-width:768px) {
	.article-content .content img {
		display: block !important;
		max-width: 100% !important;
		width: auto !important;
		height: auto !important;
		margin-left: auto !important;
		margin-right: auto !important;
		transform: none !important;
		position: relative !important;
		left: auto !important;
		right: auto !important
	}

	.article-content .content p,
	.article-content .content figure {
		text-align: justify
	}
}

.article-content .content figure img,
.article-content .content .wp-block-image img {
	max-width: 100%;
	width: auto !important;
	height: auto
}

@media screen and (min-width:1024px) {

	.article-content .content img,
	.article-content .content figure img,
	article .content img {
		max-width: 90% !important;
		width: auto !important;
		object-fit: contain
	}

	.article-content .content img[width]:not([width="1"]):not([width="2"]) {
		max-width: min(90%, 1200px) !important
	}

	.article-content .content>p:first-of-type img,
	.article-content .content>figure:first-of-type img {
		max-width: 100% !important;
		max-height: 70vh !important;
		margin-bottom: 2rem
	}
}

@media screen and (min-width:1440px) {

	.article-content .content img,
	article .content img {
		max-width: min(85%, 1000px) !important
	}

	.article-content .content img.wide,
	.article-content .content figure.wide img {
		max-width: min(100%, 1400px) !important
	}
}

@media screen and (min-width:1024px) {

	body .article-content .content img,
	body article .content img {
		max-width: min(90%, 1000px) !important;
		max-height: min(600px) !important;
		width: auto !important;
		height: auto !important
	}

	body .article-content .content img.full-width,
	body .article-content .content img[data-full-width],
	body article .content img.full-width,
	body article .content img[data-full-width] {
		max-width: 100% !important;
		width: 100% !important
	}
}

@media screen and (min-width:1024px) {
	.article-image {
		width: 100% !important;
		height: 300px !important
	}

	.article-image img {
		width: 100% !important;
		height: 100% !important;
		object-fit: cover !important;
		object-position: center !important
	}

	.article-card-featured .article-card-image {
		height: 400px !important
	}
}

@media screen and (min-width:1440px) {
	.article-image {
		height: 400px !important
	}

	.article-card-image {
		height: 320px !important
	}

	.article-card-featured .article-card-image {
		height: 450px !important
	}
}

@media screen and (min-width:1920px) {
	.article-image {
		height: 500px !important
	}

	.article-card-image {
		height: 350px !important
	}

	.article-card-featured .article-card-image {
		height: 500px !important
	}
}

.article-grid .article-card {
	overflow: hidden;
	background: var(--background-color-secondary, #fff);
	transition: transform .2s ease, box-shadow .2s ease;
	min-height: 480px;
	display: flex;
	flex-direction: column
}

.article-grid .article-card:hover {
	transform: translateY(-4px);
	box-shadow: 0 4px 12px rgba(0, 0, 0, .1)
}

.article-grid .article-image {
	width: 100% !important;
	height: 280px !important;
	margin: 0 !important;
	background-color: #f0f0f0;
	position: relative;
	overflow: hidden;
	flex-shrink: 0
}

.article-grid .article-image img,
.article-grid .article-image img[width="300"][height="200"] {
	width: 100% !important;
	height: 100% !important;
	object-fit: cover !important;
	object-position: center !important;
	position: absolute !important;
	top: 0 !important;
	left: 0 !important;
	transition: transform .3s ease
}

.article-grid .article-card:hover .article-image img {
	transform: scale(1.05)
}

.article-grid .article-content {
	padding: 1.25rem !important;
	background: var(--background-color-secondary, #fff) !important;
	position: relative !important;
	top: 0 !important;
	transform: none !important;
	left: 0 !important;
	margin: 0 !important;
	width: 100% !important;
	max-width: 100% !important;
	display: flex !important;
	flex-direction: column !important;
	flex: 1 !important
}

.article-grid .article-title {
	font-size: 1.5rem !important;
	margin-bottom: .75rem !important;
	line-height: 1.35 !important;
	font-weight: 600 !important;
	display: block !important;
	min-height: 2.8rem !important;
	word-wrap: break-word !important;
	overflow-wrap: break-word !important;
	hyphens: auto !important
}

.article-grid .article-title a {
	display: block !important;
	overflow: visible !important;
	text-overflow: unset !important;
	color: var(--heading-color);
	text-decoration: none
}

.article-grid .article-summary {
	color: var(--text-color-secondary, #666) !important;
	line-height: 1.5 !important;
	margin-bottom: 1rem !important;
	flex: 1 !important;
	display: -webkit-box !important;
	-webkit-line-clamp: 4 !important;
	line-clamp: 4 !important;
	-webkit-box-orient: vertical !important;
	overflow: hidden !important;
	text-overflow: ellipsis !important;
	font-size: .9rem !important
}

.article-grid .article-summary p {
	flex: 1 !important;
	margin: 0 !important
}

.article-grid .article-footer {
	margin-top: auto !important;
	align-self: flex-start !important
}

.article-card-title a {
	-webkit-line-clamp: unset !important;
	line-clamp: unset !important;
	overflow: visible !important;
	display: block !important;
	text-overflow: unset !important
}

.article-card {
	display: flex !important;
	flex-direction: column !important;
	height: 100% !important;
	min-height: 480px !important
}

.article-card-content {
	display: flex !important;
	flex-direction: column !important;
	flex: 1 !important;
	height: 100% !important
}

.article-card-meta {
	order: -1 !important;
	margin-bottom: .75rem !important
}

.article-card-title {
	order: -2 !important;
	margin-bottom: .5rem !important;
	min-height: 2.8rem !important;
	display: flex !important;
	align-items: flex-start !important
}

.article-card-featured .article-card-title {
	min-height: auto !important
}

.article-card-description,
.article-card-summary {
	flex: 1 !important;
	margin-top: 0 !important
}

@media screen and (max-width:479px) {
	.article-grid .article-card {
		min-height: 440px !important
	}

	.article-grid .article-image {
		height: 240px !important
	}

	.article-grid .article-title,
	.article-card-title {
		font-size: 1rem !important
	}

	.article-card-featured .article-card-title {
		font-size: 1.8rem !important
	}

	.article-card-title {
		min-height: 2.8rem !important
	}
}

@media screen and (min-width:480px) and (max-width:767px) {
	.article-grid .article-card {
		min-height: 440px !important
	}

	.article-grid .article-image {
		height: 240px !important
	}

	.article-grid .article-title,
	.article-card-title {
		font-size: 1.05rem !important
	}

	.article-card-featured .article-card-title {
		font-size: 1.9rem !important
	}

	.article-card-title {
		min-height: 2.8rem !important
	}
}

@media screen and (min-width:768px) and (max-width:1023px) {

	.article-grid .article-title,
	.article-card-title {
		font-size: 1.5rem !important
	}

	.article-card-featured .article-card-title {
		font-size: 2rem !important
	}

	.article-card-title {
		min-height: 2.8rem !important
	}
}

@media screen and (min-width:1024px) {
	.article-grid .article-card {
		min-height: 480px !important
	}

	.article-grid .article-image {
		height: 280px !important
	}

	.article-grid .article-title,
	.article-card-title {
		font-size: 1.5rem !important
	}

	.article-card-featured .article-card-title {
		font-size: 2.2rem !important;
		line-height: 1.25 !important
	}
}

img.lazyload,
img.lazyloading {
	opacity: 0;
	transition: opacity .3s ease-in-out
}

img.lazyloaded {
	opacity: 1
}

.blur-up {
	filter: blur(5px);
	transition: filter .3s
}

.blur-up.lazyloaded {
	filter: blur(0)
}

img[data-src] {
	display: block;
	min-height: 1px
}

.lazyload-wrapper {
	position: relative;
	overflow: hidden;
	background-color: #f0f0f0
}

.lazyload-wrapper::before {
	content: '';
	position: absolute;
	top: 0;
	left: -100%;
	width: 100%;
	height: 100%;
	background: linear-gradient(90deg, transparent, rgba(255, 255, 255, .4), transparent);
	animation: shimmer 1.5s infinite
}

.lazyload-wrapper.loaded::before {
	display: none
}

@keyframes shimmer {
	to {
		left: 100%
	}
}

.article-card-image img.lazyload,
.article-card-image img.lazyloading {
	background-color: #f5f5f5
}

.article-image img.lazyload,
.article-image img.lazyloading {
	background-color: #f5f5f5;
	min-height: 200px
}

@media(max-width:768px) {

	.article-image img.lazyload,
	.article-image img.lazyloading {
		min-height: 150px
	}
}

details.keypoints-cartouche {
	background: linear-gradient(135deg, rgba(26, 26, 46, .95) 0%, rgba(22, 33, 62, .95) 100%);
	border: 2px solid transparent;
	border-image: linear-gradient(45deg, #ff7b10, #ff9940, #ff00ff)1;
	border-radius: 12px;
	padding: .75rem 1.25rem;
	margin: 0 0 1.5rem;
	position: relative;
	overflow: hidden;
	box-shadow: 0 0 20px rgba(255, 123, 16, .1), inset 0 0 20px rgba(255, 153, 64, 5%)
}

details.keypoints-cartouche[open] {
	padding: 1rem 1.25rem 2rem
}

details.keypoints-cartouche::after {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background: linear-gradient(0deg, transparent 0%, rgba(255, 123, 16, 3%) 50%, transparent 100%);
	animation: scanline 8s linear infinite;
	pointer-events: none
}

@keyframes scanline {
	0% {
		transform: translateY(-100%)
	}

	100% {
		transform: translateY(100%)
	}
}

.keypoints-title {
	font-size: 1rem;
	font-weight: 900;
	color: #fff;
	margin: 0;
	text-transform: uppercase;
	letter-spacing: 3px;
	cursor: pointer;
	list-style: none;
	position: relative;
	padding-left: 1.5rem;
	line-height: 1.2;
	animation: glitch 2s infinite
}

@keyframes glitch {

	0%,
	100% {
		text-shadow: 2px 0 #ff7b10, -2px 0 #f0f, 0 0 10px rgba(255, 123, 16, .5)
	}

	25% {
		text-shadow: -2px 0 #ff9940, 2px 0 #ff7b10, 0 0 10px rgba(255, 153, 64, .5)
	}

	50% {
		text-shadow: 2px 2px #f0f, -2px -2px #ff7b10, 0 0 15px rgba(255, 123, 16, .5)
	}
}

details.keypoints-cartouche[open] .keypoints-title {
	margin-bottom: .75rem
}

.keypoints-title::before {
	content: 'â—ˆ';
	position: absolute;
	left: 0;
	top: 50%;
	transform: translateY(-50%);
	color: var(--link-color);
	font-size: 1rem;
	transition: all .3s ease;
	animation: rotate-pulse 3s linear infinite
}

@keyframes rotate-pulse {
	0% {
		transform: translateY(-50%)rotate(0)scale(1);
		opacity: 1
	}

	50% {
		transform: translateY(-50%)rotate(180deg)scale(1.1);
		opacity: .8
	}

	100% {
		transform: translateY(-50%)rotate(360deg)scale(1);
		opacity: 1
	}
}

@keyframes pulse {

	0%,
	100% {
		transform: translateY(-50%)scale(1);
		opacity: 1
	}

	50% {
		transform: translateY(-50%)scale(1.2);
		opacity: .7
	}
}

details.keypoints-cartouche[open] .keypoints-title::before {
	content: 'â—‰';
	transform: translateY(-50%);
	animation: pulse-glow 1.5s ease-in-out infinite
}

@keyframes pulse-glow {

	0%,
	100% {
		opacity: 1;
		text-shadow: 0 0 10px var(--link-color)
	}

	50% {
		opacity: .6;
		text-shadow: 0 0 5px var(--link-color)
	}
}

.keypoints-title::-webkit-details-marker {
	display: none
}

.keypoints-list {
	margin: 0;
	padding: 0;
	list-style: none
}

ol.keypoints-list {
	counter-reset: keypoint
}

.keypoints-disclaimer {
	position: absolute;
	bottom: .5rem;
	right: 1rem;
	font-size: .65rem;
	color: #888;
	opacity: .6;
	font-style: italic;
	letter-spacing: .02em
}

.keypoint-item {
	position: relative;
	padding: .25rem 0 .25rem 1.5rem;
	color: #e0e0e0;
	line-height: 1.4;
	font-size: .9rem;
	transition: all .3s ease
}

.keypoint-item:hover {
	color: #ff7b10;
	transform: translateX(5px);
	text-shadow: 0 0 5px rgba(255, 123, 16, .5)
}

.keypoint-item:not(:last-child) {
	border-bottom: none
}

.keypoint-item::before {
	content: 'â–¸';
	position: absolute;
	left: 0;
	top: .25rem;
	color: var(--link-color);
	font-size: 1rem;
	animation: pulse 2s infinite;
	animation-delay: calc(var(--item-index, 0) * .2s)
}

ol.keypoints-list>.keypoint-item {
	padding-left: 2.25rem
}

ol.keypoints-list>.keypoint-item::before {
	counter-increment: keypoint;
	content: counter(keypoint);
	top: .15rem;
	width: 1.5rem;
	height: 1.5rem;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border-radius: 999px;
	background: rgba(255, 123, 16, .18);
	border: 1px solid rgba(255, 123, 16, .35);
	color: var(--link-color);
	font-size: .85rem;
	font-weight: 800;
	animation: none
}

@media(prefers-color-scheme:light) {
	details.keypoints-cartouche {
		background: var(--background-color-secondary);
		border: 1px solid var(--box-shadow);
		border-left: 3px solid var(--link-color);
		border-image: none;
		box-shadow: 0 2px 8px rgba(0, 0, 0, 5%)
	}

	details.keypoints-cartouche::after {
		display: none
	}

	.keypoints-title {
		color: var(--couleur-titre);
		animation: none;
		text-shadow: none;
		font-weight: 700;
		letter-spacing: .05em
	}

	.keypoint-item {
		color: var(--primary-color)
	}

	.keypoint-item:hover {
		color: var(--link-color);
		text-shadow: none
	}

	.keypoint-item::before {
		color: var(--link-color);
		animation: none
	}
}

body:not(.force-dark) details.keypoints-cartouche {
	background: var(--background-color-secondary);
	border: 1px solid var(--box-shadow);
	border-left: 3px solid var(--link-color);
	border-image: none;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 5%)
}

body:not(.force-dark) details.keypoints-cartouche::after {
	display: none
}

body:not(.force-dark) .keypoints-title {
	color: var(--couleur-titre);
	animation: none;
	text-shadow: none;
	font-weight: 700;
	letter-spacing: .05em
}

body:not(.force-dark) .keypoint-item {
	color: var(--primary-color)
}

body:not(.force-dark) .keypoint-item:hover {
	color: var(--link-color);
	text-shadow: none
}

body:not(.force-dark) .keypoint-item::before {
	color: var(--link-color);
	animation: none
}

body:not(.force-dark) .keypoints-disclaimer {
	color: #666;
	opacity: .7
}

details.keypoints-cartouche:hover {
	opacity: 1;
	transition: opacity .2s ease
}

@media(max-width:768px) {
	details.keypoints-cartouche {
		margin: 0 0 1rem;
		padding: .85rem 1rem
	}

	details.keypoints-cartouche[open] {
		padding: .85rem 1rem 1.75rem
	}

	.keypoints-disclaimer {
		font-size: .6rem;
		bottom: .4rem;
		right: .75rem
	}

	.keypoints-title {
		font-size: .85rem
	}

	.keypoint-item {
		padding-left: 1rem;
		font-size: .85rem
	}

	.keypoint-item::before {
		font-size: .8rem
	}
}

details.llm-summary {
	margin: 0 0 1.5rem;
	background: var(--background-color-secondary);
	border: 1px solid var(--box-shadow);
	border-left: 3px solid var(--link-color);
	border-radius: 12px;
	overflow: hidden
}

.force-dark details.llm-summary {
	background: rgba(26, 26, 46, .6)
}

details.llm-summary summary {
	cursor: pointer;
	padding: 1rem 1.25rem;
	list-style: none
}

details.llm-summary summary::-webkit-details-marker {
	display: none
}

details.llm-summary summary::after {
	content: "";
	float: right;
	width: .55rem;
	height: .55rem;
	margin-top: .2rem;
	border-right: 2px solid;
	border-bottom: 2px solid;
	transform: rotate(45deg);
	opacity: .55
}

details.llm-summary[open] summary::after {
	transform: rotate(225deg)
}

.llm-summary-inner {
	padding: 0 1.25rem 1rem
}

.llm-summary-title {
	margin: 0;
	font-size: .85rem;
	font-weight: 900;
	letter-spacing: .08em;
	text-transform: uppercase;
	color: var(--couleur-titre)
}

.llm-summary-text {
	margin: 0 0 .75rem;
	line-height: 1.55;
	display: -webkit-box;
	line-clamp: 4;
	-webkit-line-clamp: 4;
	-webkit-box-orient: vertical;
	overflow: hidden
}

.llm-summary-points {
	margin: 0;
	padding: 0;
	list-style: none;
	counter-reset: llm-points
}

.llm-summary-points li {
	position: relative;
	margin: .35rem 0;
	padding-left: 2rem;
	line-height: 1.5
}

.llm-summary-points li::before {
	counter-increment: llm-points;
	content: counter(llm-points);
	position: absolute;
	left: 0;
	top: .1rem;
	width: 1.35rem;
	height: 1.35rem;
	display: grid;
	place-items: center;
	border-radius: 999px;
	font-size: .85rem;
	font-weight: 800;
	color: var(--couleur-titre);
	background: rgba(85, 109, 141, .12)
}

.llm-summary-empty {
	margin: 0;
	font-style: italic;
	opacity: .85
}

.llm-summary-ai-notice {
	display: block;
	margin: .75rem 0 0;
	font-size: .7rem;
	text-align: right;
	opacity: .5;
	font-style: italic;
	width: 100%
}

.article-qa {
	margin: 0 0 1.5rem
}

.article-qa-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1rem
}

@media(min-width:900px) {
	.article-qa-grid {
		grid-template-columns: 1fr 1fr;
		gap: 1.25rem
	}
}

.article-qa-card {
	background: var(--background-color-secondary);
	border: 1px solid var(--box-shadow);
	border-left: 3px solid var(--link-color);
	border-radius: 12px;
	padding: 1rem 1.25rem;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 5%)
}

.force-dark .article-qa-card {
	background: rgba(26, 26, 46, .6);
	box-shadow: 0 2px 10px rgba(0, 0, 0, .25)
}

.article-qa-title {
	margin: 0 0 .5rem;
	font-size: 1.05rem;
	font-weight: 800;
	letter-spacing: .02em
}

.article-qa-body {
	margin: 0
}

.article-qa-card .content {
	margin: 0
}

.article-qa-card ol,
.article-qa-card ul {
	margin: .5rem 0 0
}

.recent-articles-section {
	background: var(--background-color-secondary);
	padding-left: 4rem;
	padding-right: 4rem;
	padding-top: 1rem;
	padding-bottom: 1rem;
	margin: 0;
	width: 100%
}

.recent-articles-title {
	color: var(--text-color);
	font-size: 2.5rem;
	font-weight: 700;
	margin: 0 0 1.5rem;
	padding: 0;
	position: relative;
	display: flex;
	align-items: center;
	gap: .75rem
}

.recent-articles-title::before {
	content: '';
	width: 4px;
	height: 2.5rem;
	background: var(--link-color);
	border-radius: 2px
}

.recent-articles-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 1.5rem;
	position: relative
}

.recent-article-card {
	background: var(--background-color);
	transition: all .2s ease;
	position: relative;
	overflow: hidden;
	border-radius: 6px
}

.recent-article-card:hover {
	background: var(--background-color-secondary);
	transform: translateY(-2px);
	box-shadow: 0 4px 12px var(--shadow-color)
}

.recent-article-link {
	display: flex;
	align-items: center;
	gap: .875rem;
	text-decoration: none !important;
	color: inherit;
	padding: 1rem;
	height: 100%;
	min-height: 100px
}

.recent-article-link:hover {
	text-decoration: none !important
}

.recent-article-thumbnail {
	flex-shrink: 0;
	width: 120px;
	height: 120px;
	border-radius: 6px;
	overflow: hidden;
	background: var(--background-color);
	position: relative
}

.recent-article-thumbnail img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform .3s ease, filter .3s ease
}

.recent-article-card:hover .recent-article-thumbnail img {
	transform: scale(1.1)rotate(2deg);
	filter: brightness(1.05)
}

.recent-article-content {
	flex: 1;
	min-width: 0
}

.recent-article-title {
	color: var(--text-color);
	font-size: 1.5rem;
	font-weight: 600;
	line-height: 1.35;
	margin: 0 0 .4rem;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
	text-overflow: ellipsis;
	transition: all .2s ease;
	position: relative
}

.recent-article-card:hover .recent-article-title {
	color: var(--link-color);
	padding-left: 5px
}

.recent-article-date {
	color: var(--text-color-secondary);
	font-size: .8rem;
	font-weight: 400;
	transition: all .2s ease
}

.recent-article-card:hover .recent-article-date {
	color: var(--link-color);
	padding-left: 5px
}

@media(max-width:1400px) {
	.recent-articles-grid {
		grid-template-columns: repeat(3, 1fr)
	}
}

@media(max-width:1200px) {
	.recent-articles-grid {
		grid-template-columns: repeat(2, 1fr)
	}

	.recent-article-thumbnail {
		width: 100px;
		height: 100px
	}
}

@media(max-width:768px) {
	.recent-articles-section {
		padding: 1.5rem 1rem;
		margin: 2rem 0
	}

	.recent-articles-title {
		font-size: 1.25rem;
		margin-bottom: 1.25rem
	}

	.recent-articles-grid {
		grid-template-columns: 1fr;
		gap: .75rem
	}

	.recent-article-thumbnail {
		width: 80px;
		height: 80px;
		border-radius: 3px
	}

	.recent-article-title {
		font-size: 1.2rem
	}

	.recent-article-link {
		padding: .875rem
	}
}

@media(max-width:480px) {
	.recent-articles-section {
		padding: 1rem;
		margin: 1.5rem 0
	}

	.recent-articles-title {
		font-size: 1.15rem;
		gap: .5rem
	}

	.recent-articles-title::before {
		width: 3px;
		height: 1.2rem
	}

	.recent-article-link {
		padding: .75rem;
		gap: .75rem;
		min-height: 80px
	}

	.recent-article-thumbnail {
		width: 65px;
		height: 65px
	}

	.recent-article-title {
		font-size: 1.1rem;
		-webkit-line-clamp: 2
	}

	.recent-article-date {
		font-size: .75rem
	}
}

@media(max-width:360px) {
	.recent-articles-section {
		padding: .75rem
	}

	.recent-article-thumbnail {
		width: 55px;
		height: 55px
	}

	.recent-article-title {
		font-size: 1rem
	}

	.recent-article-link {
		padding: .625rem
	}
}

@media(prefers-reduced-motion:reduce) {

	.recent-article-card,
	.recent-article-thumbnail img,
	.recent-article-title {
		transition: none
	}
}

.guardia-section {
	padding: 4rem !important
}

.guardia-section .recent-articles-title::before {
	background: #8b5cf6
}

.guardia-grid {
	grid-template-columns: repeat(6, 1fr) !important;
	gap: 1rem !important
}

.guardia-grid+.guardia-grid {
	margin-top: 1rem
}

.guardia-card-overlay {
	position: relative !important;
	overflow: hidden;
	height: 250px;
	padding: 0 !important;
	background: 0 0 !important;
	border-radius: 8px
}

.guardia-section .recent-article-card.guardia-card-overlay {
	background: 0 0 !important;
	padding: 0 !important
}

.guardia-overlay-link {
	display: block !important;
	width: 100%;
	height: 100%;
	position: relative;
	text-decoration: none !important;
	padding: 0 !important;
	gap: 0 !important;
	align-items: stretch !important
}

.guardia-overlay-link:hover {
	text-decoration: none !important
}

.guardia-image-container {
	position: relative;
	width: 100%;
	height: 100%;
	overflow: hidden
}

.guardia-bg-image {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform .3s ease, filter .3s ease
}

.guardia-header-card {
	overflow: hidden;
	border-radius: 8px
}

.guardia-header-card .guardia-bg-image {
	object-fit: cover;
	object-position: center
}

.guardia-card-overlay:hover .guardia-bg-image {
	transform: scale(1.08);
	filter: brightness(.8)
}

.guardia-overlay-content {
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	padding: 1.75rem 1.25rem 1.25rem;
	background: linear-gradient(to top, rgba(0, 0, 0, .95) 0%, rgba(0, 0, 0, .75) 40%, rgba(0, 0, 0, .3) 70%, transparent 100%);
	display: flex;
	align-items: flex-end;
	z-index: 2;
	pointer-events: none
}

.guardia-overlay-title {
	font-size: 1.4rem;
	font-weight: 700;
	line-height: 1.2;
	position: absolute;
	bottom: 2rem;
	left: 50%;
	transform: translateX(-50%);
	background: var(--background-color-secondary);
	padding: .5rem .75rem;
	border-radius: 6px;
	box-shadow: 0 6px 18px var(--shadow-color);
	transition: transform .2s ease;
	letter-spacing: -.01em;
	display: inline-block;
	pointer-events: none;
	text-align: center;
	max-width: 90%
}

.guardia-card-overlay:hover .guardia-overlay-title {
	transform: translateX(-50%)translateY(-2px)
}

@media(max-width:1400px) {
	.guardia-grid {
		grid-template-columns: repeat(6, 1fr) !important;
		gap: .75rem !important
	}

	.guardia-card-overlay {
		height: 180px
	}

	.guardia-overlay-title {
		font-size: 1.1rem
	}
}

@media(max-width:1200px) {
	.guardia-grid {
		grid-template-columns: repeat(3, 1fr) !important
	}

	.guardia-card-overlay {
		height: 160px
	}

	.guardia-overlay-content {
		padding: 1.5rem 1rem 1rem
	}

	.guardia-overlay-title {
		font-size: 1.1rem;
		bottom: 1.25rem
	}
}

@media(max-width:992px) {
	.guardia-grid {
		grid-template-columns: repeat(3, 1fr) !important
	}

	.guardia-card-overlay {
		height: 140px
	}

	.guardia-overlay-title {
		font-size: 1rem;
		bottom: 1rem
	}
}

@media(max-width:768px) {
	.guardia-section {
		padding: 2rem 1rem !important
	}

	.guardia-grid {
		grid-template-columns: repeat(2, 1fr) !important
	}

	.guardia-card-overlay {
		height: 120px
	}

	.guardia-overlay-content {
		padding: 1rem .75rem .75rem
	}

	.guardia-overlay-title {
		font-size: .9rem;
		bottom: .75rem;
		padding: .4rem .6rem
	}
}

@media(max-width:480px) {
	.guardia-section {
		padding: 1.5rem .75rem !important
	}

	.guardia-grid {
		grid-template-columns: repeat(2, 1fr) !important;
		gap: .5rem !important
	}

	.guardia-card-overlay {
		height: 100px
	}

	.guardia-overlay-content {
		padding: .75rem .5rem .5rem;
		background: linear-gradient(to top, rgba(0, 0, 0, .95) 0%, rgba(0, 0, 0, .7) 50%, transparent 100%)
	}

	.guardia-overlay-title {
		font-size: .8rem;
		bottom: .5rem;
		padding: .3rem .5rem
	}
}

.pub-section img[src$=".svg"],
.native-ad img[src$=".svg"] {
	max-height: 250px;
	height: auto;
	width: auto;
	display: block;
	margin: 1rem auto
}

.native-ad .content p {
	margin: .75rem 0
}

.native-ad .content p:first-child {
	margin-top: 0
}

.native-ad .content p:last-child {
	margin-bottom: 0
}

.category-section-separator {
	width: 100%;
	margin: 2rem 0 1.5rem;
	padding: 0 1rem;
	display: flex;
	align-items: center;
	gap: 1rem
}

.category-section-separator::before,
.category-section-separator::after {
	content: "";
	flex: 1;
	height: 1px;
	background: linear-gradient(to right, transparent, var(--border-color, #e0e0e0), transparent)
}

.category-section-title {
	margin: 0;
	padding: .5rem 1.5rem;
	font-size: 1rem;
	font-weight: 600;
	color: var(--text-color-secondary, #666);
	text-transform: uppercase;
	letter-spacing: .05em;
	white-space: nowrap;
	background: var(--bg-color, #fff);
	border-radius: 2rem;
	border: 1px solid var(--border-color, #e0e0e0)
}

@media(prefers-color-scheme:dark) {

	.category-section-separator::before,
	.category-section-separator::after {
		background: linear-gradient(to right, transparent, var(--border-color-dark, #444), transparent)
	}

	.category-section-title {
		color: var(--text-color-secondary-dark, #aaa);
		background: var(--bg-color-dark, #1a1a1a);
		border-color: var(--border-color-dark, #444)
	}
}

.category-folders {
	display: grid;
	grid-template-columns: repeat(6, 1fr);
	gap: 1.5rem;
	margin: 1.5rem 0;
	width: 100%;
	padding-left: 4rem;
	padding-right: 4rem;
	max-width: 1800px;
	margin-left: auto;
	margin-right: auto
}

.category-folders>.category-folder {
	grid-column: span 2
}

.category-folders>.category-folder:last-child:nth-child(3n+1) {
	grid-column: 1/-1
}

.category-folders>.category-folder:last-child:nth-child(3n+1) .category-folder-visual {
	aspect-ratio: 21/9
}

.category-folders>.category-folder:nth-last-child(2):nth-child(3n+1) {
	grid-column: span 3
}

.category-folders>.category-folder:last-child:nth-child(3n+2) {
	grid-column: span 3
}

.category-folder {
	display: flex;
	flex-direction: column;
	text-decoration: none;
	color: inherit;
	transition: transform .3s ease, box-shadow .3s ease;
	background: linear-gradient(135deg, var(--category-gradient-start, #9b59b6), var(--category-gradient-end, #3498db));
	border-radius: 12px;
	padding: 2px
}

.category-folder:hover {
	transform: translateY(-5px);
	box-shadow: 0 5px 15px rgba(0, 0, 0, .1);
	text-decoration: none
}

.category-folder:hover .category-folder-title,
.category-folder:hover .category-folder-description {
	text-decoration: none
}

.category-folder-inner {
	background: var(--background-color-secondary, #fff);
	border-radius: 10px;
	overflow: hidden;
	flex: 1;
	display: flex;
	flex-direction: column
}

.category-folder-visual {
	position: relative;
	width: 100%;
	aspect-ratio: 4/3;
	overflow: hidden;
	background: linear-gradient(180deg, var(--category-gradient-start, #9b59b6) 0%, var(--category-gradient-end, #e74c3c) 100%);
	display: flex;
	align-items: center;
	justify-content: center
}

.category-folder-icon {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center
}

.category-folder-info {
	padding: 1rem;
	flex: 1;
	display: flex;
	flex-direction: column
}

.category-folder-title {
	font-size: 1.35rem;
	font-weight: 700;
	margin: 0 0 .5rem;
	color: var(--heading-color);
	line-height: 1.35;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden
}

.category-folder-description {
	color: var(--text-color-muted, #666);
	font-size: .9rem;
	line-height: 1.5;
	margin: 0;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden
}

.category-folder[data-category=securite],
.category-folder[data-category=vpn],
.category-folder[data-category=vie-privee] {
	--category-gradient-start: #9b59b6;
	--category-gradient-end: #3498db
}

.category-folder[data-category=web],
.category-folder[data-category=phishing],
.category-folder[data-category=hacking] {
	--category-gradient-start: #e67e22;
	--category-gradient-end: #e91e63
}

.category-folder[data-category=cloud],
.category-folder[data-category=environnement],
.category-folder[data-category=dev] {
	--category-gradient-start: #2ecc71;
	--category-gradient-end: #00bcd4
}

.category-folder[data-category=ia],
.category-folder[data-category=intelligence-artificielle],
.category-folder[data-category=tech] {
	--category-gradient-start: #3498db;
	--category-gradient-end: #5c6bc0
}

.category-folder[data-category=gaming],
.category-folder[data-category=jeux-video],
.category-folder[data-category=multimedia] {
	--category-gradient-start: #e74c3c;
	--category-gradient-end: #ff9800
}

.category-folder[data-category=linux],
.category-folder[data-category=open-source],
.category-folder[data-category=tutoriels] {
	--category-gradient-start: #009688;
	--category-gradient-end: #4caf50
}

.category-folder[data-category=lifestyle],
.category-folder[data-category=culture-geek] {
	--category-gradient-start: #e91e63;
	--category-gradient-end: #9c27b0
}

.category-folder[data-category=hardware],
.category-folder[data-category=materiel] {
	--category-gradient-start: #1a237e;
	--category-gradient-end: #00bcd4
}

@media(min-width:1920px) {
	.category-folders {
		padding-left: 6rem;
		padding-right: 6rem;
		max-width: 1800px
	}
}

@media(min-width:1400px) and (max-width:1919px) {
	.category-folders {
		padding-left: 4rem;
		padding-right: 4rem
	}
}

@media(min-width:1024px) and (max-width:1399px) {
	.category-folders {
		padding-left: 8rem;
		padding-right: 8rem
	}
}

@media(min-width:768px) and (max-width:1023px) {
	.category-folders {
		padding-left: 2rem;
		padding-right: 2rem;
		gap: 1.5rem
	}
}

@media(max-width:767px) {
	.category-folders {
		grid-template-columns: 1fr;
		gap: 1.2rem;
		padding-left: 1rem;
		padding-right: 1rem
	}

	.category-folder-info {
		padding: .75rem
	}

	.category-folder-title {
		font-size: 1rem
	}
}

@media(prefers-color-scheme:dark) {
	.category-folder-inner {
		background: var(--background-color-secondary, #1a1a1a)
	}

	.category-folder-description {
		color: var(--text-color-muted, #aaa)
	}
}

[data-theme=dark] .category-folder-inner {
	background: var(--background-color-secondary, #1a1a1a)
}

[data-theme=dark] .category-folder-description {
	color: var(--text-color-muted, #aaa)
}

.breadcrumb-container {
	display: block;
	box-sizing: border-box;
	width: 100%;
	margin: 0;
	padding-top: 20px;
	padding-bottom: 20px;
	padding-left: 0 !important;
	padding-right: 0 !important
}

.breadcrumb {
	list-style: none;
	margin: 0;
	font-family: sans-serif;
	font-size: .85rem;
	text-transform: uppercase;
	letter-spacing: 1px
}

.breadcrumb-container .breadcrumb {
	padding-left: 6rem !important;
	padding-right: 6rem !important
}

.breadcrumb li {
	display: inline-block;
	color: #6c757d
}

.breadcrumb li+li::before {
	content: "â€º";
	padding: 0 10px;
	color: #ccc;
	font-weight: 700
}

.breadcrumb-nav .breadcrumb li+li::before {
	content: "/";
	font-weight: 400
}

.breadcrumb-nav .breadcrumb li:last-child,
.breadcrumb-nav .breadcrumb li:last-child a {
	color: #6c757d;
	font-weight: 600
}

.breadcrumb a {
	text-decoration: none;
	color: #6c757d;
	transition: color .2s
}

.breadcrumb a:hover {
	color: #000
}

.breadcrumb .active {
	color: #000;
	font-weight: 700
}

@media(prefers-color-scheme:dark) {

	.breadcrumb li,
	.breadcrumb a {
		color: #a0a0a0
	}

	.breadcrumb a:hover,
	.breadcrumb .active {
		color: #fff
	}

	.breadcrumb li+li::before {
		color: #666
	}
}

@media(min-width:1920px) {
	.breadcrumb-container .breadcrumb {
		padding-left: 6rem !important;
		padding-right: 6rem !important
	}
}

@media(min-width:1400px) and (max-width:1919px) {
	.breadcrumb-container .breadcrumb {
		padding-left: 4rem !important;
		padding-right: 4rem !important
	}
}

@media(min-width:1024px) and (max-width:1399px) {
	.breadcrumb-container .breadcrumb {
		padding-left: 8rem !important;
		padding-right: 8rem !important
	}
}

@media(min-width:768px) and (max-width:1023px) {
	.breadcrumb-container .breadcrumb {
		padding-left: 2rem !important;
		padding-right: 2rem !important
	}
}

@media(max-width:767px) {
	.breadcrumb-container .breadcrumb {
		padding-left: 1rem !important;
		padding-right: 1rem !important
	}
}

.category-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
	gap: 24px;
	padding: 0 2rem;
	max-width: 1400px;
	margin: 2rem auto
}

.category-card {
	display: flex;
	flex-direction: column;
	background: var(--background-color-secondary);
	border-radius: 16px;
	overflow: hidden;
	text-decoration: none;
	color: var(--text-color);
	transition: transform .2s ease, box-shadow .2s ease;
	border: 1px solid var(--border-color)
}

.category-card:hover {
	transform: translateY(-4px);
	box-shadow: 0 12px 40px rgba(0, 0, 0, .15)
}

.category-card-visual {
	position: relative;
	aspect-ratio: 4/3;
	background: var(--background-color-hero);
	display: flex;
	align-items: center;
	justify-content: center;
	overflow: hidden
}

.category-card-image {
	width: 100%;
	height: 100%;
	object-fit: cover
}

.category-card-icon {
	width: 80px;
	height: 80px;
	display: flex;
	align-items: center;
	justify-content: center;
	background: rgba(255, 255, 255, .1);
	border-radius: 20px;
	padding: 16px
}

.category-card-icon img {
	width: 48px;
	height: 48px;
	filter: brightness(0)invert(1);
	opacity: .9
}

.category-card:hover .category-card-icon {
	background: rgba(255, 123, 16, .3)
}

.category-card:hover .category-card-icon img {
	opacity: 1
}

.category-card-content {
	padding: 20px;
	display: flex;
	flex-direction: column;
	gap: 8px
}

.category-card-title {
	font-size: 1.25rem;
	font-weight: 700;
	color: var(--heading-color);
	margin: 0;
	line-height: 1.3
}

.category-card-description {
	font-size: .85rem;
	color: var(--text-color-secondary);
	margin: 0;
	line-height: 1.4;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden
}

.category-card-count {
	font-size: .85rem;
	color: var(--text-color-muted, var(--text-color-secondary));
	margin: 0;
	opacity: .7
}

@media(max-width:768px) {
	.category-grid {
		grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
		gap: 16px;
		padding: 0 1rem
	}

	.category-card-content {
		padding: 16px
	}

	.category-card-title {
		font-size: 1.1rem
	}

	.category-card-icon {
		width: 64px;
		height: 64px;
		padding: 12px
	}

	.category-card-icon img {
		width: 40px;
		height: 40px
	}
}

@media(max-width:480px) {
	.category-grid {
		grid-template-columns: 1fr;
		gap: 12px
	}

	.category-card {
		flex-direction: row;
		align-items: center
	}

	.category-card-visual {
		width: 100px;
		min-width: 100px;
		aspect-ratio: 1
	}

	.category-card-icon {
		width: 48px;
		height: 48px;
		padding: 10px;
		border-radius: 12px
	}

	.category-card-icon img {
		width: 28px;
		height: 28px
	}

	.category-card-content {
		padding: 12px 16px
	}

	.category-card-title {
		font-size: 1rem
	}

	.category-card-count {
		font-size: .85rem
	}
}

.article-content {
	max-width: 90ch
}

.article-content .content>p,
.article-content .content>ul,
.article-content .content>ol,
.article-content .content>blockquote p {
	line-height: 1.6
}

@media screen and (max-width:768px) {
	.article-content {
		max-width: 100%
	}
}

.menu-overlay {
	background: var(--background-color-hero) !important;
	overflow-y: auto !important
}

.menu-overlay nav.header-buttons {
	display: flex !important;
	flex-direction: column !important;
	min-height: 100%;
	padding: 70px 24px 32px !important;
	align-items: center !important;
	justify-content: flex-start !important
}

.mobile-nav-list {
	display: flex !important;
	flex-direction: column !important;
	width: 100%;
	max-width: 300px;
	margin: 0 auto;
	gap: 4px
}

.mobile-nav-item {
	display: flex !important;
	flex-direction: row !important;
	align-items: center !important;
	gap: 14px !important;
	padding: 14px 16px !important;
	text-decoration: none !important;
	color: #fff !important;
	border-radius: 10px;
	transition: background .15s ease;
	font-size: 1rem !important;
	font-weight: 500 !important;
	margin-bottom: 0 !important
}

.mobile-nav-item:hover,
.mobile-nav-item:focus {
	background: rgba(255, 255, 255, .1)
}

.mobile-nav-item img {
	width: 24px !important;
	height: 24px !important;
	filter: brightness(0)invert(1);
	opacity: .9;
	flex-shrink: 0
}

.mobile-nav-item:hover img {
	opacity: 1
}

.mobile-nav-item span {
	flex: 1
}

.menu-overlay .cta-buttons {
	display: flex !important;
	flex-direction: row !important;
	gap: 12px !important;
	margin-top: auto !important;
	padding-top: 32px !important;
	width: 100%;
	max-width: 300px;
	justify-content: center !important;
	border-top: 1px solid rgba(255, 255, 255, .15)
}

.menu-overlay .cta-button {
	flex: 1;
	padding: 14px 18px !important;
	font-size: .9rem !important;
	font-weight: 600 !important;
	text-align: center;
	border-radius: 8px !important;
	text-decoration: none !important;
	margin: 0 !important;
	transition: all .15s ease
}

.menu-overlay .cta-button.primary {
	background: var(--button-primary-background) !important;
	color: #fff !important;
	border: none !important
}

.menu-overlay .cta-button.primary:hover {
	background: #ff8c33 !important
}

.menu-overlay .cta-button.secondary {
	background: 0 0 !important;
	color: #fff !important;
	border: 2px solid rgba(255, 255, 255, .4) !important
}

.menu-overlay .cta-button.secondary:hover {
	background: rgba(255, 255, 255, .1) !important;
	border-color: rgba(255, 255, 255, .6) !important
}

.menu-overlay .modal-close {
	position: absolute !important;
	top: 18px !important;
	right: 18px !important;
	left: auto !important;
	width: 44px !important;
	height: 44px !important;
	font-size: 32px !important;
	font-weight: 300;
	color: #fff !important;
	background: 0 0 !important;
	border-radius: 8px;
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	cursor: pointer;
	z-index: 10;
	transition: background .15s ease
}

.menu-overlay .modal-close:hover {
	background: rgba(255, 255, 255, .1) !important
}

@media(max-width:380px) {
	.menu-overlay nav.header-buttons {
		padding: 60px 16px 24px !important
	}

	.mobile-nav-list {
		max-width: 100%
	}

	.mobile-nav-item {
		padding: 12px 14px !important;
		gap: 12px !important;
		font-size: .95rem !important
	}

	.menu-overlay .cta-buttons {
		flex-direction: column !important;
		gap: 10px !important
	}

	.menu-overlay .cta-button {
		width: 100%
	}
}

@media screen and (max-width:768px) {
	html {
		overflow-x: hidden;
		overflow-y: auto;
		-webkit-overflow-scrolling: touch;
		height: 100%
	}

	body {
		overflow-x: hidden !important;
		overflow-y: auto !important;
		-webkit-overflow-scrolling: touch;
		height: auto !important;
		min-height: 100vh;
		position: relative !important;
		margin: 0
	}

	.main-container {
		overflow-x: hidden !important;
		overflow-y: visible !important;
		height: auto !important;
		min-height: auto !important;
		max-height: none !important
	}

	main,
	.wrapper,
	.container,
	.articles,
	.article-content,
	.content,
	.post-content {
		overflow-x: hidden !important;
		overflow-y: visible !important;
		height: auto !important;
		min-height: auto !important;
		max-height: none !important;
		width: 100% !important;
		max-width: 100% !important
	}

	.sidebar {
		overflow-x: hidden !important;
		overflow-y: visible !important;
		height: auto !important;
		position: static !important;
		display: block !important;
		width: 100% !important;
		max-width: 100% !important
	}

	.sticky-ad,
	.sticky {
		position: relative !important;
		top: auto !important
	}

	.home-cards,
	.home-articles,
	.card {
		overflow-x: hidden !important;
		overflow-y: visible !important;
		height: auto !important;
		width: 100% !important;
		max-width: 100% !important
	}

	.menu-overlay {
		-webkit-overflow-scrolling: touch
	}

	pre {
		overflow-x: auto;
		-webkit-overflow-scrolling: touch;
		max-width: 100%
	}

	.card {
		max-width: 100%;
		overflow-x: hidden
	}

	* {
		-webkit-tap-highlight-color: transparent;
		-webkit-touch-callout: none
	}

	body.menu-open {
		overflow: hidden !important;
		position: fixed !important;
		width: 100% !important
	}
}

@media screen and (max-width:480px) {
	body {
		width: 100%;
		max-width: 100%
	}

	.wrapper,
	.main-container {
		width: 100%;
		max-width: 100%;
		padding-left: 0;
		padding-right: 0;
		box-sizing: border-box
	}

	* {
		max-width: 100%;
		box-sizing: border-box
	}

	img,
	video,
	iframe {
		max-width: 100% !important;
		height: auto
	}
}

.hide-on-scroll-header {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	z-index: 1000;
	transition: transform .3s ease-in-out;
	will-change: transform
}

.hide-on-scroll-header.header-hidden {
	transform: translateY(-100%)
}

@media screen and (max-width:768px) {
	body {
		padding-top: calc(var(--header-height, 80px) + env(safe-area-inset-top))
	}

	.hide-on-scroll-header {
		background-color: var(--color-bande, var(--background-color-hero));
		box-shadow: none
	}

	.hide-on-scroll-header {
		-webkit-backface-visibility: hidden;
		backface-visibility: hidden;
		-webkit-perspective: 1000;
		perspective: 1000
	}
}

@media screen and (min-width:769px) {
	.hide-on-scroll-header {
		position: relative !important;
		transform: none !important;
		transition: none !important
	}

	body {
		padding-top: 0 !important
	}
}

.youtube-container {
	position: relative;
	padding-bottom: 56.25%;
	height: 0;
	overflow: hidden;
	max-width: 100%;
	margin-bottom: 1.5rem;
	display: block;
	clear: both
}

.youtube-container iframe {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%
}

.youtube-container+p,
.youtube-container+* {
	margin-top: 0;
	text-align: left;
	clear: both
}

.youtube-container+p a,
.youtube-container+* a {
	position: relative;
	z-index: 1;
	overflow: visible
}

.yt-thumb {
	position: relative;
	width: 100%;
	padding-top: 56.25%;
	background-size: cover;
	background-position: 50%;
	border-radius: 8px;
	overflow: hidden;
	box-shadow: 0 4px 16px rgba(0, 0, 0, .15);
	cursor: pointer
}

.yt-overlay {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	background: rgba(0, 0, 0, .4);
	transition: background .2s
}

.yt-thumb:hover .yt-overlay {
	background: rgba(0, 0, 0, .5)
}

.yt-play {
	margin-bottom: 16px;
	filter: drop-shadow(0 2px 8px rgba(0, 0, 0, .6));
	transition: transform .2s
}

.yt-thumb:hover .yt-play {
	transform: scale(1.08)
}

.yt-msg {
	color: #fff;
	text-align: center;
	font-size: 1rem;
	background: rgba(0, 0, 0, .6);
	padding: 10px 20px;
	border-radius: 4px;
	box-shadow: 0 2px 8px rgba(0, 0, 0, .2);
	max-width: 80%
}

@media(max-width:768px) {
	.yt-msg {
		font-size: .9rem;
		padding: 8px 12px
	}

	.yt-play {
		width: 58px;
		height: 41px
	}
}

.social-embed-placeholder {
	position: relative;
	background-color: var(--background-color-secondary, #f5f5f5);
	border: 2px solid var(--border-color, #e0e0e0);
	border-radius: 8px;
	padding: 2rem;
	text-align: center;
	cursor: pointer;
	transition: all .3s ease;
	min-height: 200px;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center
}

.social-embed-placeholder:hover {
	background-color: var(--background-color-hover, #ebebeb);
	border-color: var(--primary-color, #333)
}

.social-embed-icon {
	width: 48px;
	height: 48px;
	margin-bottom: 1rem;
	opacity: .7
}

.social-embed-title {
	font-size: 1.2rem;
	font-weight: 600;
	margin-bottom: .5rem;
	color: var(--text-color, #333)
}

.social-embed-warning {
	font-size: .9rem;
	color: var(--text-color-secondary, #666);
	margin-bottom: 1rem;
	max-width: 400px
}

.social-embed-button {
	background-color: var(--primary-color, #333);
	color: #fff;
	padding: .75rem 1.5rem;
	border: none;
	border-radius: 4px;
	font-size: 1rem;
	cursor: pointer;
	transition: background-color .3s ease
}

.social-embed-button:hover {
	background-color: var(--primary-color-hover, #555)
}

.twitter-placeholder .social-embed-icon {
	fill: #1da1f2
}

.facebook-placeholder .social-embed-icon {
	fill: #1877f2
}

.tiktok-placeholder .social-embed-icon {
	fill: #000
}

.social-embed-loaded {
	animation: fadeIn .3s ease
}

@keyframes fadeIn {
	from {
		opacity: 0;
		transform: translateY(10px)
	}

	to {
		opacity: 1;
		transform: translateY(0)
	}
}

@media(prefers-color-scheme:dark) {
	.social-embed-placeholder {
		background-color: var(--background-color-secondary, #2a2a2a);
		border-color: var(--border-color, #404040)
	}

	.social-embed-placeholder:hover {
		background-color: var(--background-color-hover, #353535)
	}
}

.button-container {
	text-align: center;
	margin: 2rem 0;
	width: 100%
}

.button-container--padded {
	padding-bottom: 2rem
}

.button-wrapper {
	max-width: 800px;
	margin: 0 auto;
	display: flex;
	justify-content: center
}

.content-404 {
	font-size: 1.1em;
	line-height: 1.6
}

.content-404 p {
	margin-bottom: 1.5em
}

.recent-posts {
	margin-top: 3rem;
	padding: 0 1rem
}

.recent-posts h2 {
	margin-bottom: 2rem;
	font-size: 1.8em;
	text-align: center
}

table {
	width: 100%;
	border-collapse: collapse;
	margin: 2rem 0;
	font-size: 1rem;
	border-radius: var(--border-radius-base);
	overflow: hidden;
	box-shadow: 0 0 20px rgba(0, 0, 0, .1)
}

thead {
	background-color: var(--couleur-titre);
	color: #fff
}

th {
	padding: 1rem;
	text-align: left;
	font-weight: 600;
	letter-spacing: .05em;
	text-transform: uppercase;
	font-size: .9rem
}

td {
	padding: 1rem;
	border-bottom: 1px solid rgba(0, 0, 0, .1);
	color: var(--primary-color)
}

tbody tr {
	transition: background-color .3s ease
}

tbody tr:hover {
	background-color: var(--article-gradient-from)
}

tbody tr:last-child td {
	border-bottom: none
}

tbody tr:nth-child(even) {
	background-color: rgba(85, 109, 141, 5%)
}

@media(max-width:768px) {
	table {
		border-radius: 0
	}

	thead {
		display: none
	}

	tr {
		display: block;
		margin-bottom: 1rem;
		border: 1px solid rgba(0, 0, 0, .1);
		border-radius: var(--border-radius-base);
		background-color: var(--background-color-secondary)
	}

	td {
		display: block;
		text-align: right;
		position: relative;
		padding-left: 50%
	}

	td:before {
		content: attr(data-label);
		position: absolute;
		left: 1rem;
		top: 1rem;
		font-weight: 700;
		text-align: left;
		color: var(--link-color)
	}
}

.force-dark table {
	background-color: var(--background-color-secondary);
	box-shadow: 0 0 20px rgba(0, 0, 0, .3)
}

.force-dark thead {
	background-color: var(--footer-background)
}

.force-dark td {
	border-bottom: 1px solid rgba(255, 255, 255, .1)
}

.force-dark tbody tr:hover {
	background-color: var(--article-gradient-from)
}

.force-dark tbody tr:nth-child(even) {
	background-color: rgba(85, 109, 141, .1)
}

.livre-dor-page {
	max-width: 900px;
	margin: 0 auto;
	padding: 2rem 1rem
}

.livre-dor-header {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	margin-bottom: 3rem;
	padding: 2rem 1rem;
	background: 0 0;
	border: none;
	box-shadow: none;
	border-radius: 0
}

.livre-dor-title {
	font-size: 2.5rem;
	font-weight: 700;
	color: var(--heading-color, #181e2c);
	margin: 0 0 1rem;
	width: 100%
}

.livre-dor-description {
	font-size: 1.1rem;
	color: var(--text-color, #374151);
	margin: 0;
	line-height: 1.6;
	max-width: 600px;
	width: 100%
}

.livre-dor-form-section {
	margin-bottom: 3rem
}

.form-group input:user-valid,
.form-group textarea:user-valid {
	border-color: #22c55e;
	box-shadow: 0 0 0 3px rgba(34, 197, 94, .1)
}

.form-group input:user-invalid,
.form-group textarea:user-invalid {
	border-color: #dc2626;
	box-shadow: 0 0 0 3px rgba(220, 38, 38, .1)
}

@media(prefers-reduced-motion:reduce) {

	.form-group input,
	.form-group textarea,
	.form-message,
	.message-card,
	.btn-submit {
		transition: none !important;
		animation: none !important
	}
}

.livre-dor-form-container {
	background: var(--card-bg, #FFFFFF);
	border: 1px solid var(--border-color, #e5e7eb);
	border-radius: var(--border-radius-large, 16px);
	padding: 2rem;
	box-shadow: var(--box-shadow, 0 4px 6px -1px rgba(0, 0, 0, .1));
	transition: all .3s cubic-bezier(.4, 0, .2, 1)
}

.livre-dor-form-container:hover {
	box-shadow: var(--box-shadow-hover, 0 20px 25px -5px rgba(0, 0, 0, .1))
}

.livre-dor-form-title {
	font-size: 1.5rem;
	font-weight: 600;
	color: var(--heading-color, #181e2c);
	margin: 0 0 1.5rem;
	text-align: center
}

.livre-dor-form {
	display: flex;
	flex-direction: column;
	gap: 1.25rem
}

.form-group {
	display: flex;
	flex-direction: column;
	gap: .5rem
}

.form-group label {
	font-weight: 600;
	color: var(--heading-color, #181e2c);
	font-size: .95rem
}

.form-group .required {
	color: var(--link-color, #c75100)
}

.form-group input,
.form-group textarea {
	width: 100%;
	padding: .875rem 1rem;
	border: 1px solid var(--border-color, #e5e7eb);
	border-radius: var(--border-radius-base, 12px);
	font-size: 1rem;
	font-family: inherit;
	background: var(--background-color-page, #FFFFFF);
	color: var(--text-color, #374151);
	transition: all .2s ease;
	box-sizing: border-box
}

.form-group input:focus,
.form-group textarea:focus {
	outline: none;
	border-color: var(--link-color, #c75100);
	box-shadow: 0 0 0 3px rgba(199, 81, 0, .1)
}

.form-group input::placeholder,
.form-group textarea::placeholder {
	color: var(--text-color-secondary, #4a5568);
	opacity: .6
}

.form-group textarea {
	resize: vertical;
	min-height: 120px
}

.char-count {
	font-size: .8rem;
	color: var(--text-color-secondary, #4a5568);
	text-align: right
}

.form-actions-row {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 1rem;
	margin-top: .5rem;
	flex-wrap: wrap
}

@media screen and (max-width:540px) {
	.form-actions-row {
		flex-direction: column;
		align-items: stretch
	}

	.form-actions-row #turnstile-widget {
		align-self: center
	}
}

.btn-retro,
.btn-submit {
	background: var(--button-primary-background, #ff7b10);
	color: var(--button-primary-foreground, #FFFFFF);
	border: none;
	padding: .875rem 2rem;
	font-size: 1rem;
	font-weight: 600;
	border-radius: 9999px;
	cursor: pointer;
	transition: all .3s ease;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: .5rem;
	min-width: 200px;
	font-family: inherit
}

.btn-submit:hover:not(:disabled) {
	background: var(--link-color, #c75100);
	transform: translateY(-2px);
	box-shadow: 0 4px 12px rgba(255, 123, 16, .3)
}

.btn-submit:disabled {
	opacity: .5;
	cursor: not-allowed
}

.btn-loading {
	display: none
}

.form-message {
	padding: 1rem;
	border-radius: var(--border-radius-base, 12px);
	text-align: center;
	font-weight: 500;
	opacity: 0;
	transform: translateY(-10px);
	transition: opacity .3s ease, transform .3s ease;
	pointer-events: none;
	max-height: 0;
	overflow: hidden;
	padding: 0;
	margin: 0
}

.form-message.visible {
	opacity: 1;
	transform: translateY(0);
	pointer-events: auto;
	max-height: 100px;
	padding: 1rem;
	margin-top: 1rem
}

.form-message.success {
	background: rgba(34, 197, 94, .1);
	color: #16a34a;
	border: 1px solid rgba(34, 197, 94, .2)
}

.form-message.error {
	background: rgba(239, 68, 68, .1);
	color: #dc2626;
	border: 1px solid rgba(239, 68, 68, .2)
}

.livre-dor-messages-section {
	margin-top: 2rem
}

.livre-dor-messages-title {
	font-size: 1.75rem;
	font-weight: 600;
	color: var(--heading-color, #181e2c);
	margin: 0 0 1rem;
	text-align: center
}

.livre-dor-stats {
	text-align: center;
	margin-bottom: 1.5rem;
	color: var(--text-color-secondary, #4a5568);
	font-size: .95rem
}

.livre-dor-messages {
	display: flex;
	flex-direction: column;
	gap: 1rem
}

.message-card {
	background: var(--card-bg, #FFFFFF);
	border: 1px solid var(--border-color, #e5e7eb);
	border-radius: var(--border-radius-large, 16px);
	padding: 1.5rem;
	transition: all .3s cubic-bezier(.4, 0, .2, 1)
}

.message-card:hover {
	transform: translateY(-3px);
	box-shadow: var(--box-shadow-hover, 0 20px 25px -5px rgba(0, 0, 0, .1));
	border-color: var(--link-color, #c75100)
}

.message-header {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-bottom: .75rem;
	flex-wrap: wrap;
	gap: .5rem
}

.message-pseudo {
	font-weight: 700;
	color: var(--heading-color, #181e2c);
	font-size: 1.1rem
}

.message-date {
	font-size: .85rem;
	color: var(--text-color-secondary, #4a5568)
}

.message-content {
	color: var(--text-color, #374151);
	line-height: 1.7;
	font-size: 1rem;
	white-space: pre-wrap;
	word-break: break-word
}

.loading-spinner {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	padding: 3rem;
	color: var(--text-color-secondary, #4a5568)
}

.spinner {
	width: 40px;
	height: 40px;
	border: 3px solid var(--border-color, #e5e7eb);
	border-top-color: var(--link-color, #c75100);
	border-radius: 50%;
	animation: spin .8s linear infinite;
	margin-bottom: 1rem
}

@keyframes spin {
	to {
		transform: rotate(360deg)
	}
}

.livre-dor-pagination {
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 1rem;
	margin-top: 2rem;
	padding-top: 2rem;
	border-top: 1px solid var(--border-color, #e5e7eb)
}

.btn-pagination {
	background: var(--card-bg, #FFFFFF);
	color: var(--text-color, #374151);
	border: 1px solid var(--border-color, #e5e7eb);
	padding: .625rem 1.25rem;
	font-size: .9rem;
	font-weight: 600;
	border-radius: 9999px;
	cursor: pointer;
	transition: all .2s ease;
	font-family: inherit
}

.btn-pagination:hover:not(:disabled) {
	background: var(--link-color, #c75100);
	color: #fff;
	border-color: var(--link-color, #c75100);
	transform: translateY(-2px)
}

.btn-pagination:disabled {
	opacity: .4;
	cursor: not-allowed
}

.page-info {
	color: var(--text-color-secondary, #4a5568);
	font-size: .9rem;
	font-weight: 500
}

.no-messages,
.empty-message {
	text-align: center;
	padding: 3rem;
	color: var(--text-color-secondary, #4a5568);
	font-size: 1.1rem
}

.force-dark .livre-dor-header {
	border-color: rgba(255, 255, 255, 5%)
}

.force-dark .livre-dor-form-container {
	border-color: rgba(255, 255, 255, 5%)
}

.force-dark .form-group input,
.force-dark .form-group textarea {
	background: var(--background-color-secondary, #1e293b);
	border-color: var(--border-color, #334155)
}

.force-dark .message-card {
	border-color: rgba(255, 255, 255, 5%)
}

.force-dark .livre-dor-pagination {
	border-top-color: var(--border-color)
}

.force-dark .btn-pagination {
	background: var(--background-color-secondary, #1e293b);
	border-color: var(--border-color, #334155)
}

.force-dark .form-message.success {
	background: rgba(34, 197, 94, .15);
	color: #4ade80;
	border-color: rgba(34, 197, 94, .3)
}

.force-dark .form-message.error {
	background: rgba(239, 68, 68, .15);
	color: #f87171;
	border-color: rgba(239, 68, 68, .3)
}

@media screen and (max-width:768px) {
	.livre-dor-page {
		padding: 1.5rem 1rem
	}

	.livre-dor-title {
		font-size: 2rem
	}

	.livre-dor-form-container {
		padding: 1.5rem
	}

	.message-card {
		padding: 1.25rem
	}

	.livre-dor-pagination {
		flex-wrap: wrap;
		gap: .75rem
	}
}

@media screen and (max-width:480px) {
	.livre-dor-title {
		font-size: 1.75rem;
		flex-direction: column;
		gap: .5rem
	}

	.livre-dor-description {
		font-size: 1rem
	}

	.livre-dor-form-container {
		padding: 1.25rem
	}

	.livre-dor-form-title {
		font-size: 1.25rem
	}

	.btn-submit {
		width: 100%;
		min-width: auto
	}

	.message-header {
		flex-direction: column;
		align-items: flex-start;
		gap: .25rem
	}

	.btn-pagination {
		padding: .5rem 1rem;
		font-size: .85rem
	}
}

body.ads-removed .pub-section,
body.ads-removed .pub-section-band,
body.ads-removed .ad-section,
body.ads-removed .ad-section-home-banner,
body.ads-removed .ad3-section,
body.ads-removed [id^=div-gpt-ad-] {
	display: none !important;
	height: 0 !important;
	min-height: 0 !important;
	margin: 0 !important;
	padding: 0 !important
}

body.ads-removed img:not([src=""]),
body.ads-removed picture {
	visibility: visible !important;
	opacity: 1 !important
}

body.ads-removed article>*:not([class*=ad]):not([class*=pub])+*:not([class*=ad]):not([class*=pub]) {
	margin-top: 1.5rem
}

body.ads-removed article>*:first-child {
	margin-top: 0 !important
}

body.ads-removed .content-grid>:empty,
body.ads-removed .content-flex>:empty,
body.ads-removed .grid>:empty,
body.ads-removed .flex>:empty {
	display: none !important
}

body.ads-removed *+br+*,
body.ads-removed br+br {
	margin-top: 0
}

body.ads-removed hr:first-child,
body.ads-removed hr:last-child,
body.ads-removed .divider:first-child,
body.ads-removed .divider:last-child,
body.ads-removed hr+hr {
	display: none
}

body.ads-removed .content>.banner-band+*,
body.ads-removed .content>.pub-section+* {
	margin-top: 0
}

body.ads-removed main>article:first-child,
body.ads-removed .main-content>*:first-child {
	margin-top: 0
}

/* ========================================
   Patreon Dropdown Panel
   ======================================== */

.patreon-wrapper {
	position: relative;
	display: inline-block
}

.patreon-dropdown-menu {
	position: absolute;
	top: 0;
	right: 0;
	width: 198px;
	background: #fff;
	border-radius: 27px;
	box-shadow: 0px 6px 4px rgba(0, 0, 0, 0.25);
	z-index: 10001;
	overflow: hidden;
	max-height: 53px;
	transition: max-height .3s ease;
	pointer-events: auto;
	font-family: 'Alexandria', sans-serif
}

.patreon-dropdown-menu.show {
	max-height: 200px
}

.patreon-menu-header {
	display: flex;
	align-items: center;
	min-height: 53px;
	padding: 0 11px 2px;
	background: #FF7300;
	box-sizing: border-box
}

.patreon-avatar {
	width: 40px;
	height: 40px;
	border-radius: 100px;
	object-fit: cover;
	background: #EADDFF;
	box-shadow: 0px 3px 3.1px rgba(0, 0, 0, 0.25);
	flex-shrink: 0;
	border: none
}

.patreon-user-info {
	margin-left: 4px;
	flex: 1;
	min-width: 0;
	overflow: hidden
}

.patreon-fullname {
	font-weight: 600;
	font-size: 20px;
	line-height: 24px;
	color: #fff;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap
}

.patreon-menu-logout {
	background: none;
	border: none;
	color: #fff;
	cursor: pointer;
	padding: 0;
	flex-shrink: 0
}

.patreon-menu-logout:hover {
	opacity: .8
}

.patreon-menu-logout svg {
	width: 30px;
	height: 30px;
	display: block
}

.patreon-status-bar {
	text-align: center;
	padding: 0;
	transform: translateY(-10px)
}

.patreon-status-bar .patreon-status {
	font-weight: 600;
	font-size: 12px;
	line-height: 15px;
	color: #000
}

.patreon-menu-items {
	list-style: none;
	padding: 0 4px 8px;
	margin: 0
}

.patreon-menu-items li {
	margin: 0 0 2px;
	transform: translateY(-10px)
}

.patreon-menu-items li:last-child {
	margin-bottom: 0
}

.patreon-menu-items a {
	display: flex;
	align-items: center;
	height: 35px;
	padding: 0 10px;
	box-sizing: border-box;
	text-decoration: none;
	color: #000;
	border-radius: 4px;
	font-weight: 600;
	font-size: 16px;
	line-height: 1;
	white-space: nowrap;
	transition: background .2s
}

.patreon-menu-items a:hover {
	background: #EDEDED
}

.patreon-menu-items a svg {
	width: 30px;
	height: 30px;
	flex-shrink: 0;
	margin-left: -6px
}

#patreon-login-button.logged-in,
.cta-button.logged-in {
	background: var(--button-primary-background, #ff7b10) !important;
	color: var(--button-primary-foreground, #fff) !important;
	font-weight: 600 !important;
	border: none !important;
	box-shadow: 0 2px 4px rgba(255, 123, 16, .3) !important;
	transition: all .3s ease !important;
	padding: .5rem 1.25rem !important;
	cursor: pointer !important
}

#patreon-login-button.logged-in:hover,
.cta-button.logged-in:hover {
	background: var(--button-primary-background, #ff7b10) !important;
	transform: none !important;
	box-shadow: 0 2px 4px rgba(255, 123, 16, .3) !important
}

@keyframes voxdrop-slideDown {
  from {
    max-height:0;
    opacity:0
  }
  to {
    max-height:4rem;
    opacity:1
  }
}
@keyframes voxdrop-slideUp {
  from {
    max-height:4rem;
    opacity:1
  }
  to {
    max-height:0;
    opacity:0
  }
}
#voxdrop-banner {
  display:none;
  overflow:hidden
}
#voxdrop-banner.voxdrop-banner--visible {
  display:block;
  animation:voxdrop-slideDown .4s ease forwards
}
#voxdrop-banner.voxdrop-banner--hiding {
  animation:voxdrop-slideUp .3s ease forwards
}
.voxdrop-banner__inner {
  display:flex;
  align-items:center;
  justify-content:center;
  gap:1rem;
  padding:.5rem 1rem;
  background:linear-gradient(135deg,#1a1a2e 0%,#16213e 50%,#0f3460 100%);
  color:#f0f0f0;
  font-size:.9rem;
  line-height:1.4
}
.voxdrop-banner__icon {
  font-size:1.1em
}
.voxdrop-banner__typed {
  display:inline
}
.voxdrop-banner__text {
  white-space:nowrap
}
.voxdrop-banner__text strong {
  color:#fff
}
.voxdrop-banner__cta {
  display:inline-block;
  padding:.25rem .75rem;
  background:#e94560;
  color:#fff !important;
  border-radius:4px;
  text-decoration:none;
  font-size:.85rem;
  font-weight:600;
  white-space:nowrap;
  transition:background .2s ease
}
.voxdrop-banner__cta:hover {
  background:#c73650;
  text-decoration:none
}
.voxdrop-banner__close {
  background:0 0;
  border:none;
  color:#f0f0f0;
  font-size:1.3rem;
  cursor:pointer;
  padding:0 .3rem;
  line-height:1;
  opacity:.7;
  transition:opacity .2s ease
}
.voxdrop-banner__close:hover {
  opacity:1
}
@media(max-width:640px) {
  .voxdrop-banner__inner {
    flex-wrap:wrap;
    gap:.4rem;
    padding:.5rem .75rem;
    font-size:.8rem
  }
  .voxdrop-banner__text {
    white-space:normal;
    text-align:center;
    flex:1 1 100%
  }
  .voxdrop-banner__close {
    position:absolute;
    top:.25rem;
    right:.5rem
  }
  #voxdrop-banner .voxdrop-banner__inner {
    position:relative;
    padding-right:2rem
  }
}
