:root {
  --bg: #060606;
  --bg-panel: #0d0d0d;
  --line: #2a2a2a;
  --line-soft: #1a1a1a;
  --text-1: #f3f3f1;
  --text-2: #9a9a96;
  --text-3: #5c5c59;
  --font-display: 'Space Grotesk', sans-serif;
  --font-body: 'Inter', sans-serif;
  --font-mono: 'JetBrains Mono', monospace;
  --bs-body-bg: var(--bg);
  --bs-body-color: var(--text-1);
  --bs-body-font-family: var(--font-body);
  --bs-border-color: var(--line);
  --bs-link-color: var(--text-1);
  --bs-link-hover-color: var(--text-2);
  --bs-link-decoration: none;
  --bs-primary: var(--text-1);
  --bs-primary-rgb: 243,243,241;
  --bs-border-radius: 0;
  --bs-border-radius-sm: 0;
  --bs-border-radius-lg: 0;
  --bs-heading-color: var(--text-1);
}

* {
  outline-color: var(--text-1);
}

a {
  text-decoration: none;
}

::selection {
  background: var(--text-1);
  color: var(--bg);
}

/* Limitar el ancho del contenedor para una lectura más cómoda */

.container {
  max-width: 1040px;
}

/* ---------- fondo de red de nodos (canvas) ---------- */

#network-bg {
  position: fixed;
  inset: 0;
  z-index: 0;
  opacity: 0.35;
  pointer-events: none;
}

main, header, footer {
  position: relative;
  z-index: 1;
}

/* ---------- header ---------- */

.site-header {
  background: rgba(6,6,6,0.78);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-color: var(--line-soft) !important;
}

.brand-name {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 17px;
  letter-spacing: 0.01em;
}

.brand .mark circle {
  fill: var(--text-1);
}

.brand .mark line {
  stroke: var(--text-2);
  stroke-width: 1;
}

/* ---------- botones propios (monocromos) ---------- */

.btn {
  border-radius: 0;
  font-family: var(--font-mono);
}

.btn-mono {
  font-size: 12.5px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--text-1);
  border: 1px solid var(--line);
  padding: 9px 18px;
  transition: background .25s ease, color .25s ease, border-color .25s ease;
}

.btn-mono:hover {
  background: var(--text-1);
  color: var(--bg);
  border-color: var(--text-1);
}

.btn-mono-outline {
  font-size: 12px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--text-2);
  border: 1px solid var(--line);
  background: transparent;
}

.btn-mono-outline:hover {
  background: var(--text-1);
  color: var(--bg);
  border-color: var(--text-1);
}

.btn-mono-solid {
  font-size: 13px;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  background: var(--text-1);
  color: var(--bg);
  border: 1px solid var(--text-1);
  padding: 16px 30px;
  transition: opacity .25s ease;
}

.btn-mono-solid:hover {
  opacity: 0.82;
  color: var(--bg);
}

/* ---------- eyebrow ---------- */

.eyebrow {
  font-family: var(--font-mono);
  font-size: 12.5px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--text-2);
  display: flex;
  align-items: center;
  gap: 10px;
}

.eyebrow::before {
  content: '';
  width: 7px;
  height: 7px;
  background: var(--text-1);
  display: inline-block;
}

/* ---------- hero ---------- */

.hero {
  border-color: var(--line-soft) !important;
  padding-top: 64px;
}

.display-title {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(30px, 6vw, 52px);
  line-height: 1.04;
  letter-spacing: -0.01em;
}

.muted-em {
  color: var(--text-3);
}

.lead-text {
  margin-top: 22px;
  font-size: 17px;
  color: var(--text-2);
}

.meta-row {
  border-color: var(--line-soft) !important;
}

.meta-k {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--text-3);
  margin-bottom: 6px;
}

.meta-v {
  font-size: 15px;
  color: var(--text-1);
}

/* ---------- secciones genéricas ---------- */

section.block {
  border-color: var(--line-soft) !important;
}

.block-title {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: clamp(26px, 3vw, 34px);
}

.block-index {
  font-family: var(--font-mono);
  font-size: 12.5px;
  color: var(--text-3);
}

/* aparición suave al hacer scroll (clase añadida por script.js) */

section.block {
  opacity: 0;
  transform: translateY(18px);
  transition: opacity .7s ease, transform .7s ease;
}

section.block.in-view {
  opacity: 1;
  transform: translateY(0);
}

/* ---------- video ---------- */

