/*
Theme Name: JogaJá
Theme URI: https://example.com/
Author: JogaJá
Description: Portal de análise e ranking de jogos web (pt-PT). Tema clássico, leve, sem plugins. Conceito: ecrã de recordes de uma máquina de arcada de 1983 num monitor CRT âmbar.
Version: 1.1.1
Requires at least: 6.0
Requires PHP: 7.4
License: GNU General Public License v2 or later
Text Domain: jogaja
*/

/* =========================================================================
   DESIGN CONSTITUTION
   Concept: an 1983 coin-op arcade attract screen on an amber CRT monitor —
            the high-score table IS the page.
   - Two colors: CRT black #0b0c0e + amber phosphor #f5c518. One accent: hot
     magenta #ff2d55 (active rank, PLAY button, INSERT COIN). Neutrals only
     for body text legibility.
   - Type: "Press Start 2P" (pixel) for ranks/labels/score; "Space Grotesk"
     huge for headlines; system sans for body; IBM Plex Mono for meta.
   - Surfaces: CRT — scanline overlay + vignette + phosphor glow. No radius.
     1px amber rules. Scoreboard rows light up (invert to amber) on hover.
   - Layout: visible grid, 1UP/HI-SCORE bar, marquee ticker, zero-padded
     ranks, blinking cursor, one full-bleed marquee anchor.
   - Signature: coin "◉" + pixel rank before every game; PLAY ▶ in magenta;
     scanlines everywhere.
   ========================================================================= */

:root{
  --crt:#0b0c0e;
  --crt-2:#13151a;        /* raised panel */
  --crt-3:#1b1e25;        /* hover row */
  --phos:#f5c518;         /* amber phosphor */
  --phos-dim:#9a8a2e;
  --text:#dcd8cc;         /* soft body */
  --muted:#8b8779;
  --accent:#ff2d55;       /* the one accent */
  --rule:#2a2c22;         /* amber-tinted hairline */
  --maxw:1180px;
  --gutter:clamp(16px,4vw,40px);
  --pixel:"Press Start 2P",monospace;
  --mono:"IBM Plex Mono",ui-monospace,monospace;
  --display:"Space Grotesk",system-ui,sans-serif;
  --body:system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;
}

*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0;background:var(--crt);color:var(--text);
  font-family:var(--body);font-size:17px;line-height:1.65;
  -webkit-font-smoothing:antialiased;overflow-x:hidden;
}

/* CRT overlays --------------------------------------------------------- */
.scanlines{position:fixed;inset:0;z-index:60;pointer-events:none;
  background:repeating-linear-gradient(0deg,rgba(0,0,0,.16) 0,rgba(0,0,0,.16) 1px,transparent 1px,transparent 3px);
  mix-blend-mode:multiply}
.vignette{position:fixed;inset:0;z-index:59;pointer-events:none;
  background:radial-gradient(120% 90% at 50% 40%,transparent 55%,rgba(0,0,0,.55) 100%)}

/* glow + helpers ------------------------------------------------------- */
.phos{color:var(--phos);text-shadow:0 0 14px rgba(245,197,24,.35)}
.acc{color:var(--accent);text-shadow:0 0 14px rgba(255,45,85,.4)}
.blink{animation:blink 1.1s steps(2,start) infinite}
@keyframes blink{50%{opacity:0}}

a{color:inherit;text-decoration:none}
.prose a,.lnk{text-decoration:underline;text-decoration-style:dotted;text-underline-offset:3px;color:var(--phos)}
.prose a:hover,.lnk:hover{text-decoration-style:solid;color:var(--accent)}
img{max-width:100%;display:block}

.wrap{max-width:var(--maxw);margin:0 auto;padding-left:var(--gutter);padding-right:var(--gutter);position:relative;z-index:2}

.label{font-family:var(--pixel);font-size:11px;line-height:1.6;letter-spacing:.02em;
  text-transform:uppercase;color:var(--phos)}
.coin{display:inline-block;width:.7em;height:.7em;border-radius:50%;
  background:var(--accent);box-shadow:0 0 8px rgba(255,45,85,.6);vertical-align:.02em;margin-right:.55em}
