/*
Theme Name: novexarium
Theme URI: https://novexarium.com
Description: Portal de análise e ranking de jogos de construção para Android (Google Play). Conceito visual "blueprint / estaleiro": sínteses técnicas, grelha de projeto e fichas de obra. Estrutura modelada num portal de afiliados, com design e conteúdo próprios.
Author: novexarium
Version: 1.0.0
Requires at least: 6.0
Requires PHP: 7.4
License: GNU General Public License v2 or later
Text Domain: novexarium
*/

/* =========================================================================
   novexarium — "Blueprint / Estaleiro"
   Deep blueprint navy + cyan drafting grid + hi-vis safety orange.
   Archivo (display) + IBM Plex Mono (technical labels / numbers).
   ========================================================================= */

:root{
	--navy:#0a1430;          /* page background */
	--navy-2:#0d1b3e;        /* panels */
	--navy-3:#102451;        /* raised */
	--line:#21356e;          /* structural lines */
	--grid:rgba(86,128,214,.13);
	--grid-strong:rgba(86,128,214,.26);
	--ink:#eaf0ff;           /* main text */
	--muted:#93a6d4;         /* secondary text */
	--faint:#6276a8;         /* tertiary */
	--accent:#ff5b1f;        /* hi-vis safety orange */
	--accent-2:#36b6ff;      /* blueprint cyan */
	--ok:#37d399;
	--maxw:1180px;
	--r:4px;
	--mono:"IBM Plex Mono",ui-monospace,SFMono-Regular,Menlo,monospace;
	--sans:"Archivo",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
	margin:0;
	font-family:var(--sans);
	color:var(--ink);
	background-color:var(--navy);
	background-image:
		linear-gradient(var(--grid) 1px,transparent 1px),
		linear-gradient(90deg,var(--grid) 1px,transparent 1px),
		linear-gradient(var(--grid-strong) 1px,transparent 1px),
		linear-gradient(90deg,var(--grid-strong) 1px,transparent 1px);
	background-size:28px 28px,28px 28px,140px 140px,140px 140px;
	background-position:-1px -1px,-1px -1px,-1px -1px,-1px -1px;
	line-height:1.65;
	font-size:17px;
	-webkit-font-smoothing:antialiased;
	overflow-x:hidden;
}
a{color:inherit}
img{max-width:100%;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}

