.lobster-regular {
  font-family: "Lobster", sans-serif;
  font-weight: 400;
  font-style: normal;
}


.open-sans {
  font-family: "Open Sans", sans-serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
  font-variation-settings:
    "wdth" 100;
}

body {
  margin: 0;
  font-family: Arial, sans-serif;
  color: rgb(177, 41, 41);
  background: #abaaaa !important; /* gris claro profesional */



}

.hero {
  text-align: center;
  padding: 30px 20px 50px;
}

.hero-icon {
  width: 300px;
  height: auto;
  margin-bottom: 0;
  opacity: 0.95;
  filter: drop-shadow(0 3px 6px rgba(0,0,0,0.15));

}

.hero h1 {
  font-size: 42px;
  font-weight: 700;
  color: #0b1a33;
  margin-bottom: 10px;
}

.separator {
  width: 80px;
  height: 4px;
  background: #d4af37;
  margin: 15px auto 25px;
  border-radius: 4px;
}

.hero .subtitle {
  font-size: 18px;
  color: #555;
  max-width: 600px;
  margin: 0 auto;
}

.cards-wrapper {
  background: rgb(222, 222, 222);
  padding: 40px 30px;
  border-radius: 16px;
  max-width: 1200px;
  margin: 40px auto;
  box-shadow: 0 10px 25px rgba(0,0,0,0.08);
}

.grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
  gap: 20px;
  padding: 40px;
}

.card {
  justify-content: space-between;
  align-items: center;
  animation: fadeIn 1s ease;
}

@keyframes fadeIn {
  from { opacity: 0; transform: translateY(10px); }
  to { opacity: 1; transform: translateY(0); }
}

.card img {
  width: 100%;
  object-fit: contain;
}

.card1 {
  background: linear-gradient(to right, #43a833eb, #dc1b22e7);
  padding: 20px;
  border-radius: 12px;
  text-align: center;
  transition: transform .2s, background .2s;
}

.card1:hover {
  transform: translateY(-5px);
  background: linear-gradient(to right, #34762b, #dc141b);
}

.card1 img {
  width:100%;
  height :250px;
}

.card1 a {
  display: inline-block;
  margin-top: 10px;
  padding: 10px 20px;
  background: linear-gradient(to right, #DC141A, #34762bbb);
  color: black;
  text-decoration: none;
  border-radius: 6px;
}

.card1 a:hover {
  background: linear-gradient(to right, #34762bbb, #DC141A);
}

.card2 {
  background: #244679 !important;
  padding: 20px;
  border-radius: 12px;
  text-align: center;
  transition: transform .2s, background .2s;
}

.card2:hover {
  transform: translateY(-5px);
  background: #0D2F76 !important;
}

.botones1 {
    display: flex;
    justify-content: center;
    gap: 15px;
}

.botones1 a {
    padding: 10px 10px;
    background: linear-gradient(to right, #7b99c5, #16325c, #3266b3);
    color: black;
    text-decoration: none;
    border-radius: 6px;
    margin-top: 10px;
    border: 2px solid #d4b758;
    width: 100px;
}


.card2 a:hover {
  background: linear-gradient(to right, #16325c, #3266b3, #16325c);
}

.card3 {
  background: linear-gradient(to right, #ed5094, #702DE1);
  padding: 20px;
  border-radius: 12px;
  text-align: center;
  transition: transform .2s, background .2s;
}

.card3:hover {
  transform: translateY(-5px);
  background: linear-gradient(to right, #cd3c7a, #6940b0);
}

.botones2 {
    display: flex;
    justify-content: center;
    gap: 15px;
}

.botones2 a {
    padding: 10px 10px;
    background: linear-gradient(to right, #702DE1, #ed5094);
    color: black;
    text-decoration: none;
    border-radius: 6px;
    margin-top: 10px;
    width: 95px;
}

.card3 a:hover {
  background: linear-gradient(to right, #702DE1, #ed5094, #702DE1);
}

.card4 {
  background: #817f7f !important;
  padding: 20px;
  border-radius: 12px;
  text-align: center;
  transition: transform .2s, background .2s;
}

.card4:hover {
  transform: translateY(-5px);
  background: #5e5e5e !important;
}

.card4 a {
  display: inline-block;
  margin-top: 10px;
  padding: 10px 20px;
  background: linear-gradient(to right, #d4af37, #5E5A5B, #d4af37);
  color: white;
  text-decoration: none;
  border-radius: 6px;
}

.card4 a:hover {
  background: linear-gradient(to right, #5E5A5B, #d4af37, #5E5A5B);
  color: white;
}

.footer {
  text-align: center;
  padding: 50px 20px;
  margin-top: 60px;
  background: #cccbcb !important;
  border-top: 4px solid #d4af37; /* línea dorada premium */
}

.footer-title {
  font-size: 22px;
  font-weight: 700;
  color: #0b1a33;
  margin-bottom: 5px;
}

.footer-sub {
  font-size: 15px;
  color: #555;
  margin-bottom: 20px;
}

.footer-line {
  width: 60px;
  height: 3px;
  background: #d4af37;
  margin: 0 auto 20px;
  border-radius: 3px;
}

.footer-copy {
  font-size: 14px;
  color: #777;
}
