/*
Theme Name: Nocth Studio
Theme URI: https://nocth.com.br
Author: Nocth
Author URI: https://nocth.com.br
Description: Tema do Nocth Studio — vitrine de projetos (jogos, apps, web e mais) + diario do estudio. Identidade "coruja noturna". Inclui o tipo de conteudo "Projetos" para cadastrar cada trabalho pelo painel, com tipo, status e link.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: nocthstudio
Tags: blog, portfolio, custom-logo, custom-menu, featured-images, translation-ready
*/

/* =========================================================================
   TOKENS — toda a identidade vive aqui. Mude estas variaveis e o site
   inteiro acompanha. Quer tema claro? Troque --bg/--text e pronto.
   ========================================================================= */
:root{
  /* Cores — noite de coruja: base meia-noite (nao preto puro) + ambar dos olhos */
  --bg:        #000000;   /* preto puro — base da marca */
  --bg-2:      #0C0A08;   /* superficie levemente quente (tom de brasa) */
  --bg-3:      #17120D;   /* cartoes elevados / hover */
  --line:      rgba(255,170,90,.10);  /* linhas com leve tom quente */
  --line-2:    rgba(255,170,90,.18);
  --text:      #F4EFEA;   /* off-white levemente quente */
  --muted:     #A89A8C;   /* secundario quente */
  --amber:     #FA7500;   /* PRIMARIA — laranja da marca */
  --amber-2:   #FF9A3D;   /* glow ambar claro */
  --moon:      #FFC24D;   /* ember/tocha — realce dourado quente (games) */
  --ember:     #FF4D1F;   /* brasa quente p/ CTAs e status "lancado" */
  --ink:       #140800;   /* texto sobre laranja */
  --ok:        #36D399;

  /* Tipografia — display com personalidade + corpo neutro + mono "de dados" */
  --font-display: "Bricolage Grotesque", "Segoe UI", system-ui, sans-serif;
  --font-body:    "Inter", system-ui, -apple-system, sans-serif;
  --font-mono:    "JetBrains Mono", ui-monospace, "Courier New", monospace;

  /* Escala e ritmo */
  --maxw: 1160px;
  --gap: clamp(1rem, 2vw, 1.5rem);
  --radius: 16px;
  --radius-sm: 10px;
  --section-y: clamp(4.5rem, 9vw, 8rem);
}

/* =========================================================================
   RESET enxuto
   ========================================================================= */