::selection{background:var(--accent);color:#fff}

/* ---- mono label / technical text ---- */
.mono,.kicker,.sect-no,.coords,.card-rank,.stars,.titleblock,.tags span,.count,.note,.date{
	font-family:var(--mono);
}

/* ---- skip link ---- */
.skip{position:absolute;left:-9999px;top:0;background:var(--accent);color:#fff;padding:10px 16px;z-index:100}
.skip:focus{left:8px;top:8px}

/* =========================================================================
   Header
   ========================================================================= */
.topbar{
	border-bottom:1px solid var(--line);
	background:rgba(10,20,48,.7);
	font-family:var(--mono);
	font-size:11.5px;
	letter-spacing:.14em;
	text-transform:uppercase;
	color:var(--faint);
}
.topbar .wrap{display:flex;justify-content:space-between;gap:18px;padding-top:8px;padding-bottom:8px;flex-wrap:wrap}
.topbar b{color:var(--accent-2);font-weight:600}

.site-head{position:sticky;top:0;z-index:50;background:rgba(10,20,48,.86);backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.brand-row{display:flex;align-items:center;gap:20px;padding:16px 0}
.brand{
	display:inline-flex;align-items:center;gap:12px;
	font-weight:900;font-size:24px;letter-spacing:-.02em;text-decoration:none;color:var(--ink);
	text-transform:lowercase;
}
.brand .mark{
	width:30px;height:30px;flex:0 0 auto;border:2px solid var(--accent);position:relative;border-radius:3px;
	background:
		linear-gradient(45deg,transparent 46%,var(--accent) 46%,var(--accent) 54%,transparent 54%),
		linear-gradient(-45deg,transparent 46%,var(--accent-2) 46%,var(--accent-2) 54%,transparent 54%);
}
.brand .dom{color:var(--faint);font-family:var(--mono);font-size:12px;font-weight:500;letter-spacing:.05em}

.nav{margin-left:auto;display:flex;gap:6px;flex-wrap:wrap;align-items:center}
.nav a{
	text-decoration:none;color:var(--muted);font-weight:600;font-size:14.5px;
	padding:8px 13px;border-radius:var(--r);letter-spacing:.01em;transition:.15s;
}
.nav a:hover{color:var(--ink);background:var(--navy-3)}
.menu-toggle{
	display:none;margin-left:auto;background:var(--navy-3);color:var(--ink);border:1px solid var(--line);
	font-family:var(--mono);font-size:12px;letter-spacing:.12em;text-transform:uppercase;padding:9px 14px;border-radius:var(--r);cursor:pointer;
}

/* =========================================================================
   Buttons
   ========================================================================= */
.btn{
	display:inline-flex;align-items:center;gap:8px;
	background:var(--accent);color:#fff;text-decoration:none;font-weight:800;
	font-size:14.5px;padding:11px 18px;border-radius:var(--r);border:1px solid var(--accent);
	letter-spacing:.01em;transition:.15s;white-space:nowrap;
}
.btn:hover{background:#ff7340;border-color:#ff7340;transform:translateY(-1px)}
.btn--lg{padding:14px 24px;font-size:16px}
.btn--ghost{background:transparent;color:var(--ink);border:1px solid var(--line)}
.btn--ghost:hover{background:var(--navy-3);border-color:var(--accent-2);color:#fff;transform:none}

/* =========================================================================
   Hero
   ========================================================================= */
.hero{position:relative;padding:clamp(48px,8vw,104px) 0 clamp(34px,5vw,56px);border-bottom:1px solid var(--line)}
.hero .wrap{display:grid;grid-template-columns:1.15fr .85fr;gap:48px;align-items:center}
.kicker{
	color:var(--accent-2);font-size:12.5px;letter-spacing:.22em;text-transform:uppercase;margin:0 0 18px;
	display:inline-flex;align-items:center;gap:10px;
}
.kicker::before{content:"";width:26px;height:0;border-top:2px dashed var(--accent)}
.hero h1{
	font-size:clamp(34px,5.4vw,62px);line-height:1.02;font-weight:900;letter-spacing:-.02em;margin:0 0 22px;
}
.hero h1 em{color:var(--accent);font-style:normal}
.lede{font-size:clamp(16px,1.5vw,19px);color:var(--muted);max-width:52ch;margin:0 0 30px}
.hero .cta-row{display:flex;gap:12px;flex-wrap:wrap}

.readout{
	margin-top:34px;display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);
	border:1px solid var(--line);border-radius:var(--r);overflow:hidden;font-family:var(--mono);
}
.readout .cell{background:var(--navy-2);padding:16px 14px}
.readout .n{display:block;font-size:24px;font-weight:600;color:var(--accent-2)}
.readout .t{font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--faint)}

/* blueprint "sheet" framing a hero screenshot */
.sheet{
	position:relative;border:1px solid var(--line);background:var(--navy-2);padding:14px;border-radius:var(--r);
}
.sheet::before{
	content:attr(data-tag);position:absolute;top:-1px;left:18px;transform:translateY(-50%);
	background:var(--navy);color:var(--accent-2);font-family:var(--mono);font-size:11px;letter-spacing:.14em;
	text-transform:uppercase;padding:2px 9px;border:1px solid var(--line);border-radius:3px;
}
.sheet img{border-radius:3px;width:100%;height:auto;aspect-ratio:16/10;object-fit:cover;filter:saturate(1.02)}
.sheet .scale{
	margin-top:10px;height:0;border-top:1px dashed var(--line);position:relative;
}
.sheet .scale span{
	position:absolute;top:-8px;font-family:var(--mono);font-size:10px;color:var(--faint);letter-spacing:.1em;
}
.sheet .scale span:nth-child(1){left:0}
.sheet .scale span:nth-child(2){left:50%;transform:translateX(-50%)}
.sheet .scale span:nth-child(3){right:0}

/* =========================================================================
   Sections
   ========================================================================= */
.sect{padding:clamp(46px,6vw,78px) 0;border-bottom:1px solid var(--line)}
.sect--tight{padding:clamp(34px,4.5vw,56px) 0}
.sect-head{display:flex;align-items:baseline;gap:16px;margin-bottom:34px;flex-wrap:wrap}
.sect-no{color:var(--accent);font-size:13px;letter-spacing:.18em;border:1px solid var(--accent);border-radius:3px;padding:3px 9px}
.sect-head h2{font-size:clamp(24px,3vw,34px);font-weight:900;letter-spacing:-.015em;margin:0}
.sect-head .lead{color:var(--muted);font-size:15px;margin:0;flex-basis:100%;max-width:60ch;font-family:var(--mono)}

/* =========================================================================
   Featured dossier (#1)
   ========================================================================= */
.feature{
	display:grid;grid-template-columns:1.05fr .95fr;gap:0;border:1px solid var(--line);border-radius:var(--r);
	overflow:hidden;background:var(--navy-2);position:relative;
}
.feature .shot{position:relative}
.feature .shot img{width:100%;height:100%;min-height:280px;object-fit:cover}
.feature .badge{
	position:absolute;top:16px;left:16px;background:var(--accent);color:#fff;font-family:var(--mono);
	font-size:12px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;padding:6px 12px;border-radius:3px;
}
.feature .fbody{padding:clamp(22px,3vw,38px)}
.feature h3{font-size:clamp(24px,3vw,32px);font-weight:900;margin:0 0 8px;letter-spacing:-.01em}
.feature h3 a{text-decoration:none}
.feature .tags{margin:0 0 16px}
.feature p{color:var(--muted);margin:0 0 22px}
.feature .frow{display:flex;align-items:center;gap:18px;flex-wrap:wrap}

/* =========================================================================
   Catalog grid — blueprint cards
   ========================================================================= */
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.card{
	display:flex;flex-direction:column;border:1px solid var(--line);border-radius:var(--r);background:var(--navy-2);
	overflow:hidden;position:relative;transition:.18s;
}
.card:hover{border-color:var(--accent-2);transform:translateY(-3px);box-shadow:0 14px 40px -22px rgba(54,182,255,.5)}
.card.is-top{border-color:rgba(255,91,31,.55)}
.card .shot{position:relative;display:block;border-bottom:1px solid var(--line)}
.card .shot img{width:100%;aspect-ratio:16/10;object-fit:cover}
.card .card-rank{
	position:absolute;top:0;left:0;background:var(--navy);color:var(--accent);font-weight:600;
	font-size:13px;letter-spacing:.06em;padding:5px 10px;border-right:1px solid var(--line);border-bottom:1px solid var(--line);
}
.card .card-body{padding:16px 17px 18px;display:flex;flex-direction:column;gap:10px;flex:1}
.card h3{font-size:19px;font-weight:800;margin:0;letter-spacing:-.01em;line-height:1.2}
.card h3 a{text-decoration:none}
.card .blurb{color:var(--muted);font-size:14px;margin:0;flex:1}
.tags{display:flex;flex-wrap:wrap;gap:6px}
.tags span{
	font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--accent-2);
	border:1px solid var(--line);border-radius:3px;padding:2px 7px;
}

/* title block / spec cartouche */
.card-spec{
	display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:2px;
	border-top:1px dashed var(--line);padding-top:12px;
}
.stars{font-size:13px;color:var(--muted);letter-spacing:.02em}
.stars b{color:var(--accent);letter-spacing:.05em;font-weight:400}

/* =========================================================================
   Categories
   ========================================================================= */
.cats{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.cat{
	display:flex;flex-direction:column;gap:6px;text-decoration:none;border:1px solid var(--line);border-radius:var(--r);
	padding:18px 16px;background:var(--navy-2);transition:.15s;position:relative;
}
.cat:hover{border-color:var(--accent);background:var(--navy-3)}
.cat .no{font-family:var(--mono);font-size:11px;color:var(--accent-2);letter-spacing:.1em}
.cat span:not(.no):not(.count){font-weight:800;font-size:17px}
.cat .count{font-family:var(--mono);font-size:11px;color:var(--faint);letter-spacing:.06em}

/* =========================================================================
   Steps + Criteria
   ========================================================================= */
.steps,.crit{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.step,.item{border:1px solid var(--line);border-radius:var(--r);padding:22px 20px;background:var(--navy-2);position:relative}
.step .n,.item .n{
	font-family:var(--mono);font-size:13px;color:var(--accent);border:1px solid var(--accent);border-radius:3px;
	width:38px;height:38px;display:flex;align-items:center;justify-content:center;margin-bottom:14px;
}
.step h4,.item h4{margin:0 0 8px;font-size:17px;font-weight:800}
.step p,.item p{margin:0;color:var(--muted);font-size:14px}

/* =========================================================================
   Pull quote
   ========================================================================= */
.pull{padding:clamp(40px,6vw,72px) 0;border-bottom:1px solid var(--line);text-align:center}
.pull q{display:block;font-size:clamp(24px,3.6vw,40px);font-weight:900;letter-spacing:-.02em;quotes:none;max-width:22ch;margin:0 auto}
.pull q em{color:var(--accent);font-style:normal}
.pull .by{font-family:var(--mono);color:var(--faint);font-size:12px;letter-spacing:.14em;text-transform:uppercase;margin-top:18px}

/* =========================================================================
   Blog teaser
   ========================================================================= */
.posts{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.pcard{
	display:flex;flex-direction:column;gap:10px;text-decoration:none;border:1px solid var(--line);border-radius:var(--r);
	padding:20px 18px;background:var(--navy-2);transition:.15s;
}
.pcard:hover{border-color:var(--accent-2);transform:translateY(-3px)}
.pcard .date{font-size:11px;color:var(--faint);letter-spacing:.08em;text-transform:uppercase}
.pcard h4{margin:0;font-size:17px;font-weight:800;line-height:1.25}
.pcard p{margin:0;color:var(--muted);font-size:14px;flex:1}
.pcard .lnk{color:var(--accent);font-weight:700;font-size:13.5px}

/* =========================================================================
   FAQ
   ========================================================================= */
.faq{display:flex;flex-direction:column;gap:10px;max-width:840px}
.faq details{border:1px solid var(--line);border-radius:var(--r);background:var(--navy-2);overflow:hidden}
.faq summary{
	cursor:pointer;list-style:none;padding:16px 20px;font-weight:700;display:flex;gap:12px;align-items:center;
}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";margin-left:auto;color:var(--accent);font-family:var(--mono);font-size:20px}
.faq details[open] summary::after{content:"–"}
.faq .q{font-family:var(--mono);font-size:12px;color:var(--accent-2);letter-spacing:.06em}
.faq .a{padding:0 20px 18px;color:var(--muted);font-size:15px}

/* =========================================================================
   Single jogo (review)
   ========================================================================= */
.single-head{display:grid;grid-template-columns:1fr auto;gap:30px;align-items:start;padding:clamp(36px,5vw,64px) 0 26px}
.single-head h1{font-size:clamp(28px,4vw,46px);font-weight:900;letter-spacing:-.02em;margin:.1em 0 .25em}
.rank-big{font-family:var(--mono);color:var(--accent-2);font-size:12px;letter-spacing:.16em;text-transform:uppercase;margin:0;display:flex;align-items:center;gap:10px}
.rank-big .sq{width:12px;height:12px;background:var(--accent);display:inline-block}
.cta-box{
	border:1px solid var(--line);border-radius:var(--r);padding:20px;background:var(--navy-2);min-width:230px;
	display:flex;flex-direction:column;gap:12px;
}
.cta-box .stars{font-size:15px}
.note{font-size:12px;color:var(--faint);margin:0;letter-spacing:.02em}
.single-cover{border:1px solid var(--line);border-radius:var(--r);overflow:hidden;background:var(--navy-2);padding:12px;margin-bottom:14px}
.single-cover img{width:100%;border-radius:3px;aspect-ratio:16/9;object-fit:cover}

/* =========================================================================
   Prose (reviews + legal pages)
   ========================================================================= */
.prose{max-width:760px;margin:0 auto;padding:8px 0 16px;font-size:17px}
.prose h2{font-size:clamp(21px,2.4vw,28px);font-weight:900;letter-spacing:-.01em;margin:1.6em 0 .5em;padding-top:.3em;border-top:1px solid var(--line)}
.prose h3{font-size:20px;font-weight:800;margin:1.3em 0 .4em}
.prose p{color:#cdd9f5;margin:0 0 1.1em}
.prose ul,.prose ol{color:#cdd9f5;padding-left:1.3em;margin:0 0 1.2em}
.prose li{margin:.35em 0}
.prose a{color:var(--accent-2);text-decoration:underline;text-underline-offset:3px}
.prose strong{color:var(--ink)}
.prose em{color:var(--muted)}

/* =========================================================================
   Footer
   ========================================================================= */
.site-foot{border-top:2px solid var(--accent);background:rgba(13,27,62,.5);margin-top:0}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:34px;padding:clamp(40px,5vw,64px) 0 30px}
.site-foot .brand{font-size:22px;margin-bottom:0}
.site-foot h5{font-family:var(--mono);font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--accent-2);margin:0 0 14px;display:flex;align-items:center;gap:9px}
.site-foot h5 .sq{width:9px;height:9px;background:var(--accent)}
.site-foot ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:9px}
.site-foot ul a{color:var(--muted);text-decoration:none;font-size:14.5px}
.site-foot ul a:hover{color:var(--ink)}
.site-foot .foot-grid>div>p a{color:var(--accent-2);text-decoration:none;font-family:var(--mono);font-size:14px}
.colophon{
	border-top:1px solid var(--line);padding:18px 0 36px;display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap;
	font-family:var(--mono);font-size:12px;color:var(--faint);letter-spacing:.04em;
}

/* =========================================================================
   Archive nav + pagination
   ========================================================================= */
.catbar{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:30px;border-bottom:1px solid var(--line);padding-bottom:16px;font-family:var(--mono)}
.catbar a{text-decoration:none;color:var(--muted);font-size:13px;padding:6px 12px;border:1px solid var(--line);border-radius:3px;letter-spacing:.04em}
.catbar a:hover,.catbar a.is-active{color:#fff;border-color:var(--accent);background:var(--navy-3)}
.pagination{display:flex;gap:8px;flex-wrap:wrap;font-family:var(--mono)}
.pagination .page-numbers{padding:8px 13px;border:1px solid var(--line);border-radius:3px;text-decoration:none;color:var(--muted)}
.pagination .current{background:var(--accent);color:#fff;border-color:var(--accent)}

/* =========================================================================
   Subscribe form (OneSignal)
   ========================================================================= */
.subscribe{max-width:560px;border:1px solid var(--line);border-radius:var(--r);background:var(--navy-2);padding:clamp(22px,3vw,34px);position:relative}
.subscribe::before{
	content:"NX · FORM";position:absolute;top:-1px;right:18px;transform:translateY(-50%);
	background:var(--navy);color:var(--accent-2);font-family:var(--mono);font-size:10.5px;letter-spacing:.14em;
	padding:2px 9px;border:1px solid var(--line);border-radius:3px;
}
.subscribe .form-row{margin-bottom:14px}
.subscribe label{display:block;font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--faint);margin-bottom:6px}
.subscribe input{
	width:100%;background:var(--navy);border:1px solid var(--line);border-radius:var(--r);color:var(--ink);
	font-family:var(--sans);font-size:15px;padding:12px 14px;transition:.15s;
}
.subscribe input:focus{outline:none;border-color:var(--accent-2);box-shadow:0 0 0 3px rgba(54,182,255,.15)}
.subscribe input::placeholder{color:var(--faint)}
.btn-full{width:100%;justify-content:center;margin-top:6px}
.success-msg{margin-top:14px;padding:12px 14px;border:1px solid var(--ok);border-radius:var(--r);color:var(--ok);font-family:var(--mono);font-size:13px;background:rgba(55,211,153,.08)}
.success-msg.hidden{display:none}

/* =========================================================================
   Responsive
   ========================================================================= */
@media(max-width:980px){
	.hero .wrap{grid-template-columns:1fr;gap:34px}
	.feature{grid-template-columns:1fr}
	.feature .shot img{min-height:220px}
	.grid{grid-template-columns:repeat(2,1fr)}
	.cats,.steps,.crit,.posts{grid-template-columns:repeat(2,1fr)}
	.foot-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:640px){
	body{font-size:16px}
	.menu-toggle{display:inline-block}
	.nav{display:none;flex-basis:100%;flex-direction:column;gap:2px;margin:8px 0 4px}
	.nav.open{display:flex}
	.brand-row{flex-wrap:wrap}
	.readout{grid-template-columns:repeat(2,1fr)}
	.grid,.cats,.steps,.crit,.posts{grid-template-columns:1fr}
	.single-head{grid-template-columns:1fr}
	.foot-grid{grid-template-columns:1fr}
}
