/* forge-shim.css — structural fixes + framework-class mapping on top of
   styles.css / innerpages.css / auth.css (v2 flat theme).

   This file deliberately does NOT restyle the board tiles, modal or filters
   anymore — styles.css/innerpages.css own those in v2. It keeps only:
     1. document-level scroll (the grid cells must not trap it),
     2. the challenge-modal show/hide contract,
     3. WTForms/Bootstrap class mapping (login/register/settings render them),
     4. forge-specific helpers (footer, alerts, event banner),
     5. a couple of safety nets ([hidden], pt-BR category colors). */

/* ---- 1. Document scroll ---- */
html { overflow: auto; height: auto; }
body.ip-body, body.auth-body { overflow: auto; height: auto; }
.ip-main { overflow-y: visible; }

/* ---- 2. Hacker cam removed — hide any leftover mockup nodes ---- */
.pixel-hacker-wrap, .forge-bg-canvas { display: none; }

/* ---- 3. Scoreboard graph legend ---- */
.forge-graph-legend {
  display: flex; flex-wrap: wrap; gap: 12px 18px;
  margin-top: 12px;
  padding-top: 12px;
  border-top: 1px solid var(--line);
  font-size: 12px;
  color: var(--fg);
}
.forge-graph-leg-item { display: inline-flex; align-items: center; gap: 6px; }
.forge-graph-swatch { display: inline-block; width: 10px; height: 10px; }

/* ---- 4. WTForms / Bootstrap class mapping ---- */
.form-control, .form-select, .forge-input, .forge-select {
  background: var(--bg);
  border: 1px solid var(--line);
  color: var(--fg);
  padding: 8px 10px;
  font-family: var(--font-mono);
  font-size: 13px;
  outline: none;
  width: 100%;
}
.form-control::placeholder, .forge-input::placeholder { color: var(--faint); }
.form-control:focus, .form-select:focus, .forge-input:focus, .forge-select:focus {
  border-color: var(--green);
}
.form-label {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.1em;
  color: var(--dim);
}
.form-text { color: var(--dim); font-family: var(--font-mono); font-size: 10px; }
.form-check {
  display: flex; align-items: center; gap: 8px;
  font-family: var(--font-mono); font-size: 12px; color: var(--dim);
}
.form-check-input, .forge-check { accent-color: var(--green); margin: 0; }
.form-check-label { color: var(--dim); }

.btn, .btn-primary, .btn-success, .btn-info {
  display: inline-block;
  padding: 9px 16px;
  background: var(--green);
  color: var(--bg);
  font-family: var(--font-mono);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.06em;
  border: none;
  cursor: pointer;
  text-decoration: none;
}
.btn:hover, .btn-primary:hover { background: var(--green-bright); }
.btn-secondary, .btn-outline-secondary, .btn-outlined {
  background: transparent; color: var(--green); border: 1px solid var(--line-strong);
}
.btn-secondary:hover, .btn-outline-secondary:hover, .btn-outlined:hover {
  border-color: var(--green); color: var(--green-bright);
}
.btn-danger { background: var(--red); color: var(--bg); }
.btn-danger:hover { background: #ff6677; }

.alert {
  padding: 10px 14px;
  font-family: var(--font-mono);
  font-size: 12px;
  border: 1px solid var(--line);
  color: var(--fg);
  margin-bottom: 12px;
}
.alert-warning { border-color: var(--amber); color: var(--amber); }
.alert-danger { border-color: var(--red); color: var(--red); }
.alert-success { border-color: var(--green); color: var(--green-bright); }
.alert-info { border-color: var(--line-strong); color: var(--dim); }

/* Generic tables used by framework pages */
.table, table { width: 100%; border-collapse: collapse; font-family: var(--font-mono); font-size: 13px; }
.table th, table th {
  text-align: left;
  padding: 8px 12px;
  border-bottom: 1px solid var(--line-strong);
  color: var(--dim);
  font-weight: 500;
  letter-spacing: 0.08em;
  font-size: 11px;
}
.table td, table td {
  padding: 8px 12px;
  border-bottom: 1px solid var(--line);
  color: var(--fg);
}
.table tr:hover td { background: rgba(0, 229, 58, 0.04); }

/* ---- 5. Forge-specific helpers ---- */
.forge-footer {
  position: fixed;
  left: 0; right: 0; bottom: 0;
  text-align: center;
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--faint);
  padding: 4px 0;
  z-index: 10;
  pointer-events: none;
}
.forge-alert {
  margin: 0 0 14px;
  padding: 10px 14px;
  border-left: 2px solid var(--green);
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--fg);
}
.forge-alert.error { border-left-color: var(--red); color: var(--red); }
.forge-alert.info { border-left-color: var(--amber); color: var(--amber); }
.forge-field { display: flex; flex-direction: column; gap: 4px; margin-bottom: 14px; }
.forge-center {
  display: flex; align-items: center; justify-content: center;
  min-height: calc(100vh - 80px);
  padding: 40px;
}

/* ---- 6. Safety nets ---- */
[hidden] { display: none !important; }

/* The HTML `hidden` attribute and explicit JS toggles control these. */
#challenge-window {
  display: none;
  position: fixed; inset: 0;
  z-index: 1000;
  align-items: center;
  justify-content: center;
}
#challenge-window.show { display: flex; }
#challenge-backdrop {
  position: fixed; inset: 0;
  background: rgba(2, 4, 2, 0.85);
  z-index: 999;
}
body.forge-modal-open { overflow: hidden; }

/* Category color fallbacks (pt-BR category folder names). */
.cat-redes, .cat-network { color: #88ccff; }
.cat-terminal { color: var(--amber); }
.cat-programao, .cat-programacao, .cat-programming { color: var(--green); }
.cat-reversing, .cat-rev { color: #ff88cc; }
.cat-forensics, .cat-forensic { color: #88ccff; }
.cat-pwn { color: var(--amber); }

/* ---- Event banner ---- */
.forge-event-banner {
  border: 1px solid var(--amber);
  border-left-width: 3px;
  background: rgba(255, 176, 0, 0.06);
  padding: 12px 16px;
  margin: 0 0 18px;
  font-family: var(--font-mono);
}
.forge-event-banner-row {
  display: flex; align-items: center; justify-content: space-between;
  gap: 16px; flex-wrap: wrap;
}
.forge-event-banner-main { display: flex; align-items: baseline; gap: 12px; flex-wrap: wrap; }
.forge-event-tag { color: var(--amber); font-weight: 700; letter-spacing: .08em; font-size: 12px; }
.forge-event-name { color: var(--fg); font-size: 15px; letter-spacing: .04em; }
.forge-event-banner-meta { display: flex; gap: 14px; align-items: center; font-size: 12px; }
.forge-event-countdown { font-weight: 700; letter-spacing: .04em; }
.forge-event-banner-desc {
  margin-top: 8px;
  border-top: 1px solid rgba(255, 176, 0, 0.2);
  padding-top: 8px;
}
