/* =============================================================
	 H U B   G L O B A L   T H E M E
	 Paleta (Opção B ajustada): Azul primário sóbrio (#1f4d92), Vermelho secundário (#7c1620), Destaque (#ffc107)
	 Estrutura de tokens para facilitar evolução (dark mode, branding futuro)
============================================================= */
:root{
	/* Cores principais */
		/* Nova hierarquia: azul como primário de UI, vermelho como secundário */
			--color-primary:#1f4d92;          /* primário (interação) azul mais sóbrio */
			--color-primary-rgb:31,77,146;
			--color-primary-50:#e8eff7;
			--color-primary-100:#d4e0f0;
			--color-primary-200:#b0c8e4;
			--color-primary-300:#88add7;
			--color-primary-400:#5a8cc5;
			--color-primary-500:#3d6faa;
			--color-primary-600:#2f5c98;
			--color-primary-700:#1f4d92; /* base */
			--color-primary-800:#183d74;
			--color-primary-900:#122c53;
		--color-secondary:#7c1620;        /* acento institucional / ênfase */
		--color-secondary-rgb:124,22,32;
			--color-accent:var(--color-primary);  /* alias para compat */
			--color-accent-rgb:var(--color-primary-rgb);
		--color-highlight:#ffc107;        /* destaque / badges / ênfase */
		/* Escala secundária (vermelho suavizado) */
		--color-secondary-50:#fbecee;
		--color-secondary-100:#f8e2e3;
		--color-secondary-200:#efcdcf;
		--color-secondary-300:#e3a7ab;
		--color-secondary-400:#cf7b82;
		--color-secondary-500:#b9545c;
		--color-secondary-600:#9d3a43;
		--color-secondary-700:#7c1620;
		--color-secondary-800:#640f18;
		--color-secondary-900:#470a10;
	/* Neutros / superfícies */
	--color-bg:#faf9f9;
	--color-bg-alt:#ffffff;
	--color-surface:#ffffff;
	--color-border:#e3e3e3;
	--color-border-subtle:#ececec;
	--color-shadow-rgb:0,0,0;
	--color-text:#222;
	--color-text-soft:#555;
	--color-text-faint:#777;
	--color-inverse:#ffffff;
	--color-focus-outline:rgba(60,129,246,.55);
	color-scheme: light;
	/* Estados */
	--color-success:#1b8e3e;
	--color-danger:#b32020;
	--color-warning:#ffc107;
	--color-info:#3c81f6;
	/* Tipografia */
	--font-stack:system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,sans-serif;
	--font-size-xs:.62rem;
	--font-size-sm:.72rem;
	--font-size-base:.9rem;
	--font-size-md:1rem;
	--font-size-lg:1.18rem;
	--font-size-xl:1.42rem;
	--line-height-tight:1.15;
	--line-height-base:1.35;
	/* Espaçamento (8pt scale adaptada) */
	--space-1:.25rem;
	--space-2:.5rem;
	--space-3:.75rem;
	--space-4:1rem;
	--space-5:1.25rem;
	--space-6:1.75rem;
	--radius-xs:6px;
	--radius-sm:8px;
	--radius-md:12px;
	--radius-lg:16px;
	--radius-pill:999px;
	--radius-round:50%;
	/* Sombra */
	--shadow-sm:0 1px 2px rgba(var(--color-shadow-rgb),.06),0 0 0 1px rgba(var(--color-shadow-rgb),.03);
	--shadow-md:0 2px 6px -1px rgba(var(--color-shadow-rgb),.12),0 1px 3px rgba(var(--color-shadow-rgb),.08);
	--shadow-lg:0 4px 18px -3px rgba(var(--color-shadow-rgb),.18),0 3px 8px rgba(var(--color-shadow-rgb),.08);
	/* Transições */
	--transition-fast:.15s cubic-bezier(.4,0,.2,1);
	--transition-base:.25s cubic-bezier(.4,0,.2,1);
}