.sq{display:inline-block;width:.6em;height:.6em;background:var(--accent);vertical-align:.04em;margin-right:.5em}
.sect-no{font-family:var(--pixel);color:var(--accent);font-size:13px}

/* =================== MARQUEE TICKER =================================== */
.ticker{background:var(--accent);color:#fff;overflow:hidden;white-space:nowrap;
  border-bottom:2px solid var(--crt);position:relative;z-index:3}
.ticker .run{display:inline-block;padding:7px 0;font-family:var(--pixel);font-size:10px;
  letter-spacing:.04em;animation:marq 26s linear infinite}
.ticker .run span{margin:0 26px}
@keyframes marq{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* =================== HEADER =========================================== */
.site-head{border-bottom:2px solid var(--phos);background:var(--crt);position:relative;z-index:3}
.hud{display:flex;justify-content:space-between;align-items:center;padding:8px 0;
  border-bottom:1px solid var(--rule);font-family:var(--pixel);font-size:10px;color:var(--phos)}
.hud .acc{color:var(--accent)}
.brand-row{display:flex;align-items:center;justify-content:space-between;gap:24px;padding:16px 0}
.brand{font-family:var(--display);font-weight:700;font-size:clamp(1.7rem,5vw,3rem);
  line-height:.9;letter-spacing:-.02em;text-transform:uppercase;color:var(--phos);
  text-shadow:0 0 16px rgba(245,197,24,.4)}
.brand em{font-style:normal;color:var(--accent);text-shadow:0 0 16px rgba(255,45,85,.5)}
.nav{display:flex;flex-wrap:wrap;gap:20px;font-family:var(--mono);font-size:13px;
  letter-spacing:.04em;text-transform:uppercase;align-items:center}
.nav a{padding:4px 0;border-bottom:2px solid transparent;color:var(--text)}
.nav a:hover,.nav .current-menu-item>a{border-bottom-color:var(--accent);color:var(--accent)}
.menu-toggle{display:none}

/* =================== HERO ============================================= */
.hero{padding:clamp(40px,8vw,96px) 0 clamp(28px,5vw,52px);border-bottom:2px solid var(--phos)}
.hero .kicker{font-family:var(--pixel);font-size:11px;letter-spacing:.02em;
  text-transform:uppercase;color:var(--accent);margin-bottom:22px}
.hero h1{font-family:var(--display);font-weight:700;font-size:clamp(2.4rem,8.5vw,6.4rem);
  line-height:.94;letter-spacing:-.025em;margin:0;text-transform:uppercase;max-width:15ch;color:var(--phos);
  text-shadow:0 0 24px rgba(245,197,24,.28)}
.hero h1 em{font-style:normal;color:var(--accent);text-shadow:0 0 24px rgba(255,45,85,.4)}
.hero .cursor{color:var(--accent)}
.hero .lede{margin-top:24px;max-width:48ch;font-size:clamp(1rem,2.2vw,1.2rem);color:var(--text)}
.hero .meta-strip{display:flex;flex-wrap:wrap;gap:14px;margin-top:34px}
.hero .meta-strip .stat{border:1px solid var(--rule);padding:12px 16px;background:var(--crt-2)}
.hero .meta-strip .n{font-family:var(--pixel);font-size:16px;color:var(--phos);display:block;margin-bottom:8px}
.hero .meta-strip .t{font-family:var(--mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--muted)}

/* =================== SECTIONS ========================================= */
.sect{padding:clamp(40px,7vw,84px) 0}
.sect--tight{padding:clamp(28px,4vw,46px) 0}
.sect-head{display:flex;align-items:baseline;gap:16px;margin-bottom:30px;
  border-bottom:1px solid var(--phos);padding-bottom:14px;flex-wrap:wrap}
.sect-head h2{font-family:var(--display);font-weight:700;font-size:clamp(1.5rem,4vw,2.5rem);
  line-height:1;letter-spacing:-.02em;margin:0;text-transform:uppercase;color:var(--phos)}
.sect-head .lead{font-family:var(--mono);font-size:13px;color:var(--muted);margin-left:auto;
  max-width:40ch;text-align:right}

/* =================== EDITOR'S PICK =================================== */
.pick{border:2px solid var(--phos);background:linear-gradient(180deg,var(--crt-2),var(--crt));
  display:grid;grid-template-columns:280px 1fr auto;gap:clamp(16px,3vw,34px);align-items:center;
  padding:clamp(20px,3vw,30px);box-shadow:0 0 40px rgba(245,197,24,.08)}
.pick .cover{position:relative;aspect-ratio:16/10;border:1px solid var(--rule);overflow:hidden}
.pick .cover img{width:100%;height:100%;object-fit:cover;display:block}
.pick .cover .badge{position:absolute;top:0;left:0;font-family:var(--pixel);font-size:11px;color:var(--crt);
  background:var(--phos);padding:8px 12px;text-transform:uppercase;box-shadow:0 0 14px rgba(245,197,24,.5)}
.pick h3{font-family:var(--display);font-weight:700;font-size:clamp(1.6rem,4vw,2.8rem);
  line-height:1;margin:0 0 10px;text-transform:uppercase;letter-spacing:-.01em;color:var(--phos)}
.pick .tags{font-family:var(--mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);margin-bottom:12px}
.pick p{margin:0;color:var(--text);max-width:60ch}
.pick .aside{display:flex;flex-direction:column;align-items:flex-end;gap:14px;min-width:150px}

/* =================== SCOREBOARD ====================================== */
.board{border-top:2px solid var(--phos)}
.row{display:grid;grid-template-columns:62px 104px 1fr auto;gap:clamp(12px,2.4vw,26px);align-items:center;
  padding:18px 8px;border-bottom:1px solid var(--rule);transition:background .12s,box-shadow .12s}
.row:hover{background:var(--crt-3);box-shadow:inset 3px 0 0 var(--accent)}
.row .cover{aspect-ratio:16/10;background:var(--crt-2);border:1px solid var(--rule);overflow:hidden}
.row .cover img{width:100%;height:100%;object-fit:cover;display:block}
.row:hover .cover{border-color:var(--accent)}
.row .rank{font-family:var(--pixel);font-size:clamp(1rem,3vw,1.5rem);line-height:1;color:var(--phos);
  display:flex;align-items:center;gap:.4em}
.row.is-top .rank{color:var(--accent);text-shadow:0 0 12px rgba(255,45,85,.4)}
.row .body h3{font-family:var(--display);font-weight:700;font-size:clamp(1.2rem,3vw,1.8rem);
  line-height:1.05;margin:0 0 6px;letter-spacing:-.01em;color:var(--text)}
.row .body h3 a:hover{color:var(--phos)}
.row .tags{font-family:var(--mono);font-size:11px;letter-spacing:.05em;text-transform:uppercase;color:var(--muted);margin-bottom:8px}
.row .tags span:not(:last-child)::after{content:" · ";color:var(--accent)}
.row .blurb{max-width:64ch;color:var(--muted);font-size:.96rem}
.row .aside{display:flex;flex-direction:column;align-items:flex-end;gap:11px;min-width:128px}
.stars{font-family:var(--mono);font-size:13px;white-space:nowrap;color:var(--phos)}
.stars b{color:var(--phos)}

/* buttons -------------------------------------------------------------- */
.btn{display:inline-flex;align-items:center;gap:.5em;font-family:var(--pixel);font-size:11px;
  letter-spacing:.02em;text-transform:uppercase;padding:13px 18px;border:2px solid var(--accent);
  background:var(--accent);color:#fff;cursor:pointer;transition:transform .08s,box-shadow .12s,background .12s,color .12s;
  box-shadow:0 0 0 rgba(255,45,85,0)}
.btn:hover{box-shadow:0 0 18px rgba(255,45,85,.55);transform:translateY(-1px)}
.btn:active{transform:translateY(1px)}
.btn--ghost{background:transparent;color:var(--phos);border-color:var(--phos)}
.btn--ghost:hover{background:var(--phos);color:var(--crt);box-shadow:0 0 18px rgba(245,197,24,.5)}
.btn--lg{padding:16px 24px;font-size:12px}

/* =================== STEPS (como jogar) ============================== */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(14px,2.5vw,26px)}
.step{border:1px solid var(--rule);background:var(--crt-2);padding:24px}
.step .n{font-family:var(--pixel);font-size:22px;color:var(--accent);margin-bottom:16px}
.step h4{font-family:var(--display);font-weight:700;font-size:1.25rem;margin:0 0 8px;text-transform:uppercase;color:var(--phos)}
.step p{margin:0;color:var(--muted);font-size:.95rem}

