/* ========== LAYOUT STICKY ========== */
html, body { 
  height: 100%; 
  margin: 0;
  padding: 0;
  overflow-x: hidden;
}
body{
  min-height: 100vh;   /* fallback */
  min-height: 100svh;  /* preferido en navegadores modernos */
  display: flex;
  flex-direction: column;
  margin: 0;
  background: #0a0a0a;
  color: #e6e6e6;
  font-family: "Oswald","Lato",system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  width: 100%;
  max-width: 100%;
}
main{ flex: 1 0 auto; }
footer.lm-footer{ margin-top: auto; }

/* ========== FOOTER BASE ========== */
.lm-footer{ 
  background:#000; 
  color:#d7d7d7; 
  width: 100%;
  max-width: 100%;
  overflow-x: hidden;
}
.lm-footer .container{ 
  width:min(1200px,92%); 
  margin-inline:auto; 
  max-width: 100%;
  padding: 0 16px;
}

.lm-footer__content{
  display:grid;
  grid-template-columns:1.3fr 1fr 1fr 1fr;
  gap:48px;
  padding:56px 0 36px;
  width: 100%;
  max-width: 100%;
}

.lm-col--brand .lm-brand{ margin:0 0 10px; font-size:22px; letter-spacing:.4px; font-weight:700; }
.lm-tagline{ margin:0 0 18px; line-height:1.6; color:#bfbfbf; }

/* Social */
.lm-social{ display:flex; gap:14px; margin-top:12px; flex-wrap: wrap; }
.lm-social__btn{
  display:inline-flex; align-items:center; justify-content:center;
  width:36px; height:36px; border-radius:8px;
  border:1px solid rgba(255,255,255,.2);
  background:linear-gradient(#0b0b0b,#0a0a0a);
  color:#fff; text-decoration:none;
  transition:transform .2s ease, border-color .25s ease;
  flex-shrink: 0;
}
.lm-social__btn i{ font-size:18px; line-height:1; }
.lm-social__btn:hover{ transform:translateY(-2px); border-color:rgba(255,255,255,.4); }

/* Listas */
.lm-heading{ text-transform:uppercase; letter-spacing:.12em; font-size:13px; color:#bdbdbd; margin:6px 0 12px; }
.lm-list{ list-style:none; margin:0; padding:0; }
.lm-list li{ margin:10px 0; }
.lm-list a{ color:#e1e1e1; text-decoration:none; font-size:15px; }
.lm-list a:hover{ text-decoration:underline; }

/* Íconos en listas (Font Awesome) */
.lm-list--icons li{
  display:flex; align-items:center; gap:10px;
  margin-bottom:8px; color:#ccc;   /* texto gris */
}
.lm-list--icons li i{
  font-size:16px; color:#ccc; min-width:20px; text-align:center;
  flex-shrink: 0;
}
.lm-list--icons li a{ color:#fff; text-decoration:none; }
.lm-list--icons li a:hover{ text-decoration:underline; }

/* Si aún usas puntitos .lm-ico en otras listas, se mantienen minimal */
.lm-ico{
  width:18px; height:18px; border-radius:50%;
  border:1px solid #2a2a2a; display:inline-block; position:relative; flex:0 0 18px; opacity:.9;
}
.lm-ico::after{ content:""; position:absolute; inset:4px; border-radius:2px; border:1px solid #3a3a3a; }
.lm-ico[data-ico="pin"]::after{ transform:rotate(45deg); }
.lm-ico[data-ico="mail"]::after{ border-radius:1px; }
.lm-ico[data-ico="time"]::after{ border-radius:50%; }
.lm-ico[data-ico="star"]::after{ border-radius:50% 50% 0 50%; transform:rotate(45deg); }

/* ========== BARRA INFERIOR (disposición pedida) ========== */
.lm-footer__bottom{ 
  position:relative; 
  padding:16px 0; 
  border-top:1px solid #0f0f0f; 
  background:#000; 
  width: 100%;
  max-width: 100%;
  overflow-x: hidden;
}
.lm-bottom__row{ 
  position:relative; 
  min-height:60px; 
  width: 100%;
  max-width: 100%;
}

/* Abajo-izquierda */
.lm-copy{
  position:absolute; bottom:10px; left:0;
  margin:0; font-size:14px; color:#9c9c9c;
  max-width: calc(100% - 200px);
  word-wrap: break-word;
}
/* Abajo-derecha */
.lm-legal{
  position:absolute; bottom:10px; right:0; 
  display:flex; gap:22px;
  flex-wrap: wrap;
}
.lm-legal a{ 
  color:#9f9f9f; 
  font-size:13px; 
  text-decoration:none; 
  white-space: nowrap;
}
.lm-legal a:hover{ text-decoration:underline; }

/* Arriba-derecha (Back to top dentro del footer) */
.lm-to-top{
  position:absolute; top:10px; right:0;
  width:40px; height:40px; border-radius:8px;
  border:1px solid rgba(255,255,255,.3);
  background:transparent; color:#fff; cursor:pointer;
  display:flex; align-items:center; justify-content:center;
  transition:background .25s ease;
  flex-shrink: 0;
}
.lm-to-top:hover{ background:rgba(255,255,255,.1); }

/* ========== MODO COMPACTO ========== */
.lm-footer--compact .lm-footer__content{
  padding:28px 0 20px;
  gap:24px;
  grid-template-columns:1.1fr 1fr 1fr 1fr;
}
.lm-footer--compact .lm-col--brand .lm-brand{ font-size:18px; margin:0 0 6px; letter-spacing:.3px; }
.lm-footer--compact .lm-tagline{ margin:0 0 10px; line-height:1.45; font-size:14px; color:#c9c9c9; }

.lm-footer--compact .lm-social{ gap:8px; }
.lm-footer--compact .lm-social__btn{ width:28px; height:28px; }

.lm-footer--compact .lm-heading{ font-size:12px; margin:2px 0 8px; letter-spacing:.1em; }
.lm-footer--compact .lm-list li{ margin:6px 0; }
.lm-footer--compact .lm-list a{ font-size:14px; }

.lm-footer--compact .lm-ico{ width:14px; height:14px; flex:0 0 14px; }
.lm-footer--compact .lm-ico::after{ inset:3px; }

.lm-footer--compact .lm-footer__bottom{ padding:10px 0; }
.lm-footer--compact .lm-bottom__row{ min-height:40px; }
.lm-footer--compact .lm-copy,
.lm-footer--compact .lm-legal a{ font-size:12px; }
.lm-footer--compact .lm-to-top{ width:30px; height:30px; }

/* ========== RESPONSIVE MEJORADO ========== */
@media (max-width:1000px){
  .lm-footer__content{ 
    grid-template-columns:1fr 1fr; 
    gap:32px; 
    padding: 40px 0 30px;
  }
  .lm-footer--compact .lm-footer__content{ gap:18px; }
}

@media (max-width:768px){
  .lm-footer__content{ 
    grid-template-columns:1fr; 
    gap:28px; 
    padding: 32px 0 24px;
  }
  .lm-footer--compact .lm-footer__content{ gap:16px; }
  
  .lm-footer .container {
    padding: 0 12px;
  }
  
  .lm-social {
    gap: 10px;
  }
  
  .lm-social__btn {
    width: 32px;
    height: 32px;
  }
  
  .lm-social__btn i {
    font-size: 16px;
  }
}

@media (max-width:640px){
  .lm-footer__content{ 
    grid-template-columns:1fr; 
    gap:24px; 
    padding: 24px 0 20px;
  }
  .lm-footer--compact .lm-footer__content{ gap:16px; }

  /* En móvil apilamos y centramos la barra inferior */
  .lm-legal, .lm-copy, .lm-to-top{ position:static; }
  .lm-bottom__row{ 
    display:grid; 
    gap:10px; 
    justify-items:center; 
    text-align: center;
  }
  .lm-legal{ 
    justify-content: center;
    gap: 16px;
  }
  .lm-legal a{ 
    margin:0 5px; 
    font-size: 12px;
  }
  
  .lm-copy {
    font-size: 12px;
    text-align: center;
  }
  
  .lm-footer .container {
    padding: 0 8px;
  }
  
  .lm-social {
    gap: 8px;
    justify-content: center;
  }
  
  .lm-social__btn {
    width: 28px;
    height: 28px;
  }
  
  .lm-social__btn i {
    font-size: 14px;
  }
}

@media (max-width: 480px) {
  .lm-footer .container {
    padding: 0 4px;
  }
  
  .lm-footer__content {
    gap: 20px;
    padding: 20px 0 16px;
  }
  
  .lm-legal {
    gap: 12px;
  }
  
  .lm-legal a {
    font-size: 11px;
  }
  
  .lm-copy {
    font-size: 11px;
  }
  
  .lm-social {
    gap: 6px;
  }
  
  .lm-social__btn {
    width: 24px;
    height: 24px;
  }
  
  .lm-social__btn i {
    font-size: 12px;
  }
}