/*
Implementation Skeleton v3 - 12/6/18
Add styles to overwrite customer CSS, USE WITH CAUTION.
*/

.promo-white{
	background: white;
}
.promo-cream{
	background: #f9f3cb;
}
.promo-navy{
	background: #ccd3da;
}
.promo-red{
	background: #990000;
}
.gradient-red-dark-light{
	background: linear-gradient(180deg, #990000 -0.02%, #D52027 96.5%);
}
.gradient-blue-dark-light{
	background: linear-gradient(180deg, #002244 -0.02%, #1791ad 96.5%);
}
.scrolling-promo-boxes-section .promo-title-white{
	color: white;
}


/* New CSS for the Fast Facts Section */
.fast_facts_whiteBG {
	--bgColor: #fff;
	--titleColor: #990000;
	--subtitleColor: black;
}
.fast_facts_redBG {
	--bgColor: #990000;
	--titleColor: #fff;
	--subtitleColor: #fff;
}
/* Existing class @ _rankings.scss:57	 */
.sb-rankings .rankings-wrapper .ranking-card .rank-value {
	color: var(--titleColor); /* modified */
	font-family: "Bitter", serif;
	font-size: 3.125rem;
	font-weight: 600;
	font-style: normal;
	line-height: 0.9;
	margin-bottom: 1rem;
}
/* Existing class @ _rankings.scss:75	 */
.sb-rankings .rankings-wrapper .ranking-card .rank-separator {
	width: 93px;
	border: 1px solid var(--subtitleColor);
	margin: 0 auto 1rem;
	opacity: 1;
}
/* Existing class @ _rankings.scss:105	 */
@media (min-width: 992px) {
	.sb-rankings .rankings-wrapper .row > div:first-of-type .ranking-card {
		border-left: 1px solid var(--subtitleColor);
	}
}
/* Existing class @ _rankings.scss:99	 */
@media (min-width: 992px) {
	.sb-rankings .rankings-wrapper .ranking-card {
		border-right: 1px solid var(--subtitleColor);
	}
}
/* Existing class @ _rankings.scss:161	 */
.sb-rankings .rankings-wrapper .rankings-cta::before {
	content: "";
	position: absolute;
	top: 50%;
	left: 0;
	right: 0;
	height: 1px;
	background-color: var(--subtitleColor);
	z-index: 0;
}
/* Existing class @ _variables.scss:244	 */
.sb-rankings .rankings-wrapper .rankings-cta .btn-link {
	position: relative;
	z-index: 1;
	display: inline-block;
	padding: 0 1rem;
	font-family: "Alumni Sans", sans-serif;
	font-weight: 600;
	font-size: 1.5625rem;
	font-style: normal;
	text-transform: uppercase;
	color: var(--titleColor);
	text-decoration: none;
	background-color: var(--bgColor);
	border-left: 1px solid var(--subtitleColor);
	border-right: 1px solid var(--subtitleColor);
}

/* Added classes */
.fast_facts {
	background-color: var(--bgColor);
	padding-top: 15px;
	padding-bottom: 20px;
}
.fast_facts_rank_title {
	margin: 0 0 6px;
	color: var(--titleColor);
	text-transform: uppercase;
	font-weight: 600;
	line-height: 1.12;
	font-size: 4em;
}	
.fast_facts_rank_subtitle {
	margin: 0 12% 50px;
	font-size: 1.5em;
	line-height: 1.2em;
	padding-bottom: 1em;
	color: var(--subtitleColor);
}
.rankings-wrapper {
	color: var(--subtitleColor);
}


/* Ticket 254599 */
.section-content-wrapper::after {
	content: "";
	display: block;
	clear: both;
}

/* CSS for Image Hero */
/*! 

==========================

 HOMEPAGE HERO (IMAGE DESKTOP)

========================== 

*/

.homepage-hero-image {
  position: relative;
  height: 1028px;
  margin-bottom: 116px;
}

@media (min-width: 992px) and (max-width: 1400px) {
  .homepage-hero-image {
    margin-bottom: clamp(0px, -282.04px + 28.4314vw, 116px);
  }
}

.homepage-hero-image .hero-background {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.homepage-hero-image .hero-background .image-container {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 2;
  clip-path: polygon(0 0, 100% 0, 100% 85%, 0 100%);
}

.homepage-hero-image .hero-background .image-container img {
  position: absolute;
  width: 100%;
  height: 100%;
  object-fit: cover;
  z-index: 1;
  pointer-events: none;
}

.homepage-hero-image .hero-background .image-container .hero-wrapper {
  position: relative;
  z-index: 2;
  height: 100%;
  pointer-events: auto;
}

.homepage-hero-image .hero-background .image-container .content-banner {
  display: flex;
  width: 495px;
  height: 100%;
  flex-direction: column;
  justify-content: flex-start;
  align-items: flex-end;
  border-right: 1px solid #FFFFFF;
  border-left: 1px solid #FFFFFF;
  background: #002244;
  position: relative;
  flex-shrink: 0;
}

.homepage-hero-image .hero-background .image-container .content-banner .banner-content-wrapper {
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  align-items: flex-start;
  padding-top: 90px;
  position: relative;
  z-index: 3;

}

.homepage-hero-image .hero-background .image-container .content-banner .banner-content-wrapper .banner-content {
  padding: 52px 0 0 0;
  margin-right: 48px;
  margin-left: 52px;
  width: auto;
  border-top: 1px solid #FFFFFF;
  position: relative;
  z-index: 3;
}

.homepage-hero-image .hero-background .image-container .content-banner .banner-content-wrapper .change-life-btn {
  display: flex;
  width: 208px;
  height: 56px;
  justify-content: center;
  align-items: center;
  color: #FFFFFF !important;
  font-family: "Alumni Sans", sans-serif;
  font-size: 2.0625rem;
  font-weight: 600;
  line-height: 0.6;
  text-decoration: none;
  background-color: #990000 !important;
  border: 1px solid #990000 !important;
  transition: all 0.3s ease;
  margin-bottom: 56px;
  text-transform: uppercase;
  position: relative;
  z-index: 3;
  cursor: pointer;
}

.homepage-hero-image .hero-background .image-container .content-banner .banner-content-wrapper .change-life-btn:hover, .homepage-hero-image .hero-background .image-container .content-banner .banner-content-wrapper .change-life-btn:focus {
  color: #990000 !important;
  background-color: #FFFFFF !important;
  border-color: #990000 !important;
}

.homepage-hero-image .hero-background .image-container .content-banner .banner-content-wrapper .hero-title {
  font-family: "Alumni Sans", sans-serif;
  font-size: 6.125rem;
  font-weight: 700;
  line-height: 1.1;
  color: #FFFFFF;
  font-weight: 800;
  line-height: 0.75;
  text-transform: uppercase;
  margin-bottom: 16px;
}

.homepage-hero-image .hero-background .image-container .content-banner .banner-content-wrapper .hero-subtitle {
  color: #FFFFFF;
  font-family: "Bitter", serif;
  font-size: 1.375rem;
  font-style: italic;
  font-weight: 400;
  line-height: 1.55;
  margin-bottom: 48px;
}

.homepage-hero-image .hero-background .image-container .content-banner .keyline {
  width: 395px;
  height: 1px;
  background: #FFFFFF;
  margin: 0 0 45px 0;
}

.homepage-hero-image .hero-background .image-container .content-banner .bottom-links {
  position: relative;
  z-index: 2;
  margin-bottom: 56px;
}

/* A11y: ensure hero quick links render as semantic list without bullets/extra spacing */
.homepage-hero-image .hero-background .image-container .content-banner .bottom-links .bottom-links-list {
  list-style: none;
  margin: 0;
  padding: 0;
}

/* Video hero variant */
.homepage-hero .hero-background .video-container .content-banner .bottom-links .bottom-links-list {
  list-style: none;
  margin: 0;
  padding: 0;
}

/* Tablet hero variant */
.homepage-hero-tablet .hero-background .hero-wrapper .content-banner > .banner-content .bottom-links .bottom-links-list {
  list-style: none;
  margin: 0;
  padding: 0;
}

.homepage-hero-image .hero-background .image-container .content-banner .bottom-links a {
  color: #BCCF9D;
  font-family: "Barlow Semi Condensed", sans-serif;
  font-size: 1.375rem;
  font-weight: 400;
  line-height: 1.6;
  text-decoration: underline;
  text-decoration-skip-ink: none;
  text-underline-offset: 37%;
  text-transform: uppercase;
  display: block;
  margin-bottom: 20px;
}

.homepage-hero-image .hero-background .image-container .content-banner .bottom-links a:hover {
  color: #FFFFFF;
}

.homepage-hero-image .hero-background .image-container .content-banner .bottom-links a:focus-visible {
  color: #FFFFFF;
  outline: 1px dashed #BCCF9D;
  outline-offset: 2px;
}

.homepage-hero-image .hero-background .image-container .content-banner > .prisms {
  position: absolute;
  bottom: 0;
  right: 0;
  width: 100%;
  height: auto;
  z-index: 1;
}

.homepage-hero-image .hero-background .bg-triangle {
  position: absolute;
  bottom: clamp(-160px, -160px + 100 * (1399px - 100vw) / 407, 0px);
  right: 0;
  width: 1500px;
  height: 500px;
  z-index: 1;
  transform-origin: bottom right;
}

.homepage-hero-image .hero-background .bg-triangle path {
  fill: #1791AD;
}

.homepage-hero-image .hero-wrapper {
  position: relative;
  z-index: 3;
  max-width: 1780px;
  height: 100%;
  margin: 0 auto;
  padding: 0 1.625rem;
  display: flex;
  justify-content: space-between;
  pointer-events: none;
}

.homepage-hero-image .hero-wrapper .action-buttons {
  position: absolute;
  right: 1.625rem;
  bottom: 30px;
  filter: drop-shadow(0 4px 8px rgba(0, 0, 0, 0.2));
  pointer-events: auto;
  background: #FFFFFF;
  padding: 1px;
}

/* A11y: normalize list semantics for CTA groups used across breakpoints */
.homepage-hero-image .hero-wrapper .action-buttons-list,
.action-buttons-tablet .action-buttons-list,
.mobile-action-buttons-container .action-buttons-list {
  list-style: none;
  margin: 0;
  padding: 0;
}
.homepage-hero-image .hero-wrapper .action-buttons-list > li,
.action-buttons-tablet .action-buttons-list > li,
.mobile-action-buttons-container .action-buttons-list > li {
  margin: 0;
}

/* Video hero CTA list */
.homepage-hero .hero-wrapper .action-buttons-list {
  list-style: none;
  margin: 0;
  padding: 0;
}
.homepage-hero .hero-wrapper .action-buttons-list > li {
  margin: 0;
}

/* Tablet hero: keep previous horizontal 3-up layout with new UL wrapper */
.homepage-hero-tablet .action-buttons-tablet .action-buttons-wrapper .action-buttons-list {
  display: flex;
  width: 100%;
}
.homepage-hero-tablet .action-buttons-tablet .action-buttons-wrapper .action-buttons-list > li {
  flex: 1 1 0;
}
.homepage-hero-tablet .action-buttons-tablet .action-buttons-wrapper .action-buttons-list > li > a.btn {
  width: 100%;
}

/* Mobile hero: replicate previous column layout with new UL wrapper */
.homepage-hero-mobile .mobile-action-buttons-container .action-buttons-wrapper .action-buttons-list {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1rem;
}

/* Sub-footer list semantics (visuals unchanged) */
.sb-sub-footer .sb-sub-footer-list {
  list-style: none;
  margin: 0;
  padding: 0;
}
.sb-sub-footer .sb-sub-footer-list li {
  display: inline;
}
.sb-sub-footer .sb-sub-footer-list li + li::before {
  content: " | ";
}


@media (max-width: 1199px) {
  .homepage-hero-image .hero-wrapper .action-buttons {
    bottom: 80px;
  }
}

.homepage-hero-image .hero-wrapper .action-buttons .btn {
  display: flex;
  height: 72px;
  padding: 18px 32px;
  justify-content: center;
  align-items: center;
  width: 346px;
  color: #FFFFFF;
  font-family: "Alumni Sans", sans-serif;
  font-size: 2.125rem;
  font-weight: 700;
  text-decoration: none;
  transition: all 0.3s ease;
  border-radius: 0;
  position: relative;
  overflow: hidden;
}

.homepage-hero-image .hero-wrapper .action-buttons .btn::after {
  content: "›";
  position: absolute;
  left: 60px;
  opacity: 0;
  transform: translateX(-20px);
  transition: all 0.3s ease;
}

.homepage-hero-image .hero-wrapper .action-buttons .btn:hover {
  transform: none;
}

.homepage-hero-image .hero-wrapper .action-buttons .btn:hover::after {
  opacity: 1;
  transform: translateX(0);
  left: 15px;
}

.homepage-hero-image .hero-wrapper .action-buttons .btn:focus-visible {
  outline: 2px solid #FFFFFF;
  outline-offset: 2px;
}

.homepage-hero-image .hero-wrapper .action-buttons .btn-apply {
  border-top: 6px solid #FFFFFF;
  border-right: 6px solid #FFFFFF;
  border-bottom: 3px solid #FFFFFF;
  border-left: 6px solid #FFFFFF;
  background: linear-gradient(270deg, #0166BA -0.02%, #00549A 45.99%, #002244 96.5%);
  text-transform: uppercase;
}

.homepage-hero-image .hero-wrapper .action-buttons .btn-apply:hover {
  background: linear-gradient(90deg, #0166BA -0.02%, #00549A 45.99%, #002244 96.5%);
}

.homepage-hero-image .hero-wrapper .action-buttons .btn-apply:focus-visible {
  outline: 2px solid #FFFFFF;
  outline-offset: 2px;
}

.homepage-hero-image .hero-wrapper .action-buttons .btn-tour {
  border-top: 3px solid #FFFFFF;
  border-right: 6px solid #FFFFFF;
  border-bottom: 3px solid #FFFFFF;
  border-left: 6px solid #FFFFFF;
  background: linear-gradient(90deg, #1791AD 0%, #BCCF9D 100%);
  text-transform: uppercase;
}

.homepage-hero-image .hero-wrapper .action-buttons .btn-tour:hover {
  background: linear-gradient(-90deg, #1791AD 0%, #BCCF9D 100%);
}

.homepage-hero-image .hero-wrapper .action-buttons .btn-tour:focus-visible {
  outline: 2px solid #FFFFFF;
  outline-offset: 2px;
}

.homepage-hero-image .hero-wrapper .action-buttons .btn-info {
  border-top: 3px solid #FFFFFF;
  border-right: 6px solid #FFFFFF;
  border-bottom: 6px solid #FFFFFF;
  border-left: 6px solid #FFFFFF;
  background: linear-gradient(270deg, #D52027 -0.02%, #990000 45.99%, #6B000D 96.5%);
  text-transform: uppercase;
}

.homepage-hero-image .hero-wrapper .action-buttons .btn-info:hover {
  background: linear-gradient(90deg, #D52027 -0.02%, #990000 45.99%, #6B000D 96.5%);
}

.homepage-hero-image .hero-wrapper .action-buttons .btn-info:focus-visible {
  outline: 2px solid #FFFFFF;
  outline-offset: 2px;
}

.homepage-hero-image .banner-content {
  padding: 0;
  margin-right: 48px;
  margin-left: 52px;
  width: auto;
}

.homepage-hero-image::before {
  content: "";
  display: none;
  --content-banner-left: 0px;
}

@media (min-width: 992px) {
  .homepage-hero-image::before {
    --content-banner-left: calc((100% - 495px) / 2);
  }
}