/* =================== CATEGORIES ====================================== */
.cats{border-top:2px solid var(--phos)}
.cat{display:flex;align-items:baseline;gap:18px;padding:16px 8px;border-bottom:1px solid var(--rule);
  font-family:var(--display);font-size:clamp(1.15rem,3.2vw,1.9rem);font-weight:700;text-transform:uppercase;
  letter-spacing:-.01em;color:var(--text);transition:background .12s,padding-left .12s}
.cat .no{font-family:var(--pixel);font-size:12px;color:var(--accent);min-width:50px}
.cat .count{margin-left:auto;font-family:var(--mono);font-size:13px;font-weight:400;color:var(--muted);text-transform:none}
.cat:hover{background:var(--crt-3);color:var(--phos);padding-left:16px}

/* =================== PULL QUOTE (marquee anchor) ===================== */
.pull{border-top:2px solid var(--phos);border-bottom:2px solid var(--phos);
  padding:clamp(40px,7vw,96px) 0;background:var(--crt-2)}
.pull q{font-family:var(--display);font-weight:700;quotes:none;font-size:clamp(1.9rem,6vw,4rem);
  line-height:1.04;letter-spacing:-.02em;display:block;max-width:22ch;color:var(--phos);text-shadow:0 0 24px rgba(245,197,24,.25)}