*,*::before,*::after{ box-sizing:border-box; }
*{ margin:0; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
body{
  background:var(--bg);
  color:var(--text);
  font-family:var(--font-body);
  font-size:1.0625rem;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img,svg,video{ display:block; max-width:100%; height:auto; }
a{ color:inherit; text-decoration:none; }
button,input,textarea,select{ font:inherit; color:inherit; }
ul[role="list"]{ list-style:none; padding:0; }

/* Foco visivel sempre (acessibilidade) */
:focus-visible{ outline:2px solid var(--amber); outline-offset:3px; border-radius:4px; }

/* Respeita quem desativou animacoes no SO */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{ animation-duration:.001ms!important; transition-duration:.001ms!important; scroll-behavior:auto!important; }
}

/* =========================================================================
   LAYOUT base
   ========================================================================= */
.wrap{ width:min(100% - 2.5rem, var(--maxw)); margin-inline:auto; }
.section{ padding-block:var(--section-y); position:relative; }
.section--tight{ padding-block:clamp(3rem,6vw,5rem); }

/* Skip link (acessibilidade — pula direto pro conteudo) */
.skip-link{
  position:absolute; left:-999px; top:0; z-index:1000;
  background:var(--amber); color:var(--ink); padding:.6rem 1rem; border-radius:0 0 8px 0; font-weight:600;
}
.skip-link:focus{ left:0; }

/* =========================================================================
   TIPOGRAFIA
   ========================================================================= */
h1,h2,h3,h4{ font-family:var(--font-display); font-weight:700; line-height:1.08; letter-spacing:-.02em; }
h1{ font-size:clamp(2.6rem, 7vw, 5rem); }
h2{ font-size:clamp(2rem, 4.5vw, 3.1rem); }
h3{ font-size:clamp(1.25rem, 2.4vw, 1.6rem); letter-spacing:-.01em; }
p{ color:var(--muted); }
strong{ color:var(--text); font-weight:600; }

/* Eyebrow em mono = "marcador de dados/codigo". Estrutura que diz algo,
   nao enfeite: sinaliza o tom tecnico da marca. */
.eyebrow{
  font-family:var(--font-mono); font-size:.8rem; font-weight:500;
  letter-spacing:.04em; color:var(--amber); text-transform:lowercase;
  display:inline-flex; align-items:center; gap:.5rem;
}
.eyebrow::before{ content:"//"; opacity:.6; }

.lead{ font-size:clamp(1.05rem,1.6vw,1.25rem); color:var(--muted); max-width:54ch; }

/* =========================================================================
   BOTOES
   ========================================================================= */
.btn{
  --_bg:var(--amber); --_fg:var(--ink);
  display:inline-flex; align-items:center; gap:.55rem;
  background:var(--_bg); color:var(--_fg);
  font-weight:600; font-size:.98rem;
  padding:.8rem 1.4rem; border-radius:999px; border:1px solid transparent;
  cursor:pointer; white-space:nowrap; transition:transform .15s ease, box-shadow .2s ease, background .2s ease;
  box-shadow:0 8px 30px -10px color-mix(in srgb, var(--amber) 60%, transparent);
}
.btn:hover{ transform:translateY(-2px); box-shadow:0 14px 40px -10px color-mix(in srgb, var(--amber) 70%, transparent); }
.btn--ghost{
  --_bg:transparent; --_fg:var(--text);
  border-color:var(--line-2); box-shadow:none;
}
.btn--ghost:hover{ border-color:var(--amber); background:color-mix(in srgb, var(--amber) 8%, transparent); box-shadow:none; }
.btn svg{ width:1.05em; height:1.05em; }

/* =========================================================================
   HEADER / NAV
   ========================================================================= */
.site-header{
  position:fixed; inset:0 0 auto 0; z-index:100;
  transition:background .3s ease, border-color .3s ease, backdrop-filter .3s ease;
  border-bottom:1px solid transparent;
}
.site-header.is-stuck{
  background:color-mix(in srgb, var(--bg) 82%, transparent);
  backdrop-filter:blur(14px) saturate(140%);
  border-bottom-color:var(--line);
}
.nav{ display:flex; align-items:center; justify-content:space-between; height:72px; gap:1rem; }
.brand{ display:inline-flex; align-items:center; gap:.6rem; font-family:var(--font-display); font-weight:700; font-size:1.35rem; letter-spacing:-.02em; }
.brand .owl{ width:30px; height:30px; }
/* Logo enviada pelo painel (the_custom_logo) — SEM isto a imagem estoura no
   tamanho natural do arquivo. Limita a altura e deixa a largura proporcional. */
.brand img,
.custom-logo{ height:44px; width:auto; max-width:180px; object-fit:contain; display:block; }
.custom-logo-link{ display:inline-flex; align-items:center; line-height:0; }
.site-footer .custom-logo{ height:40px; }
.brand b{ color:var(--text); }
.brand .dot{ color:var(--amber); }

.nav-menu{ display:flex; align-items:center; gap:1.6rem; list-style:none; }
.nav-menu a{ color:var(--muted); font-size:.95rem; font-weight:500; transition:color .2s ease; }
.nav-menu a:hover, .nav-menu .current-menu-item > a{ color:var(--text); }
.nav-cta{ display:flex; align-items:center; gap:.75rem; }

/* Botao mobile */
.nav-toggle{ display:none; background:none; border:1px solid var(--line-2); border-radius:10px; width:42px; height:42px; align-items:center; justify-content:center; cursor:pointer; }
.nav-toggle span,.nav-toggle span::before,.nav-toggle span::after{
  content:""; display:block; width:18px; height:2px; background:var(--text); position:relative; transition:.25s;
}
.nav-toggle span::before{ position:absolute; top:-6px; }
.nav-toggle span::after{ position:absolute; top:6px; }
body.nav-open .nav-toggle span{ background:transparent; }
body.nav-open .nav-toggle span::before{ top:0; transform:rotate(45deg); }
body.nav-open .nav-toggle span::after{ top:0; transform:rotate(-45deg); }

@media (max-width:860px){
  .nav-toggle{ display:flex; }
  .nav-menu{
    position:fixed; inset:72px 0 auto 0; flex-direction:column; gap:0;
    background:var(--bg-2); border-bottom:1px solid var(--line);
    padding:1rem 1.25rem 1.5rem; align-items:stretch;
    /* fechado: oculto de verdade (sem barra preta sobrando) */
    opacity:0; visibility:hidden; transform:translateY(-10px);
    transition:opacity .25s ease, transform .25s ease, visibility .25s ease;
  }
  body.nav-open .nav-menu{ opacity:1; visibility:visible; transform:translateY(0); }
  .nav-menu li{ border-bottom:1px solid var(--line); }
  .nav-menu a{ display:block; padding:.9rem 0; font-size:1.05rem; }
  /* CTA do topo some no mobile (marca com mais espaco) */
  .nav-cta{ display:none; }
}

/* =========================================================================
   GLOW / ATMOSFERA — assinatura visual: a luz dos olhos da coruja no escuro
   ========================================================================= */
.glow{ position:absolute; border-radius:50%; filter:blur(70px); opacity:.55; pointer-events:none; z-index:0; }
.glow--amber{ background:radial-gradient(circle, var(--amber) 0%, transparent 70%); }
.glow--moon{ background:radial-gradient(circle, var(--moon) 0%, transparent 70%); }

/* Campo de estrelas sutil no hero */
.stars{ position:absolute; inset:0; z-index:0; pointer-events:none; opacity:.5; }

/* =========================================================================
   HERO
   ========================================================================= */
.hero{ position:relative; padding-top:clamp(8rem, 16vh, 11rem); padding-bottom:var(--section-y); overflow:hidden; isolation:isolate; }
.hero .glow--amber{ width:620px; height:620px; top:-180px; right:-120px; }
.hero .glow--moon{ width:420px; height:420px; bottom:-160px; left:-120px; opacity:.32; }
.hero__inner{ position:relative; z-index:2; max-width:880px; }
.hero h1{ margin:.8rem 0 .4rem; }
.hero h1 .mark{
  color:var(--amber);
  /* glow do wordmark — ecoa o brilho da logo */
  text-shadow:0 0 38px color-mix(in srgb, var(--amber) 60%, transparent),
              0 0 90px color-mix(in srgb, var(--amber) 30%, transparent);
}
.hero__tag{ font-family:var(--font-display); font-weight:600; font-size:clamp(1.4rem,3vw,2.1rem); color:var(--text); letter-spacing:-.02em; margin-bottom:1.1rem; }
.hero__actions{ display:flex; flex-wrap:wrap; gap:.8rem; margin-top:1.8rem; }
.hero__meta{ display:flex; flex-wrap:wrap; gap:1.5rem 2rem; margin-top:2.6rem; padding-top:1.6rem; border-top:1px solid var(--line); }
.hero__meta div{ font-size:.9rem; }
.hero__meta b{ font-family:var(--font-display); font-size:1.5rem; color:var(--text); display:block; }
.hero__meta span{ color:var(--muted); }

/* =========================================================================
   SECAO: DOIS BRACOS (divisoes)
   ========================================================================= */
.section-head{ max-width:640px; margin-bottom:clamp(2rem,4vw,3rem); }
.section-head h2{ margin:.7rem 0 .8rem; }

.divisions{ display:grid; grid-template-columns:repeat(2,1fr); gap:var(--gap); }
@media (max-width:760px){ .divisions{ grid-template-columns:1fr; } }
.division{
  position:relative; overflow:hidden;
  background:linear-gradient(180deg, var(--bg-2), var(--bg));
  border:1px solid var(--line); border-radius:var(--radius);
  padding:clamp(1.5rem,3vw,2.2rem);
  transition:border-color .25s ease, transform .25s ease;
}
.division:hover{ transform:translateY(-4px); }
.division__icon{ width:48px; height:48px; border-radius:12px; display:grid; place-items:center; margin-bottom:1.1rem; }
.division__tag{ font-family:var(--font-mono); font-size:.78rem; letter-spacing:.03em; }
.division h3{ margin:.5rem 0 .6rem; }
.division ul{ list-style:none; padding:0; margin:1.1rem 0 1.4rem; display:flex; flex-wrap:wrap; gap:.5rem; }
.division li{ font-size:.82rem; font-family:var(--font-mono); color:var(--muted); border:1px solid var(--line); border-radius:999px; padding:.3rem .7rem; }
.division__link{ font-weight:600; display:inline-flex; align-items:center; gap:.4rem; transition:gap .2s ease; }
.division__link:hover{ gap:.7rem; }

/* Braco consultoria = ambar | Braco games = moon (codigo de cor com sentido) */
.division--data:hover{ border-color:color-mix(in srgb, var(--amber) 50%, var(--line)); }
.division--data .division__icon{ background:color-mix(in srgb, var(--amber) 15%, transparent); color:var(--amber); }
.division--data .division__tag, .division--data .division__link{ color:var(--amber); }
.division--data .glow{ background:radial-gradient(circle, var(--amber) 0%, transparent 70%); width:240px; height:240px; top:-120px; right:-80px; opacity:.18; }

.division--games:hover{ border-color:color-mix(in srgb, var(--moon) 50%, var(--line)); }
.division--games .division__icon{ background:color-mix(in srgb, var(--moon) 15%, transparent); color:var(--moon); }
.division--games .division__tag, .division--games .division__link{ color:var(--moon); }
.division--games .glow{ background:radial-gradient(circle, var(--moon) 0%, transparent 70%); width:240px; height:240px; top:-120px; right:-80px; opacity:.18; }

/* =========================================================================
   SECAO: SERVICOS (grid)
   ========================================================================= */
.services{ display:grid; grid-template-columns:repeat(3,1fr); gap:var(--gap); }
@media (max-width:880px){ .services{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:520px){ .services{ grid-template-columns:1fr; } }
.service{
  background:var(--bg-2); border:1px solid var(--line); border-radius:var(--radius-sm);
  padding:1.4rem; transition:background .2s ease, border-color .2s ease;
}
.service:hover{ background:var(--bg-3); border-color:var(--line-2); }
.service__num{ font-family:var(--font-mono); font-size:.78rem; color:var(--amber); }
.service h3{ font-size:1.15rem; margin:.5rem 0 .4rem; }
.service p{ font-size:.92rem; }

/* =========================================================================
   FAIXA GAMES (destaque)
   ========================================================================= */
.games-band{ position:relative; overflow:hidden; border-radius:var(--radius); border:1px solid var(--line);
  background:linear-gradient(135deg, color-mix(in srgb, var(--moon) 12%, var(--bg-2)), var(--bg)); padding:clamp(2rem,5vw,3.5rem); }
.games-band .glow--moon{ width:380px; height:380px; top:-140px; right:-100px; opacity:.3; }
.games-band__grid{ position:relative; z-index:2; display:grid; grid-template-columns:1.2fr 1fr; gap:2.5rem; align-items:center; }
@media (max-width:760px){ .games-band__grid{ grid-template-columns:1fr; } }
.games-band .eyebrow{ color:var(--moon); }
.games-band h2{ margin:.7rem 0 1rem; }
.games-stack{ display:flex; flex-direction:column; gap:.7rem; }
.games-stack .chip{ display:flex; align-items:center; gap:.7rem; background:color-mix(in srgb, var(--bg) 60%, transparent); border:1px solid var(--line); border-radius:var(--radius-sm); padding:.8rem 1rem; font-size:.92rem; }
.games-stack .chip b{ font-family:var(--font-mono); color:var(--moon); }

/* =========================================================================
   BLOG (listagem em cartoes)
   ========================================================================= */
.posts{ display:grid; grid-template-columns:repeat(3,1fr); gap:var(--gap); }
@media (max-width:880px){ .posts{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:560px){ .posts{ grid-template-columns:1fr; } }
.post-card{
  display:flex; flex-direction:column; overflow:hidden;
  background:var(--bg-2); border:1px solid var(--line); border-radius:var(--radius);
  transition:transform .2s ease, border-color .2s ease;
}
.post-card:hover{ transform:translateY(-4px); border-color:var(--line-2); }
.post-card__thumb{ aspect-ratio:16/9; overflow:hidden; background:var(--bg-3); }
.post-card__thumb img{ width:100%; height:100%; object-fit:cover; transition:transform .4s ease; }
.post-card:hover .post-card__thumb img{ transform:scale(1.05); }
.post-card__noimg{ width:100%; height:100%; display:grid; place-items:center; background:radial-gradient(circle at 70% 20%, color-mix(in srgb,var(--amber) 18%, var(--bg-3)), var(--bg-3)); }
.post-card__body{ padding:1.3rem; display:flex; flex-direction:column; gap:.55rem; flex:1; }
.post-card__meta{ font-family:var(--font-mono); font-size:.74rem; color:var(--amber); display:flex; gap:.6rem; flex-wrap:wrap; }
.post-card__meta .cat{ color:var(--muted); }
.post-card h3{ font-size:1.2rem; }
.post-card h3 a:hover{ color:var(--amber); }
.post-card p{ font-size:.9rem; flex:1; }
.post-card__more{ font-weight:600; color:var(--amber); font-size:.9rem; display:inline-flex; gap:.4rem; align-items:center; transition:gap .2s; }
.post-card__more:hover{ gap:.65rem; }

/* =========================================================================
   CTA CONTATO
   ========================================================================= */
.cta-band{ position:relative; overflow:hidden; text-align:center; border-radius:var(--radius);
  border:1px solid var(--line); background:linear-gradient(180deg, var(--bg-2), var(--bg)); padding:clamp(2.5rem,6vw,4.5rem) clamp(1.5rem,4vw,3rem); }
.cta-band .glow--amber{ width:500px; height:500px; top:-200px; left:50%; transform:translateX(-50%); opacity:.25; }
.cta-band__inner{ position:relative; z-index:2; max-width:620px; margin-inline:auto; }
.cta-band h2{ margin-bottom:.9rem; }
.cta-band .hero__actions{ justify-content:center; }

/* =========================================================================
   FOOTER
   ========================================================================= */
.site-footer{ border-top:1px solid var(--line); background:var(--bg-2); padding-block:clamp(3rem,6vw,4rem) 2rem; margin-top:0; }
.footer-grid{ display:grid; grid-template-columns:1.5fr 1fr 1fr; gap:2.5rem; }
@media (max-width:720px){ .footer-grid{ grid-template-columns:1fr; gap:2rem; } }
.footer-brand p{ font-size:.92rem; margin-top:1rem; max-width:36ch; }
.footer-col h4{ font-family:var(--font-mono); font-size:.78rem; color:var(--muted); text-transform:uppercase; letter-spacing:.06em; margin-bottom:1rem; }
.footer-col ul{ list-style:none; padding:0; display:flex; flex-direction:column; gap:.6rem; }
.footer-col a{ color:var(--muted); font-size:.94rem; transition:color .2s; }
.footer-col a:hover{ color:var(--amber); }
.socials{ display:flex; gap:.7rem; margin-top:1.2rem; }
.socials a{ width:40px; height:40px; border:1px solid var(--line); border-radius:10px; display:grid; place-items:center; color:var(--muted); transition:.2s; }
.socials a:hover{ color:var(--amber); border-color:var(--amber); transform:translateY(-2px); }
.socials svg{ width:18px; height:18px; }
.footer-bottom{ display:flex; flex-wrap:wrap; gap:1rem; justify-content:space-between; align-items:center;
  margin-top:2.5rem; padding-top:1.5rem; border-top:1px solid var(--line); font-size:.85rem; color:var(--muted); }
.footer-bottom .font-mono{ font-family:var(--font-mono); }

/* =========================================================================
   ARTIGO (single) + paginas
   ========================================================================= */
.article-head{ padding-top:clamp(7rem,14vh,9rem); position:relative; overflow:hidden; }
.article-head .glow--amber{ width:480px; height:480px; top:-220px; right:-100px; opacity:.18; }
.article-head__inner{ position:relative; z-index:2; max-width:760px; }
.article-head h1{ font-size:clamp(2rem,5vw,3.4rem); margin:1rem 0; }
.article-meta{ display:flex; flex-wrap:wrap; gap:1rem; font-family:var(--font-mono); font-size:.82rem; color:var(--muted); }
.article-meta .cat{ color:var(--amber); }
.article-cover{ margin:2.5rem auto; max-width:var(--maxw); }
.article-cover img{ width:100%; border-radius:var(--radius); border:1px solid var(--line); }

/* Corpo do texto — largura de leitura confortavel */
.prose{ width:min(100% - 2.5rem, 760px); margin-inline:auto; }
.prose > *{ margin-bottom:1.3rem; }
.prose h2{ font-size:1.7rem; margin-top:2.5rem; }
.prose h3{ font-size:1.3rem; margin-top:2rem; }
.prose p,.prose li{ color:#C7CCDB; font-size:1.075rem; line-height:1.8; }
.prose a{ color:var(--amber); text-decoration:underline; text-underline-offset:3px; }
.prose strong{ color:var(--text); }
.prose ul,.prose ol{ padding-left:1.3rem; display:flex; flex-direction:column; gap:.5rem; }
.prose img{ border-radius:var(--radius-sm); border:1px solid var(--line); }
.prose blockquote{ border-left:3px solid var(--amber); padding:.4rem 0 .4rem 1.3rem; color:var(--text); font-style:italic; }
.prose code{ font-family:var(--font-mono); font-size:.9em; background:var(--bg-3); padding:.15em .4em; border-radius:6px; }
.prose pre{ background:var(--ink); border:1px solid var(--line); border-radius:var(--radius-sm); padding:1.2rem; overflow:auto; }
.prose pre code{ background:none; padding:0; }
.prose hr{ border:none; border-top:1px solid var(--line); }

.tags{ display:flex; flex-wrap:wrap; gap:.5rem; margin-top:2rem; }
.tags a{ font-family:var(--font-mono); font-size:.8rem; color:var(--muted); border:1px solid var(--line); border-radius:999px; padding:.3rem .8rem; transition:.2s; }
.tags a:hover{ color:var(--amber); border-color:var(--amber); }

/* Navegacao entre posts */
.post-nav{ display:grid; grid-template-columns:1fr 1fr; gap:var(--gap); margin-top:3rem; }
@media (max-width:560px){ .post-nav{ grid-template-columns:1fr; } }
.post-nav a{ border:1px solid var(--line); border-radius:var(--radius-sm); padding:1.1rem 1.3rem; transition:.2s; }
.post-nav a:hover{ border-color:var(--amber); }
.post-nav span{ font-family:var(--font-mono); font-size:.74rem; color:var(--muted); display:block; margin-bottom:.3rem; }
.post-nav strong{ font-size:.98rem; }
.post-nav .next{ text-align:right; }

/* =========================================================================
   PAGINACAO
   ========================================================================= */
.pagination{ display:flex; gap:.5rem; justify-content:center; margin-top:3rem; flex-wrap:wrap; }
.pagination .page-numbers{
  min-width:42px; height:42px; display:grid; place-items:center; padding:0 .8rem;
  border:1px solid var(--line); border-radius:10px; color:var(--muted); font-family:var(--font-mono); font-size:.9rem; transition:.2s;
}
.pagination .page-numbers:hover{ border-color:var(--line-2); color:var(--text); }
.pagination .page-numbers.current{ background:var(--amber); color:var(--ink); border-color:var(--amber); font-weight:600; }

/* =========================================================================
   UTIL / comentarios / busca
   ========================================================================= */
.search-form{ display:flex; gap:.5rem; max-width:420px; }
.search-form input[type="search"]{ flex:1; background:var(--bg-3); border:1px solid var(--line); border-radius:999px; padding:.7rem 1.2rem; color:var(--text); }
.empty-state{ text-align:center; padding:4rem 1rem; color:var(--muted); }
.divider{ height:1px; background:var(--line); border:none; margin:0; }

.comment-list{ list-style:none; padding:0; display:flex; flex-direction:column; gap:1.5rem; margin-top:1.5rem; }
.comment-list .comment-body{ background:var(--bg-2); border:1px solid var(--line); border-radius:var(--radius-sm); padding:1.2rem; }
.comment-form input,.comment-form textarea{ width:100%; background:var(--bg-3); border:1px solid var(--line); border-radius:var(--radius-sm); padding:.8rem 1rem; margin-bottom:.8rem; }

/* =========================================================================
   v1.1 — titulo ao lado da logo
   ========================================================================= */
.brand-title{ font-family:var(--font-display); font-weight:700; font-size:1.35rem; letter-spacing:-.02em; line-height:1; }

/* Divisoes: quando so ha 1 cartao (Games oculto), ocupa a largura toda */
.divisions--single{ grid-template-columns:1fr; }
.divisions--single .division{ max-width:680px; }

/* =========================================================================
   v1.1 — FORMULARIO DE CONTATO (shortcode [nocth_contato])
   ========================================================================= */
.nocth-form{ display:flex; flex-direction:column; gap:1rem; max-width:640px; }
.cf-row{ display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
@media (max-width:560px){ .cf-row{ grid-template-columns:1fr; } }
.cf-field{ display:flex; flex-direction:column; gap:.4rem; }
.cf-field > span{ font-family:var(--font-mono); font-size:.78rem; color:var(--muted); letter-spacing:.02em; }
.cf-field input,
.cf-field textarea{
  width:100%; background:var(--bg-2); color:var(--text);
  border:1px solid var(--line); border-radius:var(--radius-sm);
  padding:.8rem 1rem; font-size:1rem; transition:border-color .2s ease, background .2s ease;
}
.cf-field input:focus,
.cf-field textarea:focus{ border-color:var(--amber); background:var(--bg-3); outline:none; }
.cf-field textarea{ resize:vertical; min-height:130px; }
.nocth-form .btn{ align-self:flex-start; margin-top:.3rem; }

/* Honeypot: invisivel para humanos, mas presente no DOM para pegar bots */
.cf-hp{ position:absolute; left:-9999px; width:1px; height:1px; overflow:hidden; }

/* Alertas de sucesso / erro */
.cf-alert{ border-radius:var(--radius-sm); padding:1rem 1.2rem; margin-bottom:1.2rem; font-size:.95rem; border:1px solid var(--line); }
.cf-alert--ok{ background:color-mix(in srgb, var(--ok) 12%, var(--bg-2)); border-color:color-mix(in srgb, var(--ok) 45%, transparent); color:#BFF3DD; }
.cf-alert--erro{ background:color-mix(in srgb, var(--amber) 12%, var(--bg-2)); border-color:color-mix(in srgb, var(--amber) 45%, transparent); color:var(--amber-2); }

/* =========================================================================
   NOCTH GAMES — estilos especificos do estudio
   ========================================================================= */

/* Hero do estudio: foco em "press start" + jogo em destaque */
.ghero{ position:relative; overflow:hidden; padding-top:clamp(8rem,16vh,11rem); padding-bottom:var(--section-y); isolation:isolate; }
.ghero .glow--amber{ width:680px; height:680px; top:-200px; left:-160px; opacity:.4; }
.ghero__grid{ position:relative; z-index:2; display:grid; grid-template-columns:1.1fr .9fr; gap:3rem; align-items:center; }
@media (max-width:840px){ .ghero__grid{ grid-template-columns:1fr; } }
.ghero h1{ margin:.8rem 0 .6rem; }
.ghero h1 .mark{
  color:var(--amber);
  text-shadow:0 0 38px color-mix(in srgb, var(--amber) 60%, transparent),
              0 0 90px color-mix(in srgb, var(--amber) 30%, transparent);
}
/* "moldura" do jogo em destaque no hero */
.ghero__feature{ position:relative; border:1px solid var(--line-2); border-radius:var(--radius); overflow:hidden; background:var(--bg-2); box-shadow:0 30px 80px -30px color-mix(in srgb, var(--amber) 40%, transparent); }
.ghero__feature img{ width:100%; aspect-ratio:4/3; object-fit:cover; }
.ghero__feature .noart{ aspect-ratio:4/3; display:grid; place-items:center; background:radial-gradient(circle at 60% 30%, color-mix(in srgb,var(--amber) 20%, var(--bg-3)), var(--bg-3)); }
.ghero__feature .noart svg{ width:120px; height:120px; opacity:.85; }
.ghero__feature__bar{ display:flex; align-items:center; justify-content:space-between; gap:1rem; padding:1rem 1.2rem; border-top:1px solid var(--line); }
.ghero__feature__bar strong{ font-family:var(--font-display); font-size:1.15rem; }

/* "quest marker" em mono — assinatura RPG */
.qmark{ font-family:var(--font-mono); color:var(--moon); font-size:.8rem; letter-spacing:.04em; display:inline-flex; gap:.5rem; }
.qmark::before{ content:"\25B8"; } /* triangulo ▸ */

/* Grade de jogos */
.games-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:var(--gap); }
@media (max-width:880px){ .games-grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:540px){ .games-grid{ grid-template-columns:1fr; } }

.gcard{ display:flex; flex-direction:column; overflow:hidden; background:var(--bg-2); border:1px solid var(--line); border-radius:var(--radius); transition:transform .2s ease, border-color .2s ease; }
.gcard:hover{ transform:translateY(-4px); border-color:color-mix(in srgb, var(--amber) 50%, var(--line)); }
.gcard__art{ aspect-ratio:4/3; overflow:hidden; background:var(--bg-3); position:relative; }
.gcard__art img{ width:100%; height:100%; object-fit:cover; transition:transform .4s ease; }
.gcard:hover .gcard__art img{ transform:scale(1.05); }
.gcard__noart{ width:100%; height:100%; display:grid; place-items:center; background:radial-gradient(circle at 65% 25%, color-mix(in srgb,var(--amber) 16%, var(--bg-3)), var(--bg-3)); }
.gcard__noart svg{ width:64px; height:64px; opacity:.8; }
.gcard__body{ padding:1.2rem; display:flex; flex-direction:column; gap:.6rem; flex:1; }
.gcard h3{ font-size:1.2rem; }
.gcard h3 a:hover{ color:var(--amber); }
.gcard__meta{ font-family:var(--font-mono); font-size:.76rem; color:var(--muted); display:flex; flex-wrap:wrap; gap:.5rem; align-items:center; }
.gcard p{ font-size:.9rem; flex:1; }

/* Selo de status */
.badge{ display:inline-flex; align-items:center; gap:.4rem; font-family:var(--font-mono); font-size:.72rem; font-weight:500; padding:.25rem .6rem; border-radius:999px; border:1px solid var(--line-2); letter-spacing:.02em; }
.badge::before{ content:""; width:7px; height:7px; border-radius:50%; background:currentColor; }
.badge--dev{ color:var(--amber-2); border-color:color-mix(in srgb,var(--amber) 45%,transparent); }
.badge--soon{ color:var(--moon); border-color:color-mix(in srgb,var(--moon) 45%,transparent); }
.badge--live{ color:var(--ink); background:var(--ember); border-color:transparent; }
.badge--live::before{ background:var(--ink); }

/* Botao "ember" para CTA de loja */
.btn--ember{ background:var(--ember); color:#fff; box-shadow:0 8px 30px -10px color-mix(in srgb, var(--ember) 70%, transparent); }
.btn--ember:hover{ box-shadow:0 14px 40px -10px color-mix(in srgb, var(--ember) 80%, transparent); }

/* Pagina de um jogo */
.game-head{ padding-top:clamp(7rem,14vh,9rem); position:relative; overflow:hidden; }
.game-head .glow--amber{ width:520px; height:520px; top:-220px; right:-120px; opacity:.2; }
.game-head__grid{ position:relative; z-index:2; display:grid; grid-template-columns:1fr 1fr; gap:2.5rem; align-items:center; }
@media (max-width:760px){ .game-head__grid{ grid-template-columns:1fr; } }
.game-head__art{ border:1px solid var(--line-2); border-radius:var(--radius); overflow:hidden; }
.game-head__art img{ width:100%; aspect-ratio:4/3; object-fit:cover; }
.game-head h1{ font-size:clamp(2rem,5vw,3.2rem); margin:.8rem 0; }
.game-facts{ display:flex; flex-wrap:wrap; gap:1.4rem; margin:1.2rem 0; font-family:var(--font-mono); font-size:.84rem; }
.game-facts div span{ display:block; color:var(--muted); font-size:.74rem; margin-bottom:.2rem; }
.game-actions{ display:flex; flex-wrap:wrap; gap:.7rem; margin-top:1.5rem; }

/* Caixa de meta no editor de jogo (admin) */
.nocth-meta-box label{ display:block; font-weight:600; margin:1rem 0 .3rem; }
.nocth-meta-box input, .nocth-meta-box select{ width:100%; padding:.5rem; }
