/* ==========================================================
   COMPONENTS — buttons, cards, badges, forms, navigation
   ========================================================== */

/* —— BUTTONS —— */
.btn {
  --btn-pad-y: 12px;
  --btn-pad-x: 22px;
  --btn-fs: 13px;
  appearance: none; border: 0; cursor: pointer; user-select: none;
  font-family: var(--f-ui); font-weight: 600; font-size: var(--btn-fs);
  letter-spacing: .12em; text-transform: uppercase;
  padding: var(--btn-pad-y) var(--btn-pad-x);
  border-radius: var(--r-sm);
  display: inline-flex; align-items: center; gap: 10px;
  transition: all .25s cubic-bezier(.2,.8,.2,1);
  text-decoration: none; line-height: 1;
}
.btn-sm { --btn-pad-y: 8px; --btn-pad-x: 14px; --btn-fs: 11px; }
.btn-lg { --btn-pad-y: 16px; --btn-pad-x: 28px; --btn-fs: 14px; }

.btn-primary {
  background: linear-gradient(180deg, var(--lime-200), var(--lime-400));
  color: #0a1500;
  box-shadow: 0 0 0 1px rgba(163,230,53,.6), 0 8px 22px rgba(132,204,22,.35);
}
.btn-primary:hover {
  transform: translateY(-1px);
  box-shadow: 0 0 0 1px var(--lime-200), 0 0 30px rgba(163,230,53,.6), 0 12px 28px rgba(132,204,22,.5);
  color: #0a1500;
}
.btn-secondary {
  background: var(--ink-800); color: var(--ink-50);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.1);
}
.btn-secondary:hover { background: var(--ink-700); box-shadow: inset 0 0 0 1px rgba(163,230,53,.3); color: var(--lime-200); }

.btn-ghost { background: transparent; color: var(--lime-300); box-shadow: inset 0 0 0 1px rgba(163,230,53,.3); }
.btn-ghost:hover { background: rgba(163,230,53,.06); box-shadow: inset 0 0 0 1px var(--lime-300); color: var(--lime-200); }

.btn-block { width: 100%; justify-content: center; }
.btn-icon { width: 14px; height: 14px; }

