html {
  font-size: 14px;
}

@media (min-width: 768px) {
  html {
    font-size: 16px;
  }
}

.btn:focus, .btn:active:focus, .btn-link.nav-link:focus, .form-control:focus, .form-check-input:focus {
  box-shadow: 0 0 0 0.1rem white, 0 0 0 0.25rem #258cfb;
}

html {
  position: relative;
  min-height: 100%;
}

body {
  margin-bottom: 60px;
}

/* Recommendation banner styles */
.recommendation-banner { 
 width:100%; 
 position: relative; 
 overflow: hidden; 
}
.recommendation-banner-image {
 width:100%;
 height:500px; /* desktop default */
 object-fit: cover;
 display: block;
}
.banner-overlay {
 padding:30px40px;
}

/* Responsive adjustments */
@media (max-width:1200px) {
 .recommendation-banner-image { height:420px; }
 .banner-overlay h2 { font-size:1.75rem; }
}
@media (max-width:768px) {
 .recommendation-banner-image { height:300px; }
 .banner-overlay { padding:18px; }
 .banner-overlay h2 { font-size:1.3rem; }
}
@media (max-width:480px) {
 .recommendation-banner-image { height:220px; }
 .banner-overlay { padding:12px; }
 .banner-overlay h2 { font-size:1.1rem; }
 .btn.btn-light.btn-sm { top:10px; left:8px; padding:6px8px; }
}