.pull q em{font-style:normal;color:var(--accent)}
.pull .by{font-family:var(--pixel);font-size:11px;text-transform:uppercase;color:var(--muted);margin-top:26px}

/* =================== BLOG TEASER ===================================== */
.posts{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(14px,2.5vw,26px)}
.pcard{border:1px solid var(--rule);background:var(--crt-2);padding:24px;display:flex;flex-direction:column;gap:12px}
.pcard .date{font-family:var(--mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--accent)}
.pcard h4{font-family:var(--display);font-weight:700;font-size:1.3rem;line-height:1.1;margin:0;text-transform:uppercase;color:var(--phos)}
.pcard p{margin:0;color:var(--muted);font-size:.93rem;flex:1}
.pcard:hover{border-color:var(--phos)}

/* =================== CRITERIA ======================================== */
.crit{display:grid;grid-template-columns:repeat(12,1fr);gap:clamp(16px,3vw,30px)}
.crit .item{grid-column:span 6;border-top:2px solid var(--phos);padding-top:16px}
.crit .item .n{font-family:var(--pixel);color:var(--accent);font-size:12px;margin-bottom:12px}
.crit .item h4{font-family:var(--display);font-weight:700;font-size:1.3rem;margin:0 0 8px;text-transform:uppercase;color:var(--phos)}
.crit .item p{margin:0;color:var(--muted);font-size:.96rem}

/* =================== FAQ ============================================= */
.faq{border-top:2px solid var(--phos)}
.faq details{border-bottom:1px solid var(--rule);padding:18px 8px}
.faq summary{font-family:var(--display);font-weight:700;font-size:clamp(1.05rem,2.6vw,1.45rem);cursor:pointer;
  list-style:none;display:flex;gap:14px;align-items:baseline;text-transform:uppercase;color:var(--text)}
.faq summary::-webkit-details-marker{display:none}
.faq summary .q{font-family:var(--pixel);color:var(--accent);font-size:12px}
.faq summary::after{content:"+";margin-left:auto;font-family:var(--pixel);color:var(--accent);font-size:1em}
.faq details[open] summary{color:var(--phos)}
.faq details[open] summary::after{content:"–"}
.faq .a{margin-top:14px;color:var(--muted);max-width:72ch}

/* =================== SINGLE GAME ===================================== */
.single-head{display:grid;grid-template-columns:1fr 330px;gap:clamp(20px,4vw,46px);
  padding:clamp(32px,6vw,72px) 0;border-bottom:2px solid var(--phos);align-items:start}