/* —— BADGES / TAGS —— */
.badge {
  display: inline-flex; align-items: center; gap: 6px;
  font-family: var(--f-mono); font-size: 10px; letter-spacing: .12em;
  text-transform: uppercase; padding: 4px 9px;
  border-radius: var(--r-sm); border: 1px solid;
  white-space: nowrap; line-height: 1;
}
.badge-solid   { background: var(--lime-300); color: #0a1500; border-color: var(--lime-300); font-weight: 700; }
.badge-lime    { color: var(--lime-200); border-color: rgba(163,230,53,.4); background: rgba(163,230,53,.08); }
.badge-info    { color: var(--info); border-color: rgba(56,189,248,.4); background: rgba(56,189,248,.08); }
.badge-warn    { color: var(--warning); border-color: rgba(251,191,36,.4); background: rgba(251,191,36,.08); }
.badge-danger  { color: var(--danger); border-color: rgba(248,113,113,.4); background: rgba(248,113,113,.08); }
.badge-mute    { color: var(--ink-300); border-color: rgba(255,255,255,.12); background: rgba(255,255,255,.04); }
.badge-outline { background: transparent; color: var(--lime-300); border-color: var(--lime-300); }

/* Service-colored badges (mapeia para slug de categoria/term) */
.badge-svc-xcloud     { color: #4dff4d; border-color: rgba(16,124,16,.6);  background: rgba(16,124,16,.18); }
.badge-svc-boosteroid { color: #b39bff; border-color: rgba(106,58,255,.6); background: rgba(106,58,255,.18); }
.badge-svc-gfn        { color: #b3ff4d; border-color: rgba(118,185,0,.55); background: rgba(118,185,0,.16); }
.badge-svc-luna       { color: #ffc266; border-color: rgba(255,153,0,.55); background: rgba(255,153,0,.16); }
.badge-svc-blacknut   { color: #ff8aab; border-color: rgba(233,30,99,.55);  background: rgba(233,30,99,.16); }

/* —— CORNER BRACKETS —— */
.corner { position: absolute; width: 14px; height: 14px; border-color: var(--lime-300); border-style: solid; border-width: 0; }
.corner.tl { top: 10px; left: 10px;  border-top-width: 2px; border-left-width: 2px; }
.corner.tr { top: 10px; right: 10px; border-top-width: 2px; border-right-width: 2px; }
.corner.bl { bottom: 10px; left: 10px;  border-bottom-width: 2px; border-left-width: 2px; }
.corner.br { bottom: 10px; right: 10px; border-bottom-width: 2px; border-right-width: 2px; }

/* —— THUMB / FEATURED IMAGE PLACEHOLDER —— */
/* Use as fallback quando WP não tem featured image. Em produção, .thumb wraps <img> */
.thumb { position: relative; overflow: hidden;
  background: radial-gradient(circle at 30% 40%, rgba(163,230,53,.3), transparent 60%), linear-gradient(135deg, #1a2540, #0d1420);
}
.thumb.var-2 { background: radial-gradient(circle at 70% 30%, rgba(56,189,248,.25), transparent 60%), linear-gradient(135deg, #102030, #060a12); }
.thumb.var-3 { background: radial-gradient(circle at 50% 60%, rgba(132,204,22,.3),  transparent 60%), linear-gradient(135deg, #1f2e10, #0a1004); }
.thumb.var-4 { background: radial-gradient(circle at 30% 60%, rgba(106,58,255,.3),  transparent 60%), linear-gradient(135deg, #1a1230, #0a0418); }
.thumb.var-5 { background: radial-gradient(circle at 60% 30%, rgba(255,153,0,.25),  transparent 60%), linear-gradient(135deg, #2a1a00, #0d0700); }
.thumb::before {
  content:""; position:absolute; inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.06) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.06) 1px, transparent 1px);
  background-size: 24px 24px;
  mask-image: linear-gradient(180deg, #000, transparent 80%);
  -webkit-mask-image: linear-gradient(180deg, #000, transparent 80%);
  pointer-events: none;
}
.thumb img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.thumb-glyph {
  position: absolute; inset: 0; display: flex; align-items: center; justify-content: center;
  font-family: var(--f-display); font-size: 56px; color: rgba(255,255,255,.85);
  text-shadow: 0 0 30px rgba(163,230,53,.5); letter-spacing: -.04em;
}

/* —— ARTICLE CARD —— */
.article {
  background: var(--ink-800);
  border: 1px solid rgba(255,255,255,.06);
  border-radius: var(--r-md);
  overflow: hidden;
  display: flex; flex-direction: column;
  transition: all .25s ease;
  position: relative;
}
.article:hover {
  border-color: rgba(163,230,53,.3);
  transform: translateY(-2px);
  box-shadow: 0 18px 36px rgba(0,0,0,.5), 0 0 24px rgba(163,230,53,.12);
}
.article > a.article-link {
  position: absolute; inset: 0; z-index: 2;
  text-indent: -9999px; overflow: hidden;
}
.article .thumb { aspect-ratio: 16/9; }
.article .thumb-tag { position: absolute; top: 12px; left: 12px; z-index: 1; }
.article-body { padding: 16px 18px 18px; display: flex; flex-direction: column; gap: 8px; flex: 1; }
.article-cat  { font-family: var(--f-mono); font-size: 10px; color: var(--lime-300); letter-spacing:.12em; text-transform: uppercase; }
.article h3 { font-family: var(--f-ui); font-weight: 700; font-size: 17px; line-height: 1.3; margin: 0; color: var(--ink-50); }
.article-lead { color: var(--ink-300); font-size: 13px; line-height: 1.5; margin: 0; }
.article-meta { display: flex; gap: 8px; font-family: var(--f-mono); font-size: 10px; color: var(--ink-400); letter-spacing:.06em; margin-top: auto; padding-top: 4px; }
.article-meta .sep { opacity: .4; }
.article-meta .views { color: var(--lime-300); }

/* Article — horizontal variant (lista de arquivo / busca) */
.article-row {
  display: grid; grid-template-columns: 240px 1fr; gap: 20px;
  background: var(--ink-800); border: 1px solid rgba(255,255,255,.06);
  border-radius: var(--r-md); overflow: hidden;
  transition: all .25s ease; position: relative;
}
.article-row:hover { border-color: rgba(163,230,53,.3); transform: translateY(-2px); box-shadow: 0 14px 30px rgba(0,0,0,.45); }
.article-row > a.article-link { position: absolute; inset: 0; z-index: 2; text-indent: -9999px; overflow: hidden; }
.article-row .thumb { aspect-ratio: 16/10; }
.article-row .article-body { padding: 18px 22px; gap: 10px; }
.article-row h3 { font-size: 19px; }

@media (max-width: 640px) {
  .article-row { grid-template-columns: 1fr; }
  .article-row .thumb { aspect-ratio: 16/9; }
}

/* —— FORMS —— */
.input, input[type="text"], input[type="email"], input[type="search"], input[type="password"], textarea {
  appearance: none; width: 100%; padding: 12px 14px;
  background: rgba(255,255,255,.03); border: 1px solid rgba(255,255,255,.1);
  border-radius: var(--r-sm); color: var(--ink-50);
  font-family: var(--f-body); font-size: 14px;
  transition: all .2s;
}
.input::placeholder, input::placeholder, textarea::placeholder { color: var(--ink-400); }
.input:focus, input:focus, textarea:focus { outline: 0; border-color: var(--lime-300); box-shadow: 0 0 0 3px rgba(163,230,53,.15); }

.search-bar {
  display: flex; align-items: center; gap: 0;
  background: rgba(255,255,255,.03);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: var(--r-md); padding: 4px;
  transition: border-color .2s;
}
.search-bar:focus-within { border-color: var(--lime-300); box-shadow: 0 0 0 3px rgba(163,230,53,.15); }
.search-bar svg { margin: 0 12px; color: var(--ink-400); flex-shrink: 0; }
.search-bar input {
  flex: 1; background: transparent; border: 0; outline: 0;
  padding: 10px 0; color: var(--ink-50);
  font-family: var(--f-body); font-size: 14px;
}
.search-bar .btn { margin-left: 4px; flex-shrink: 0; }

/* —— PAGINATION —— */
.pagination {
  display: flex; gap: 6px; justify-content: center; align-items: center;
  margin-top: 48px; flex-wrap: wrap;
}
.pagination a, .pagination span {
  min-width: 40px; height: 40px; display: inline-flex; align-items: center; justify-content: center;
  padding: 0 12px; border-radius: var(--r-sm);
  font-family: var(--f-mono); font-size: 12px; letter-spacing: .1em;
  background: var(--ink-800); border: 1px solid rgba(255,255,255,.06);
  color: var(--ink-200); text-decoration: none;
  transition: all .2s;
}
.pagination a:hover { border-color: rgba(163,230,53,.4); color: var(--lime-200); }
.pagination .current {
  background: var(--lime-300); color: var(--ink-950); border-color: var(--lime-300); font-weight: 700;
}
.pagination .ellipsis { background: transparent; border: 0; color: var(--ink-400); }

/* —— BREADCRUMB —— */
.breadcrumb {
  font-family: var(--f-mono); font-size: 11px; letter-spacing: .1em; text-transform: uppercase;
  color: var(--ink-400);
  display: flex; flex-wrap: wrap; gap: 8px; align-items: center;
  padding: 18px 0;
}
.breadcrumb a { color: var(--ink-300); }
.breadcrumb a:hover { color: var(--lime-300); }
.breadcrumb .sep { opacity: .5; }
.breadcrumb .current { color: var(--lime-300); }

/* —— STATS / HUD —— */
.stats-row {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 0;
  border: 1px solid rgba(163,230,53,.2); border-radius: var(--r-lg);
  overflow: hidden;
  background: linear-gradient(180deg, rgba(20,35,58,.4), rgba(10,15,20,.6));
}
.stats-row .stat-cell { padding: 28px; border-right: 1px solid rgba(163,230,53,.1); position: relative; }
.stats-row .stat-cell:last-child { border-right: 0; }
.stats-row .stat-cell::before {
  content:""; position:absolute; top:0; left:0; right:0; height: 2px;
  background: linear-gradient(90deg, transparent, var(--lime-300), transparent);
  opacity: .4;
}
.stats-row .num {
  font-family: var(--f-display); font-size: 44px; line-height: 1;
  color: var(--lime-300); text-shadow: 0 0 24px rgba(163,230,53,.35);
}
.stats-row .num sup { font-size: 16px; color: var(--ink-200); margin-left: 4px; vertical-align: super; }
.stats-row .lbl { font-family: var(--f-mono); font-size: 11px; letter-spacing: .14em; text-transform: uppercase; color: var(--ink-300); margin-top: 12px; }

@media (max-width: 768px) {
  .stats-row { grid-template-columns: repeat(2, 1fr); }
  .stats-row .stat-cell:nth-child(2) { border-right: 0; }
  .stats-row .stat-cell:nth-child(1), .stats-row .stat-cell:nth-child(2) { border-bottom: 1px solid rgba(163,230,53,.1); }
  .stats-row .num { font-size: 36px; }
}

/* —— FAQ / DÚVIDA ITEM —— */
.faq-list { display: flex; flex-direction: column; gap: 10px; }
.faq {
  background: rgba(255,255,255,.03);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: var(--r-md); padding: 18px 20px;
  transition: all .2s;
}
.faq:hover { border-color: rgba(163,230,53,.3); background: rgba(163,230,53,.04); }
.faq summary { list-style: none; cursor: pointer; display: flex; justify-content: space-between; align-items: center; gap: 16px; }
.faq summary::-webkit-details-marker { display: none; }
.faq-q-text { font-family: var(--f-ui); font-weight: 600; font-size: 15px; color: var(--ink-50); }
.faq-q-icon {
  width: 24px; height: 24px; border-radius: 999px;
  border: 1px solid rgba(163,230,53,.4); color: var(--lime-300);
  display: flex; align-items: center; justify-content: center; flex: 0 0 24px;
  transition: transform .3s;
}
.faq[open] { border-color: rgba(163,230,53,.5); background: rgba(163,230,53,.06); }
.faq[open] .faq-q-icon { transform: rotate(45deg); background: rgba(163,230,53,.15); }
.faq-a { color: var(--ink-200); font-size: 14px; line-height: 1.65; margin-top: 14px; }
.faq-meta { display: flex; flex-wrap: wrap; gap: 14px; font-family: var(--f-mono); font-size: 11px; color: var(--ink-400); letter-spacing: .08em; margin-top: 14px; }
.faq-meta .author { color: var(--lime-300); }

/* —— SERVICE COMPARISON CARD —— */
.service {
  border-radius: var(--r-lg); padding: 28px;
  background: linear-gradient(180deg, rgba(20,28,38,.9), rgba(10,15,20,.95));
  border: 1px solid rgba(255,255,255,.08);
  position: relative; overflow: hidden;
  transition: transform .35s cubic-bezier(.2,.8,.2,1), border-color .3s;
}
.service:hover { transform: translateY(-4px); border-color: rgba(163,230,53,.4); box-shadow: var(--glow-sm); }
.service.featured { border-color: rgba(163,230,53,.5); box-shadow: var(--glow-md); background: linear-gradient(180deg, rgba(40,60,20,.6), rgba(10,15,20,.95)); }
.service.featured::before { content:""; position:absolute; inset:0; background: radial-gradient(circle at 50% 0%, rgba(163,230,53,.18), transparent 60%); pointer-events: none; }
.service-head { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: 22px; }
.service-logo {
  width: 48px; height: 48px; border-radius: var(--r-sm);
  display: flex; align-items: center; justify-content: center;
  font-family: var(--f-display); font-size: 22px; color: #fff;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.08);
}
.service-logo.x { background: linear-gradient(135deg, #107c10, #0a4d0a); }
.service-logo.b { background: linear-gradient(135deg, #6a3aff, #3a1aaa); }
.service-logo.g { background: linear-gradient(135deg, #76b900, #4a7800); }
.service-name { font-family: var(--f-display); font-size: 20px; text-transform: uppercase; margin: 14px 0 4px; color: var(--ink-50); }
.service-tag { font-family: var(--f-mono); font-size: 11px; color: var(--ink-400); letter-spacing: .1em; text-transform: uppercase; }
.service-price { display: flex; align-items: baseline; gap: 4px; margin: 18px 0; }
.service-price .num { font-family: var(--f-display); font-size: 38px; color: var(--lime-300); line-height: 1; }
.service-price .cur { font-family: var(--f-mono); font-size: 12px; color: var(--ink-400); }
.service-price .per { font-family: var(--f-mono); font-size: 12px; color: var(--ink-400); margin-left: 4px; }
.service ul { list-style: none; margin: 0 0 20px; padding: 0; }
.service ul li {
  padding: 10px 0; font-size: 13px; color: var(--ink-200);
  border-top: 1px solid rgba(255,255,255,.05);
  display: flex; align-items: center; gap: 10px;
}
.service ul li::before {
  content: ""; width: 14px; height: 14px; border-radius: 999px;
  background: rgba(163,230,53,.15); border: 1px solid rgba(163,230,53,.4);
  flex: 0 0 14px;
  background-image: linear-gradient(135deg, transparent 50%, var(--lime-300) 50%);
  background-size: 8px 8px; background-position: center; background-repeat: no-repeat;
}

/* —— PROSE (single post body) —— */
.prose { font-family: var(--f-body); font-size: 17px; line-height: 1.75; color: var(--ink-100); }
.prose > * + * { margin-top: 1.1em; }
.prose h2 { font-family: var(--f-display); font-size: clamp(24px, 3vw, 32px); text-transform: uppercase; margin: 2em 0 .6em; letter-spacing: -.005em; }
.prose h3 { font-family: var(--f-ui); font-size: 22px; margin: 1.6em 0 .4em; color: var(--ink-50); }
.prose h2 + p, .prose h3 + p { margin-top: .4em; }
.prose p { color: var(--ink-200); }
.prose strong { color: var(--ink-50); }
.prose a { color: var(--lime-300); text-decoration: underline; text-decoration-color: rgba(163,230,53,.4); text-underline-offset: 3px; }
.prose a:hover { text-decoration-color: var(--lime-300); }
.prose ul, .prose ol { padding-left: 24px; }
.prose ul li, .prose ol li { padding: 4px 0; color: var(--ink-200); }
.prose ul li::marker { color: var(--lime-300); }
.prose blockquote {
  margin: 1.5em 0; padding: 18px 24px;
  border-left: 3px solid var(--lime-300);
  background: rgba(163,230,53,.05);
  border-radius: 0 var(--r-md) var(--r-md) 0;
  font-style: italic; color: var(--ink-100);
}
.prose code {
  font-family: var(--f-mono); font-size: .9em;
  padding: 2px 6px; border-radius: var(--r-xs);
  background: rgba(163,230,53,.1); color: var(--lime-200);
  border: 1px solid rgba(163,230,53,.2);
}
.prose pre {
  background: var(--ink-900); border: 1px solid rgba(255,255,255,.08);
  border-radius: var(--r-md); padding: 18px; overflow-x: auto;
  font-family: var(--f-mono); font-size: 13px; line-height: 1.6;
}
.prose pre code { background: transparent; border: 0; padding: 0; color: var(--ink-100); }
.prose img, .prose figure { border-radius: var(--r-md); overflow: hidden; }
.prose figure figcaption { font-family: var(--f-mono); font-size: 12px; color: var(--ink-400); text-align: center; margin-top: 8px; letter-spacing: .05em; }
.prose hr { border: 0; border-top: 1px solid rgba(163,230,53,.15); margin: 2.4em 0; }
.prose table { width: 100%; border-collapse: collapse; font-size: 14px; }
.prose th, .prose td { padding: 10px 12px; text-align: left; border-bottom: 1px solid rgba(255,255,255,.06); }
.prose th { font-family: var(--f-ui); color: var(--lime-300); text-transform: uppercase; font-size: 12px; letter-spacing: .1em; }
