/* Colores */
:root {
  --morado: #7C3AED;
  --morado-oscuro: #5B21B6;
  --morado-claro: #A78BFA;
  --negro: #0D0D0D;
  --negro-suave: #1F1F2E;
  --gris-oscuro: #374151;
  --gris-medio: #6B7280;
  --gris-claro: #D1D5DB;
  --blanco: #FFFFFF;
}

html {
  scroll-behavior: smooth;
}

body {
  font-family: 'DM Sans', sans-serif;
  font-size: 16px;
  background-color: var(--negro);
  color: var(--blanco);
}

a {
  text-decoration: none;
  color: inherit;
}

h1 { font-family: 'Syne', sans-serif; font-size: 40px; font-weight: 800; }
h2 { font-family: 'Syne', sans-serif; font-size: 32px; font-weight: 700; }
h3 { font-family: 'Syne', sans-serif; font-size: 24px; font-weight: 600; }
h4 { font-family: 'Syne', sans-serif; font-size: 20px; font-weight: 600; }
h5 { font-size: 16px; font-weight: 500; }
h6 { font-size: 14px; font-weight: 500; }
p  { font-size: 16px; }


/* Header */
header {
  height: 64px;
  padding: 0 5%;
  background-color: var(--negro);
  border-bottom: 1px solid var(--gris-oscuro);
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: center;
  gap: 40px;
}

.logo {
  font-family: 'Fira Code', monospace;
  font-size: 15px;
  color: var(--morado-claro);
}

nav {
  display: grid;
  grid-template-columns: repeat(4, auto);
  justify-content: end;
  gap: 4px;
  align-items: center;
}

nav a {
  font-size: 15px;
  font-weight: 500;
  color: var(--gris-claro);
  padding: 8px 12px;
}

nav a:hover {
  color: var(--blanco);
}

.dropdown {
  display: inline-block;
}

.dropdown-toggle {
  font-size: 15px;
  font-weight: 500;
  color: var(--gris-claro);
  padding: 8px 12px;
  cursor: pointer;
}

.dropdown:hover .dropdown-toggle {
  color: var(--blanco);
}

.dropdown-menu {
  display: none;
  background-color: var(--negro-suave);
  border: 1px solid var(--gris-oscuro);
}

.dropdown:hover .dropdown-menu {
  display: block;
}

.dropdown-menu a {
  display: block;
  padding: 10px 16px;
  font-size: 14px;
  color: var(--gris-claro);
}

.dropdown-menu a:hover {
  color: var(--morado-claro);
}


/* Secciones */
section {
  padding: 64px 5%;
}

.seccion-oscura {
  background-color: var(--negro-suave);
  border-top: 1px solid var(--gris-oscuro);
  border-bottom: 1px solid var(--gris-oscuro);
}

.divisor {
  width: 48px;
  height: 3px;
  background-color: var(--morado);
  margin: 16px 0 32px 0;
}

.btn {
  display: inline-block;
  background-color: var(--morado);
  color: var(--blanco);
  font-weight: 600;
  font-size: 15px;
  padding: 12px 24px;
  border: none;
  cursor: pointer;
}

.btn:hover {
  background-color: var(--morado-oscuro);
}


/* Hero */
#inicio {
  padding-top: 64px;
  text-align: center;
}

.hero-tag {
  display: inline-block;
  font-family: 'Fira Code', monospace;
  font-size: 13px;
  color: var(--morado-claro);
  background-color: var(--negro-suave);
  border: 1px solid var(--gris-oscuro);
  padding: 6px 16px;
  margin-bottom: 24px;
}

.hero-contenido h1 {
  color: var(--blanco);
  line-height: 1.1;
}

.nombre-apellido {
  color: var(--morado-claro);
  margin-bottom: 20px;
}

.hero-sub {
  color: var(--gris-medio);
  margin-bottom: 32px;
}


/* Sobre mi */
.sobre-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: start;
}

.foto-col {
  display: grid;
  gap: 20px;
}

.foto {
  width: 220px;
  height: 220px;
  background-color: var(--negro-suave);
  border: 4px solid var(--morado);
  display: grid;
  place-items: center;
  font-family: 'Syne', sans-serif;
  font-size: 60px;
  font-weight: 800;
  color: var(--morado-claro);
}

.badge {
  font-family: 'Fira Code', monospace;
  font-size: 12px;
  color: var(--morado-claro);
  background-color: var(--negro-suave);
  border: 1px solid var(--gris-oscuro);
  padding: 8px 16px;
}

.info-col {
  display: grid;
  gap: 20px;
}