@media (prefers-color-scheme: dark){
	html[data-theme="dark"],
	html[data-theme="system"]{
		--color-bg:#0f1113;
		--color-bg-alt:#161a1d;
		--color-surface:#181c20;
		--color-border:#2a3036;
		--color-border-subtle:#20262b;
		--color-text:#e8ecf1;
		--color-text-soft:#aeb7c1;
		--color-text-faint:#88919b;
		--color-shadow-rgb:0,0,0;
		--color-focus-outline:rgba(255,193,7,.55);
		color-scheme: dark;
	}
}

body{margin:0;font-family:var(--font-stack);background:var(--color-bg);color:var(--color-text);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
/* Acessibilidade básica */
*:focus-visible{outline:3px solid var(--color-focus-outline);outline-offset:2px}
::selection{background:var(--color-accent);color:var(--color-inverse)}
.sr-only{position:absolute!important;width:1px!important;height:1px!important;padding:0!important;margin:-1px!important;overflow:hidden!important;clip:rect(0,0,0,0)!important;white-space:nowrap!important;border:0!important}
a{color:var(--color-accent);text-decoration:none;transition:var(--transition-fast)}
a:hover{color:var(--color-primary-500);text-decoration:underline}
a:active{color:var(--color-primary-600)}

.skip-link{position:absolute;left:-999px;top:auto;width:1px;height:1px;overflow:hidden}
.skip-link:focus{left:8px;top:8px;width:auto;height:auto;background:var(--color-accent);color:var(--color-inverse);padding:.6rem 1rem;border-radius:var(--radius-sm);z-index:999;box-shadow:var(--shadow-md)}
.container{max-width:1100px;margin:0 auto;padding:0 18px}
.site-header{background:var(--color-surface);border-bottom:1px solid var(--color-border-subtle);position:sticky;top:0;z-index:1100;backdrop-filter:saturate(180%) blur(10px);-webkit-backdrop-filter:saturate(180%) blur(10px)}
.header-inner{display:flex;align-items:center;gap:2rem;padding:.8rem 0}
.nav-toggle{display:none;margin-left:auto;background:transparent;border:1px solid var(--color-border);color:var(--color-text);padding:.45rem .55rem;border-radius:10px;cursor:pointer;position:relative;z-index:110}
.brand{display:flex;align-items:center;gap:.6rem;font-weight:800;font-size:var(--font-size-md);text-decoration:none;color:var(--color-primary);letter-spacing:.5px}
.nav-list{list-style:none;display:flex;align-items:center;gap:1rem;margin:0;padding:0}
.nav-list a{display:block;padding:.75rem 1.15rem;border-radius:var(--radius-lg);text-decoration:none;font-weight:600;color:#111;background:rgba(var(--color-primary-rgb),.10);transition:var(--transition-fast);font-size:var(--font-size-base);line-height:1.05}
.nav-list a:hover{background:rgba(var(--color-primary-rgb),.18);color:#000}
.nav-list a[aria-current=page]{background:rgba(var(--color-primary-rgb),.28);color:#000;box-shadow:0 0 0 1px rgba(var(--color-primary-rgb),.35)}
.nav-cta{background:linear-gradient(45deg,var(--color-primary),var(--color-accent)) !important;color:var(--color-inverse) !important;box-shadow:0 4px 14px -4px rgba(var(--color-primary-rgb),.55)}
.has-submenu{position:relative}
.has-submenu .submenu{display:none;position:absolute;top:100%;left:0;background:var(--color-surface);border:1px solid var(--color-border);border-radius:18px;padding:1rem;min-width:220px;list-style:none;box-shadow:var(--shadow-lg)}
.has-submenu:hover .submenu{display:block}
.has-submenu .submenu a{background:transparent;padding:.55rem .75rem;border-radius:10px;color:#222;transition:var(--transition-fast)}
.has-submenu .submenu a:hover{background:rgba(var(--color-primary-rgb),.10);color:#000}
.has-submenu .submenu a[aria-current=page]{background:rgba(var(--color-primary-rgb),.12);color:var(--color-primary)}
.badge{display:inline-block;background:var(--color-border-subtle);border-radius:var(--radius-xs);padding:.2rem .5rem;font-size:var(--font-size-xs);font-weight:600;letter-spacing:.06em;text-transform:uppercase;margin-right:4px;color:var(--color-text-soft)}
.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:1rem 1.1rem;margin:.9rem 0;box-shadow:var(--shadow-sm);transition:var(--transition-base);position:relative;overflow:hidden}
.card:before{content:"";position:absolute;inset:0;pointer-events:none;opacity:0;background:radial-gradient(circle at 20% 15%,rgba(var(--color-primary-rgb),.10),transparent 60%);transition:var(--transition-fast)}
.card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}
.card:hover:before{opacity:1}
.card .title{font-weight:700;display:block;color:var(--color-text);margin:.3rem 0 .2rem;text-decoration:none;font-size:.95rem}
.card .title:hover{ text-decoration:none }
.filters{display:flex;flex-wrap:wrap;gap:.5rem;margin:1.2rem 0}
.filters input[type=search], .filters select{padding:.55rem .65rem;border:1px solid #d5d5d5;border-radius:10px;font-size:.9rem}
.filters button{background:var(--color-primary);color:var(--color-inverse);border:1px solid var(--color-primary);font-weight:600;padding:.6rem 1rem;border-radius:10px;cursor:pointer;box-shadow:0 2px 8px -2px rgba(var(--color-primary-rgb),.4);transition:var(--transition-fast)}
.filters button:hover{background:var(--color-primary-600);border-color:var(--color-primary-600)}
.filters button:focus-visible{outline:3px solid var(--color-focus-outline);outline-offset:2px}
.count{font-size:.72rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--color-text-soft);margin:.5rem 0 1rem}
.site-footer{margin:3rem 0 0;background:linear-gradient(135deg,#14181c,#101214 55%);color:#cfd5dd;font-size:.85rem}
.footer-main{padding:2rem 0}
.footer-grid{display:grid;grid-template-columns:2fr 1.7fr 1.2fr;gap:1.8rem;align-items:flex-start}
@media (max-width:900px){.footer-grid{grid-template-columns:1fr;gap:1.2rem}}
.footer-brand .brand{color:#e8ecf2;gap:.8rem}
.footer-brand .logo{width:44px;height:44px;border-radius:10px;box-shadow:0 2px 6px rgba(0,0,0,.25)}
.footer-brand .brand-text .name{font-weight:800;letter-spacing:.2px;line-height:1.2}
.footer-brand .brand-text .microcopy{color:#a9b4c0;font-size:.9em;margin-top:.25rem}
.footer-links{display:flex;flex-direction:column;gap:.6rem}
.footer-links .links-row{display:flex;flex-wrap:wrap;gap:.75rem 1rem;list-style:none;margin:0;padding:0}
.footer-links a{color:#d8dee6;text-decoration:none;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);padding:.4rem .6rem;border-radius:10px;font-weight:600;transition:var(--transition-fast)}
.footer-links a:hover{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.14);color:#fff}
.footer-cta{display:flex;flex-direction:column;gap:.6rem;align-items:flex-start}
.footer-cta .cta{display:inline-flex;align-items:center;gap:.45rem;background:linear-gradient(45deg,var(--color-primary),var(--color-accent));color:#fff;padding:.6rem .85rem;border-radius:12px;font-weight:800;letter-spacing:.2px;box-shadow:0 6px 18px -6px rgba(var(--color-primary-rgb),.6);text-decoration:none;border:1px solid rgba(255,255,255,.15)}
.footer-cta .cta:hover{filter:brightness(1.04)}
.footer-social{display:flex;align-items:center;gap:.6rem}
.footer-social .icon{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:10px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);color:#e8ecf2;transition:var(--transition-fast)}
.footer-social .icon:hover{background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.2);color:#fff;text-decoration:none}
.footer-bottom{border-top:1px solid rgba(255,255,255,.08);padding:1rem 0 .9rem}
.fine-print{display:flex;flex-wrap:wrap;gap:.6rem .8rem;align-items:center;color:#a9b4c0}
.fine-print a{color:#d8dee6;text-decoration:none}
.fine-print a:hover{text-decoration:underline;color:#fff}

/* HERO BANNER HUB */
.hub-hero{background:var(--color-surface);border-bottom:1px solid var(--color-border-subtle)}
.hub-hero-inner{width:100%;max-width:1100px;margin:0 auto;padding:0 18px}
.hub-hero-img{width:100%;height:auto;display:block;border-radius:16px;margin:12px 0 4px;box-shadow:0 3px 10px -2px rgba(var(--color-shadow-rgb),.25);outline:1px solid rgba(var(--color-primary-rgb),.15)}
@media (max-width:680px){.hub-hero-img{border-radius:14px;margin:10px 0 2px}}
@media (max-width:1280px){
	.hub-hero-img{max-height:none !important;height:auto !important;aspect-ratio:auto !important;object-fit:contain !important}
}

/* Ícone CONHEÇA */
.icon-conheca svg{width:18px;height:18px;stroke:currentColor}

/* === HUB LISTING LAYOUT (centralizado) ================================= */
.list{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin:1.2rem 0 1.4rem;padding:0}
@media (max-width:1000px){.list{grid-template-columns:repeat(2,1fr);} }
@media (max-width:640px){.list{grid-template-columns:1fr;} }
.card{border:1px solid var(--color-border);border-radius:14px;padding:.8rem 1rem;background:var(--color-surface);display:flex;flex-direction:column;gap:.5rem;box-shadow:var(--shadow-sm)}
.card .meta{font-size:.65rem;display:flex;flex-wrap:wrap;gap:.35rem .4rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase}
.card .badge{background:rgba(var(--color-primary-rgb),.12);color:var(--color-primary);padding:.25rem .6rem;border-radius:999px;font-weight:600}
.card .badge-secondary{background:var(--color-secondary-100);color:var(--color-secondary-700)}
.card .badge-axis{max-width:130px;display:inline-block;overflow:hidden;text-overflow:ellipsis;vertical-align:middle;white-space:nowrap;}
@media (max-width:1000px){.card .badge-axis{max-width:100px}}
@media (max-width:640px){.card .badge-axis{max-width:160px}}
.card a.title{font-weight:700;font-size:.92rem;line-height:1.25;text-decoration:none;color:var(--color-text)}
.card a.title:hover{color:var(--color-primary)}
.card .authors{font-size:.66rem;line-height:1.25;color:var(--color-text-soft);font-weight:500;margin-top:.15rem;max-height:2.5em;overflow:hidden;position:relative}
.card .cta{margin-top:auto;display:inline-flex;align-items:center;gap:.3rem;font-size:.58rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;background:var(--color-primary);color:var(--color-inverse);padding:.45rem .7rem;border-radius:8px;text-decoration:none;box-shadow:0 2px 8px -2px rgba(var(--color-primary-rgb),.55);transition:var(--transition-fast)}
.card .cta:hover{background:var(--color-primary-600)}

/* Paginação */
.pagination{display:flex;flex-wrap:wrap;gap:.4rem;align-items:center;font-size:.7rem;margin:.5rem 0 1.6rem}
.pagination a,.pagination span{padding:.45rem .7rem;border:1px solid var(--color-border);border-radius:8px;text-decoration:none;font-weight:600;letter-spacing:.04em;background:var(--color-surface);color:var(--color-text-soft);transition:var(--transition-fast)}
.pagination .current{background:var(--color-primary);color:var(--color-inverse);border-color:var(--color-primary);box-shadow:0 0 0 1px rgba(var(--color-primary-rgb),.4)}
.pagination a:hover{background:rgba(var(--color-primary-rgb),.09);color:var(--color-primary)}
.pagination .disabled{opacity:.35;cursor:not-allowed}

/* Like button (listagens + detalhe) */
.like-btn{--_bg:var(--color-surface);--_bd:var(--color-border);--_ink:var(--color-text-soft);--_ink-active:var(--color-inverse);--_accent:var(--color-accent);--_accent-hover:var(--color-primary-600);--_accent-active:var(--color-primary-700);display:inline-flex;align-items:center;gap:.35rem;padding:.34rem .55rem .34rem .5rem;border:1px solid var(--_bd);background:var(--_bg);border-radius:var(--radius-pill);font-size:.58rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;cursor:pointer;line-height:1;color:var(--_ink);transition:var(--transition-fast)}
.like-btn .icon{display:inline-flex;align-items:center;justify-content:center;width:14px;height:14px}
.like-btn .icon svg{width:14px;height:14px;stroke:currentColor}
.like-btn .label{opacity:.78}
.like-btn .count{font-weight:700;font-size:.6rem;letter-spacing:.05em;padding-left:.05rem;display:none}
.like-btn.is-liked{background:var(--_accent);border-color:var(--_accent);color:var(--_ink-active);animation:none!important;transform:none!important}
.like-btn.is-liked .label{opacity:.95}
.like-btn:hover{background:rgba(var(--color-accent-rgb),.12)}
.like-btn.is-liked:hover{background:var(--_accent-hover)}
.like-btn:focus-visible{outline:3px solid var(--color-focus-outline);outline-offset:2px}
.like-btn[disabled]{opacity:.6;cursor:default}
.like-btn.loading{opacity:.6}

/* CONHEÇA TAMBÉM (component base) */
.conheca-box{background:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;padding:16px 18px;margin:28px 0 24px;box-shadow:var(--shadow-sm);position:relative;overflow:hidden}
.conheca-box:before{content:"";position:absolute;inset:0;pointer-events:none;background:linear-gradient(145deg,rgba(var(--color-primary-rgb),.07),transparent 55%)}
.conheca-box h2{margin:0 0 .75rem;font-size:1.1rem;letter-spacing:.02em;font-weight:600;color:var(--color-primary);display:flex;align-items:center;gap:.4rem}
.conheca-box{transition:background-color var(--transition-fast), border-color var(--transition-fast)}
.conheca-box a{display:block;text-decoration:none !important}
/* Evitar sublinhado no hover/focus dentro do box; preferir mudança de fundo do box */
.conheca-box a:hover{ text-decoration:none !important }
.conheca-box a:focus{ text-decoration:none !important }
.conheca-box a:hover .conheca-main{ text-decoration:none !important }
.conheca-box:hover{ background:var(--color-border-subtle) }
.conheca-main{font-size:.95rem;font-weight:600;line-height:1.3;color:var(--color-text)}
.conheca-authors{display:block;font-size:.68rem;letter-spacing:.03em;text-transform:uppercase;color:var(--color-text-soft);margin-top:.25rem}
.conheca-meta{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.55rem}
.conheca-meta .badge{background:rgba(var(--color-primary-rgb),.12);color:var(--color-primary);padding:.25rem .6rem;border-radius:999px;font-size:.55rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase}
.conheca-meta .badge-secondary{background:var(--color-secondary-100);color:var(--color-secondary-700)}
/* Ensure badge links keep badge look (no underline) */
a.badge{display:inline-block;text-decoration:none}
a.badge:hover, a.badge:focus{ text-decoration:none }
@media (prefers-color-scheme: dark){
	html[data-theme="dark"] .conheca-box,
	html[data-theme="system"] .conheca-box{background:#111417;border-color:#2a2f36}
	html[data-theme="dark"] .conheca-main,
	html[data-theme="system"] .conheca-main{color:#e8ecf2}
	html[data-theme="dark"] .conheca-authors,
	html[data-theme="system"] .conheca-authors{color:#96a0ad}
}

/* Type badges (section labels) */
.badge-type{display:inline-block;padding:.25rem .6rem;border-radius:999px;font-size:.58rem;font-weight:800;letter-spacing:.06em;text-transform:uppercase;background:var(--color-border-subtle);color:var(--color-text-soft);text-decoration:none}
.badge-type:hover,.badge-type:focus{ text-decoration:none }
.badge-type-anais{background:rgba(var(--color-primary-rgb),.12);color:var(--color-primary)}
.badge-type-revista{background:#e6f2ff;color:#0b63b6}
.badge-type-capitulo{background:#e5f5ea;color:#1b8e3e}
.badge-type-resumo{background:#fff4e0;color:#c47a00}
.badge-type-video{background:#f6e6ef;color:#8a1f4d}
.card .badge-type{margin-right:.4rem}

/* Back to Top button (site-wide) */
.back-to-top{position:fixed;right:18px;bottom:24px;width:46px;height:46px;display:flex;align-items:center;justify-content:center;border-radius:50%;border:1px solid var(--color-border);background:var(--color-primary);color:var(--color-inverse);box-shadow:var(--shadow-lg);font-weight:800;font-size:1.1rem;cursor:pointer;opacity:0;visibility:hidden;transform:translateY(8px);transition:var(--transition-base);z-index:999}
.back-to-top:hover{background:var(--color-primary-600);text-decoration:none}
.back-to-top.show{opacity:1;visibility:visible;transform:translateY(0)}
.back-to-top .btp-icon svg{display:block;width:26px;height:26px}
@media (max-width:720px){.back-to-top{right:12px;bottom:18px;width:42px;height:42px;font-size:1rem}.back-to-top .btp-icon svg{width:24px;height:24px}}
@media (prefers-reduced-motion: reduce){.back-to-top{transition:none}}

/* Desktop defaults for navs */
.primary-nav{display:block}
.mobile-nav{display:none}

/* Mobile navigation (hamburger) */
@media (max-width: 820px){
	.header-inner{gap:1rem}
	.nav-toggle{display:inline-flex;align-items:center;justify-content:center}
	/* hide desktop nav in mobile */
	.primary-nav{display:none}
	/* separate mobile nav panel */
	.mobile-nav{display:none;position:fixed;left:0;right:0;bottom:0;background:var(--color-surface);border-top:1px solid var(--color-border-subtle);box-shadow:0 -8px 24px -10px rgba(0,0,0,.25);transform:translateY(100%);transition:transform var(--transition-base);z-index:1000;max-height:75vh;overflow:auto;-webkit-overflow-scrolling:touch}
	.mobile-nav.open{display:block;transform:translateY(0)}
	.mobile-nav .nav-list{flex-direction:column;align-items:stretch;gap:.25rem;padding:.6rem;margin:0}
	.mobile-nav .nav-list a{background:transparent;border-radius:12px;padding:.85rem 1rem}
	.mobile-nav .nav-list a:hover{background:rgba(var(--color-primary-rgb),.08)}
	.mobile-nav .has-submenu{position:static}
	.mobile-nav .has-submenu > a{display:flex;align-items:center;justify-content:space-between}
	.mobile-nav .has-submenu .submenu{position:static;display:none;border:0;box-shadow:none;padding:.25rem 0;margin:.25rem 0 0;min-width:0}
	.mobile-nav .has-submenu.open .submenu{display:block}
	/* backdrop */
	.nav-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.35);backdrop-filter:saturate(140%) blur(2px);-webkit-backdrop-filter:saturate(140%) blur(2px);z-index:900}
	.nav-backdrop[hidden]{display:none !important;opacity:0 !important;visibility:hidden !important}
}

/* Prevent filter/search overflow on small screens */
.page .filters{max-width:100%}
.page .filters input[type="search"],
.page .filters select{min-width:0;max-width:100%}
@media (max-width: 820px){
	.page .filters{grid-template-columns:1fr !important}
	.page .filters input[type="search"],
	.page .filters select,
	.page .filters button{width:100%;min-width:0;box-sizing:border-box}
	.page .filters > div{display:flex;flex-wrap:wrap;width:100%;min-width:0}
}
@media (max-width: 480px){
	.page .filters{grid-template-columns:1fr !important}
	.page .filters > div{display:flex;flex-wrap:wrap}
	.page .filters input[type="search"]{width:100%}
}
.page form.search input[type="search"]{min-width:0;width:100%}
@media (max-width: 480px){
	.page form.search{grid-template-columns:1fr !important}
	.page form.search > div{display:flex;flex-wrap:wrap}
}
@media (max-width: 820px){
	.page form.search{grid-template-columns:1fr !important}
	.page form.search > div{display:flex;flex-wrap:wrap;width:100%;min-width:0}
	.page form.search input[type="search"]{width:100%;min-width:0}
}

/* ======= Policy page (Políticas) ======= */
.policy-page{--_col-gap:1.8rem;--_toc-w:280px}
.policy-header{margin:1.4rem 0 1rem}
.policy-header .lead{color:var(--color-text-soft);max-width:65ch;margin:.3rem 0 0}
.policy-layout{display:grid;grid-template-columns:var(--_toc-w) 1fr;gap:var(--_col-gap);align-items:start}
.policy-toc{position:sticky;top:84px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;padding:1rem;box-shadow:var(--shadow-sm)}
.policy-toc .toc-title{font-weight:800;font-size:.8rem;letter-spacing:.05em;text-transform:uppercase;color:var(--color-text-soft);margin:0 0 .5rem}
.policy-toc .toc-list{margin:0;padding-left:1rem}
.policy-toc a{color:var(--color-text);text-decoration:none}
.policy-toc a:hover{text-decoration:underline}
.policy-toc ol{margin:.2rem 0 .4rem;padding-left:1rem}
.policy-toc .toc-tip{margin-top:.6rem;font-size:.78rem;color:var(--color-text-soft)}
.policy-content{background:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;padding:1.1rem 1.25rem;box-shadow:var(--shadow-sm)}
.policy-content h2{scroll-margin-top:84px;margin:1rem 0 .35rem}
.policy-content h3{scroll-margin-top:84px;margin:.9rem 0 .25rem}
.policy-content p{line-height:1.6}
.policy-content ul, .policy-content ol{padding-left:1.2rem}
.policy-content li{margin:.25rem 0}
.policy-content a{color:var(--color-accent)}
.policy-content a:hover{color:var(--color-primary)}
.policy-content .toc-mobile{display:none;border:1px solid var(--color-border);border-radius:10px;padding:.6rem .8rem;background:var(--color-surface);margin:0 0 1rem}
.policy-content details > summary{cursor:pointer;font-weight:700}
@media (max-width: 980px){
	.policy-layout{grid-template-columns:1fr}
	.policy-toc{display:none}
	.policy-content .toc-mobile{display:block}
}
@media (prefers-color-scheme: dark){
	html[data-theme="dark"] .policy-toc,
	html[data-theme="system"] .policy-toc,
	html[data-theme="dark"] .policy-content,
	html[data-theme="system"] .policy-content{background:#12161a;border-color:#2a3036}
}

/* Hardening: desktop visibility to avoid duplicates */
@media (min-width: 981px){
	.policy-content .toc-mobile{display:none !important}
	.policy-toc{display:block !important}
	.nav-toggle{display:none !important}
	.policy-content{background:transparent;border:none;box-shadow:none;padding:0}
}

/* Utilities to force per-breakpoint display */
.only-desktop{display:block}
.only-mobile{display:none}
@media (max-width: 980px){
	.only-desktop{display:none !important}
	.only-mobile{display:block !important}
}

/* Collapsible policy boxes */
.policy-box{border:1px solid var(--color-border);border-radius:12px;padding:.4rem .75rem .85rem;margin:1rem 0;background:var(--color-surface);box-shadow:var(--shadow-sm)}
.policy-box > summary{list-style:none;display:flex;align-items:center;gap:.5rem;font-weight:800;letter-spacing:.02em;font-size:1.05rem;padding:.4rem 0;cursor:pointer}
.policy-box > summary::-webkit-details-marker{display:none}
.policy-box > summary:after{content:'\25B8';margin-left:auto;color:var(--color-text-soft);transition:transform var(--transition-fast)}
.policy-box[open]{box-shadow:var(--shadow-md)}
.policy-box[open] > summary:after{transform:rotate(90deg)}
.policy-box > *:not(summary){margin-left:.1rem}
.policy-box h3{margin-top:.6rem}