.video-frame {
  position: relative;
  border: 1px solid var(--line);
  background: var(--bg-panel);
  aspect-ratio: 16/9;
  overflow: hidden;
}

.video-frame video {
  object-fit: cover;
  display: block;
}

/* ---------- documentos ---------- */

.doc-list {
  border-color: var(--line-soft) !important;
}

.doc-row {
  border-color: var(--line-soft) !important;
  transition: padding-left .25s ease;
}

.doc-row:hover {
  padding-left: 10px;
}

.doc-num {
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--text-3);
}

.doc-title {
  font-size: 16px;
  color: var(--text-1);
}

.doc-sub {
  font-family: var(--font-mono);
  font-size: 11.5px;
  color: var(--text-3);
  margin-top: 4px;
}

/* ---------- panel del programa ---------- */

.program-panel {
  border: 1px solid var(--line);
  background: var(--bg-panel);
}

.program-title {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 24px;
  margin-bottom: 10px;
}

.program-text {
  color: var(--text-2);
  font-size: 14.5px;
  max-width: 420px;
}

/* ---------- footer ---------- */

.foot-left {
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--text-3);
}

.foot-right {
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--text-2);
}

.foot-right a {
  transition: color .2s ease;
}

.foot-right a:hover {
  color: var(--text-1);
}

@media (max-width:640px) {
  .hero {
    padding-top: 48px;
  }
}

@media (max-width:640px) {
  .btn-mono {
    padding: 8px 14px;
    font-size: 11px;
  }
}

@media (prefers-reduced-motion: reduce) {
  section.block {
    opacity: 1;
    transform: none;
    transition: none;
  }
}

@media (prefers-reduced-motion: reduce) {
  #network-bg {
    display: none;
  }
}

/* ============================================================
   LOGIN
   ============================================================ */

.login-shell {
  min-height: calc(100vh - 73px);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 48px 20px;
}

.login-card {
  width: 100%;
  max-width: 420px;
  border: 1px solid var(--line);
  background: var(--bg-panel);
  padding: 44px;
}

.login-title {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 28px;
}

.login-sub {
  color: var(--text-2);
  font-size: 14.5px;
}

.form-label-mono {
  display: block;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--text-3);
  margin-bottom: 8px;
}

.form-control-mono {
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: 0;
  color: var(--text-1);
  font-family: var(--font-body);
  font-size: 15px;
  padding: 12px 14px;
}

.form-control-mono::placeholder {
  color: var(--text-3);
}

.form-control-mono:focus {
  background: var(--bg);
  color: var(--text-1);
  border-color: var(--text-1);
  box-shadow: none;
}

.password-hint {
  font-family: var(--font-mono);
  font-size: 11.5px;
  line-height: 1.5;
  color: var(--text-3);
}

.password-hint code {
  color: var(--text-2);
  background: var(--bg);
  border: 1px solid var(--line-soft);
  padding: 1px 5px;
}

.login-error {
  font-family: var(--font-mono);
  font-size: 12.5px;
  color: var(--text-1);
  border: 1px solid var(--line);
  border-left: 2px solid var(--text-1);
  padding: 10px 14px;
  background: var(--bg);
}

.login-link {
  font-size: 13px;
  color: var(--text-2);
  border-bottom: 1px solid var(--line-soft);
}

.login-link:hover {
  color: var(--text-1);
  border-color: var(--text-1);
}

.login-help {
  font-size: 12.5px;
  color: var(--text-3);
}

.login-help a {
  color: var(--text-2);
  border-bottom: 1px solid var(--line-soft);
}

.login-help a:hover {
  color: var(--text-1);
}

/* ============================================================
   DASHBOARD
   ============================================================ */

.user-tag {
  font-family: var(--font-mono);
  font-size: 12.5px;
  color: var(--text-2);
}

.user-tag #user-name {
  color: var(--text-1);
}

.subsection-label {
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--text-3);
  margin-bottom: 14px;
}

.file-row {
  border-color: var(--line-soft) !important;
  transition: padding-left .25s ease;
}

.file-row:hover {
  padding-left: 10px;
}

.file-badge {
  font-family: var(--font-mono);
  font-size: 10.5px;
  letter-spacing: 0.06em;
  color: var(--text-2);
  border: 1px solid var(--line);
  padding: 4px 9px;
  white-space: nowrap;
}

.file-empty {
  font-family: var(--font-mono);
  font-size: 13px;
  color: var(--text-3);
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100%;
  text-align: center;
  padding: 20px;
}

.div-head-video-back {
  width: 100%;
  z-index: -10;
}