.single-head .rank-big{font-family:var(--pixel);color:var(--accent);font-size:11px;margin-bottom:18px;text-transform:uppercase}
.single-head h1{font-family:var(--display);font-weight:700;font-size:clamp(2.1rem,7vw,4.6rem);
  line-height:.96;letter-spacing:-.025em;margin:0;text-transform:uppercase;color:var(--phos);text-shadow:0 0 22px rgba(245,197,24,.28)}
.single-head .tags{font-family:var(--mono);font-size:12px;letter-spacing:.05em;text-transform:uppercase;color:var(--muted);margin-top:18px}
.single-head .cta-box{border:2px solid var(--phos);padding:22px;background:var(--crt-2)}
.single-head .cta-box .stars{margin-bottom:16px;font-size:15px}
.single-head .cta-box .btn{width:100%;justify-content:center}
.single-head .cta-box .note{font-family:var(--mono);font-size:11px;color:var(--muted);margin-top:12px}
.single-cover{border-bottom:2px solid var(--phos);aspect-ratio:16/8;overflow:hidden;background:var(--crt-2)}
.single-cover img{width:100%;height:100%;object-fit:cover;display:block}
.prose{max-width:72ch;padding:clamp(32px,5vw,56px) 0;color:var(--text)}
.prose p{margin:0 0 1.2em}
.prose h2,.prose h3{font-family:var(--display);text-transform:uppercase;color:var(--phos)}

/* =================== FOOTER ========================================== */
.site-foot{border-top:2px solid var(--phos);margin-top:48px;background:var(--crt-2)}
.foot-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:32px;padding:clamp(40px,6vw,68px) 0 30px}
.foot-grid .brand{font-size:clamp(1.7rem,5vw,2.8rem)}
.foot-grid h5{font-family:var(--pixel);font-size:10px;letter-spacing:.02em;text-transform:uppercase;color:var(--accent);margin:0 0 16px}
.foot-grid ul{list-style:none;margin:0;padding:0;font-family:var(--mono);font-size:13px}
.foot-grid li{margin-bottom:9px}
.foot-grid li a{color:var(--text);text-decoration:underline;text-decoration-style:dotted;text-underline-offset:3px}
.foot-grid li a:hover{color:var(--phos)}
.colophon{border-top:1px solid var(--rule);padding:18px 0 40px;font-family:var(--mono);font-size:11.5px;
  color:var(--muted);display:flex;justify-content:space-between;gap:24px;flex-wrap:wrap}

/* pagination */
.pagination{font-family:var(--mono)}
.pagination .page-numbers{display:inline-block;padding:6px 12px;border:1px solid var(--rule);margin-right:6px;color:var(--text)}
.pagination .current{background:var(--accent);border-color:var(--accent);color:#fff}

/* =================== RESPONSIVE ====================================== */
@media(max-width:900px){
  .steps,.posts{grid-template-columns:1fr 1fr}
  .crit .item{grid-column:span 12}
  .pick{grid-template-columns:1fr;text-align:left}
  .pick .badge{align-self:start;display:inline-block}
  .pick .aside{align-items:flex-start}
  .single-head{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr 1fr}
  .sect-head .lead{display:none}
}
@media(max-width:600px){
  .steps,.posts,.foot-grid{grid-template-columns:1fr}
  .row{grid-template-columns:44px 70px 1fr;gap:11px}
  .row .aside{grid-column:1 / -1;flex-direction:row;align-items:center;justify-content:space-between;width:100%;margin-top:6px}
  .nav{display:none;width:100%;flex-direction:column;gap:0;padding-bottom:10px}
  .nav.open{display:flex}
  .nav a{padding:11px 0;border-bottom:1px solid var(--rule);width:100%}
  .menu-toggle{display:inline-flex;font-family:var(--pixel);font-size:10px;background:none;
    border:2px solid var(--phos);color:var(--phos);padding:9px 12px;cursor:pointer;text-transform:uppercase}
}

/* accessibility */
:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
.skip{position:absolute;left:-9999px}
.skip:focus{left:8px;top:8px;position:fixed;z-index:80;background:var(--accent);color:#fff;padding:10px 14px;font-family:var(--mono)}
@media(prefers-reduced-motion:reduce){.blink,.ticker .run{animation:none}}