.info-col p {
  color: var(--gris-claro);
  line-height: 1.7;
}

.skills-titulo {
  font-family: 'Fira Code', monospace;
  font-size: 12px;
  color: var(--morado-claro);
  letter-spacing: 2px;
  text-transform: uppercase;
}

.skills {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
}

.skills p {
  background-color: var(--negro);
  border: 1px solid var(--gris-oscuro);
  padding: 12px 16px;
  text-align: center;
  font-family: 'Fira Code', monospace;
  font-size: 13px;
  color: var(--blanco);
}

.skills p:hover {
  border-color: var(--morado-claro);
}


/* Ciberseguridad */
.cyber-intro {
  margin-bottom: 40px;
}

.cyber-intro p {
  color: var(--gris-claro);
  line-height: 1.7;
  margin-bottom: 12px;
}

.cyber-cards {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}

.cyber-card {
  background-color: var(--negro-suave);
  border: 1px solid var(--gris-oscuro);
  padding: 24px;
}

.cyber-card:hover {
  border-color: var(--morado-claro);
}

.cyber-icon {
  font-size: 28px;
  margin-bottom: 12px;
}

.cyber-card h4 {
  color: var(--blanco);
  margin-bottom: 10px;
}

.cyber-card p {
  font-size: 14px;
  color: var(--gris-medio);
  line-height: 1.6;
}

.tag {
  display: inline-block;
  margin-top: 12px;
  font-family: 'Fira Code', monospace;
  font-size: 11px;
  padding: 3px 10px;
  background-color: var(--negro);
  color: var(--morado-claro);
  border: 1px solid var(--gris-oscuro);
}


/* Proyectos */
.subtitulo-proyectos {
  margin-bottom: 24px;
  color: var(--morado-claro);
}

.proyectos-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin-bottom: 48px;
}

.proyecto-card {
  background-color: var(--negro);
  border: 1px solid var(--gris-oscuro);
}

.proyecto-card:hover {
  border-color: var(--morado-claro);
}

.proyecto-thumb {
  height: 160px;
  background-color: var(--negro-suave);
  display: grid;
  place-items: center;
  font-size: 40px;
  border-bottom: 1px solid var(--gris-oscuro);
}

.proyecto-body {
  padding: 20px;
}

.proyecto-body h4 {
  margin-bottom: 8px;
}

.proyecto-body p {
  font-size: 14px;
  color: var(--gris-medio);
  margin-bottom: 16px;
}

.techs {
  display: flex;
  gap: 6px;
}

.techs p {
  font-family: 'Fira Code', monospace;
  font-size: 11px;
  padding: 3px 10px;
  background-color: var(--negro-suave);
  color: var(--morado-claro);
  border: 1px solid var(--gris-oscuro);
}


/* Contacto */
.contacto-desc {
  color: var(--gris-medio);
  margin-bottom: 32px;
}

.form-wrap {
  display: grid;
  grid-template-columns: 1fr;
  width: 600px;
}

.form-group {
  margin-bottom: 16px;
}

label {
  display: block;
  font-size: 14px;
  font-weight: 500;
  color: var(--gris-claro);
  margin-bottom: 8px;
}

input, textarea {
  width: 100%;
  background-color: var(--negro-suave);
  border: 1px solid var(--gris-oscuro);
  padding: 12px 16px;
  font-family: 'DM Sans', sans-serif;
  font-size: 15px;
  color: var(--blanco);
  outline: none;
}

input::placeholder, textarea::placeholder {
  color: var(--gris-medio);
}

input:focus, textarea:focus {
  border-color: var(--morado);
}

textarea {
  height: 120px;
}

.form-wrap .btn {
  width: 100%;
  margin-top: 8px;
}


/* Footer */
footer {
  background-color: var(--negro-suave);
  border-top: 1px solid var(--gris-oscuro);
  padding: 32px 5%;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  align-items: center;
  gap: 24px;
}

.footer-nombre {
  font-family: 'Syne', sans-serif;
  font-weight: 700;
  font-size: 16px;
  color: var(--blanco);
}

.footer-links {
  display: flex;
  gap: 16px;
  justify-content: center;
}

.footer-links a {
  font-family: 'Fira Code', monospace;
  font-size: 13px;
  color: var(--gris-medio);
  padding: 8px 12px;
  border: 1px solid var(--gris-oscuro);
}

.footer-links a:hover {
  color: var(--morado-claro);
  border-color: var(--morado-claro);
}

.footer-copy {
  text-align: right;
  color: var(--gris-medio);
  font-size: 12px;
}
