/* snorkelsandfins.com — header D+E (ocean split + glass) + footer 3+4 (card on teal + badge strip) */

.wrapper {
  padding-top: 7rem !important;
}

/* ── HEADER: ocean gradient, left coral stripe, light controls ── */
.header {
  height: 7rem !important;
  background: linear-gradient(105deg, #0a3d62 0%, #1a5f8a 55%, #145374 100%) !important;
  border-bottom: none !important;
  box-shadow: 0 0.35rem 1.6rem rgba(4, 47, 61, 0.35) !important;
  backdrop-filter: blur(6px);
}

.header::before {
  content: "" !important;
  display: block !important;
  position: absolute !important;
  left: 0 !important;
  top: 0 !important;
  bottom: 0 !important;
  width: 0.42rem !important;
  background: linear-gradient(180deg, #ff9a76 0%, #ff7e5f 48%, #e85d4a 100%) !important;
}

.header::after {
  content: none !important;
  display: none !important;
}

.header .logo::before,
.header .logo::after {
  content: none !important;
  display: none !important;
}

.header .search-toggle svg {
  fill: #e8f7fa !important;
}

.header .search-toggle:hover svg,
.header .search-toggle:focus svg,
.header .search-toggle--active svg {
  fill: #ff9a76 !important;
}

.header__menu-toggle {
  border-top-color: #e8f7fa !important;
  border-bottom-color: #e8f7fa !important;
}

.header__menu-toggle span {
  background: #e8f7fa !important;
}

/* Flags — capsule outline, coral active ring */
.header__nav ul {
  display: flex !important;
  align-items: center !important;
  gap: 0.55rem !important;
  margin: 0 !important;
  padding: 0 !important;
  list-style: none !important;
}

.header__nav a {
  display: inline-flex !important;
  padding: 0.2rem 0.55rem !important;
  border-radius: 999px !important;
  border: 0.14rem solid rgba(232, 247, 250, 0.35) !important;
  background: rgba(255, 255, 255, 0.08) !important;
  transition: border-color 0.2s, background 0.2s, box-shadow 0.2s !important;
}

.header__nav a:hover,
.header__nav a:focus {
  border-color: rgba(255, 154, 118, 0.75) !important;
  background: rgba(255, 255, 255, 0.14) !important;
  box-shadow: 0 0 0 0.12rem rgba(255, 126, 95, 0.25) !important;
}

.header__nav a[aria-current="page"] {
  border-color: #ff9a76 !important;
  background: rgba(255, 126, 95, 0.18) !important;
  box-shadow: 0 0 0 0.14rem rgba(255, 154, 118, 0.35) !important;
}

.header__nav a img {
  display: block !important;
  border-radius: 0.25rem !important;
}

@media screen and (max-width: 1199px) {
  .header__nav {
    top: 6.9rem !important;
    min-width: 13.5rem !important;
    padding: 0.95rem 1rem !important;
    background: #0d4a6e !important;
    border: 0.1rem solid rgba(255, 154, 118, 0.4) !important;
    border-radius: 0.75rem !important;
    box-shadow: 0 0.55rem 2rem rgba(4, 35, 48, 0.45) !important;
  }

  .header__nav ul {
    flex-direction: column !important;
    align-items: flex-end !important;
    gap: 0.65rem !important;
  }

  .header__nav li:nth-child(n+2) {
    margin-top: 0 !important;
  }
}

@media screen and (min-width: 1200px) {
  .header__menu-toggle {
    display: none !important;
  }
}

/* Intro-home anchors — single row on desktop */
@media (min-width: 992px) {
  .intro-home__list {
    display: flex !important;
    flex-wrap: nowrap !important;
    justify-content: center !important;
    align-items: stretch !important;
    gap: 0.5rem !important;
    margin: 0 !important;
    padding: 0 !important;
    list-style: none !important;
  }

  .intro-home__list li {
    flex: 1 1 0 !important;
    min-width: 0 !important;
    margin: 0 !important;
  }

  .intro-home__list a {
    width: 100% !important;
    max-width: none !important;
    margin: 0 !important;
    padding: 1rem 0.4rem !important;
    font-size: 1.35rem !important;
    line-height: 1.2 !important;
    justify-content: center !important;
    text-align: center !important;
    gap: 0.35rem !important;
  }

  .intro-home__list svg {
    margin-right: 0 !important;
    width: 2.5rem !important;
    height: 2.5rem !important;
    flex-shrink: 0 !important;
  }
}

@media (min-width: 1200px) {
  .intro-home__list {
    gap: 0.7rem !important;
  }

  .intro-home__list a {
    flex-direction: row !important;
    padding: 1.05rem 0.5rem !important;
    font-size: 1.45rem !important;
    text-align: left !important;
    justify-content: flex-start !important;
  }

  .intro-home__list svg {
    margin-right: 0.5rem !important;
    width: 2.75rem !important;
    height: 2.75rem !important;
  }
}

/* ── SITE-WIDE: ocean card / timeline content theme ── */
body {
  background: #e8f4f6 !important;
}

.wrapper:not(.wrapper--utility) {
  background: #e8f4f6;
}

/* Hero — light panel, dark text (readable on all breakpoints) */
.intro-home {
  padding: 2.5rem 0 3.5rem !important;
  color: #4a6572 !important;
  background-color: #e8f4f6 !important;
  background-image: linear-gradient(180deg, #f0f9fb 0%, #e8f4f6 55%, #d4ecef 100%) !important;
  border-bottom: 0.35rem solid #ff7e5f !important;
}

.intro-home__title {
  margin: 0 0 1.2rem !important;
  color: #0a3d62 !important;
  font-size: 3.2rem !important;
  font-weight: 700 !important;
  line-height: 1.2 !important;
}

.intro-home__text {
  max-width: 72rem;
  margin: 0 auto 2.5rem !important;
  color: #4a6572 !important;
  font-size: 1.55rem !important;
  line-height: 1.65 !important;
}

.intro-home__list a {
  border: 0.1rem solid rgba(10, 61, 98, 0.1) !important;
  box-shadow: 0 0.35rem 1.2rem rgba(10, 61, 98, 0.1) !important;
  color: #0a3d62 !important;
  background: #ffffff !important;
  transition: border-color 0.2s, color 0.2s, transform 0.2s, box-shadow 0.2s !important;
}

.intro-home__list a:hover,
.intro-home__list a:focus {
  color: #e85d4a !important;
  border-color: rgba(255, 126, 95, 0.55) !important;
  box-shadow: 0 0.45rem 1.5rem rgba(10, 61, 98, 0.14) !important;
  transform: translateY(-0.1rem);
}

@media screen and (min-width: 576px) {
  .intro-home {
    background-color: #e8f4f6 !important;
    background-image: linear-gradient(180deg, #f0f9fb 0%, #e8f4f6 55%, #d4ecef 100%) !important;
  }
}

@media screen and (min-width: 768px) {
  .intro-home {
    background-color: #e8f4f6 !important;
    background-image: linear-gradient(180deg, #f0f9fb 0%, #e8f4f6 55%, #d4ecef 100%) !important;
  }
}

@media screen and (min-width: 992px) {
  .intro-home {
    background-color: #e8f4f6 !important;
    background-image: linear-gradient(180deg, #f0f9fb 0%, #e8f4f6 55%, #d4ecef 100%) !important;
  }
}

@media screen and (min-width: 1200px) {
  .intro-home {
    padding: 3rem 0 3.5rem !important;
    background-color: #e8f4f6 !important;
    background-image: linear-gradient(180deg, #f0f9fb 0%, #e8f4f6 55%, #d4ecef 100%) !important;
  }
}

/* Main content panel */
.content {
  padding: 2rem 0 4rem !important;
  background: #d4ecef !important;
}

.content .container {
  position: relative;
  padding: 2.5rem 1.6rem 3rem !important;
  background: linear-gradient(180deg, #f7fcfd 0%, #ffffff 38%, #f4fafb 100%) !important;
  border-radius: 1rem !important;
  border: 0.1rem solid rgba(10, 61, 98, 0.07) !important;
  box-shadow: 0 0.55rem 2.2rem rgba(10, 61, 98, 0.1) !important;
}

.content .container::before,
.content .container::after {
  content: "";
  display: none;
  position: absolute;
  top: 1rem;
  bottom: 1rem;
  width: 0.42rem;
  border-radius: 0.3rem;
  background: linear-gradient(180deg, #1a5f8a 0%, #0a3d62 55%, #ff7e5f 100%);
  opacity: 0.85;
}

.content .container::before {
  left: 0;
}

.content .container::after {
  right: 0;
}

.content .heading {
  margin: 3rem 0 1rem !important;
  padding-bottom: 0.85rem !important;
  color: #0a3d62 !important;
  font-size: 2.4rem !important;
  font-weight: 700 !important;
  line-height: 1.3 !important;
  text-align: center;
  border-bottom: 0.22rem solid #ff7e5f;
}

.content .container > .heading:first-child,
.content .container > #casino-widget-iframe + script + .heading,
.content .container > h2.heading:first-of-type {
  margin-top: 0.5rem !important;
}

.content .container > p {
  max-width: 72rem;
  margin-left: auto !important;
  margin-right: auto !important;
  color: #4a6572 !important;
  font-size: 1.5rem !important;
  line-height: 1.65 !important;
  text-align: center;
}

.content #casino-widget-iframe {
  display: block;
  margin: 0 0 2rem !important;
  border-radius: 0.75rem !important;
  overflow: hidden;
  box-shadow: 0 0.35rem 1.4rem rgba(10, 61, 98, 0.1) !important;
}

/* Info-blocks — card stack, no overlapping icons (all main pages) */
.info-blocks__item {
  position: static !important;
}

@media screen and (min-width: 992px) {
  .info-blocks__item {
    padding-left: 1.8rem !important;
  }
}

.info-blocks__head {
  display: block !important;
  margin: 0 0 0.75rem !important;
}

.info-blocks__head img {
  display: none !important;
}

.content .info-blocks__item {
  margin-top: 1.5rem !important;
  padding: 1.6rem 1.8rem !important;
  padding-left: 1.8rem !important;
  background: #ffffff !important;
  border-radius: 0.85rem !important;
  border: 0.1rem solid rgba(10, 61, 98, 0.08) !important;
  border-left: 0.32rem solid #1a5f8a !important;
  box-shadow: 0 0.35rem 1.4rem rgba(10, 61, 98, 0.08) !important;
  transition: border-left-color 0.2s, box-shadow 0.2s, transform 0.2s;
}

.content .info-blocks__item:hover {
  border-left-color: #ff7e5f !important;
  box-shadow: 0 0.5rem 1.8rem rgba(10, 61, 98, 0.12) !important;
  transform: translateX(0.12rem);
}

.content .info-blocks__item .info-blocks__head .heading {
  color: #0a3d62 !important;
  font-size: 1.85rem !important;
}

.content .info-blocks__item p {
  color: #5a7380 !important;
  font-size: 1.45rem !important;
  line-height: 1.65 !important;
  text-align: left !important;
}

/* Games-money — bonus cards */
.content .games-money__card {
  border-radius: 0.85rem !important;
  border: 0.1rem solid rgba(10, 61, 98, 0.08) !important;
  border-left: 0.32rem solid #1a5f8a !important;
  box-shadow: 0 0.35rem 1.4rem rgba(10, 61, 98, 0.08) !important;
  overflow: hidden !important;
}

.content .games-money__title {
  padding: 1rem 1.2rem !important;
  color: #ffffff !important;
  font-size: 1.75rem !important;
  background: linear-gradient(135deg, #0a3d62 0%, #1a5f8a 100%) !important;
}

.content .games-money__list {
  padding: 1.2rem 1.6rem 1.4rem !important;
}

.content .games-money__list li {
  color: #5a7380 !important;
  font-size: 1.45rem !important;
  line-height: 1.65 !important;
}

/* Pros / cons — all main pages */
.pros-cons__list li::before {
  top: 0.15rem !important;
  width: 2.2rem !important;
  height: 2.2rem !important;
  background-color: transparent !important;
  background-repeat: no-repeat !important;
  background-position: center !important;
  background-size: contain !important;
}

.pros-cons__item--pros .pros-cons__list li::before {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24'%3E%3Cpath fill='%231a5f8a' fill-rule='evenodd' d='M0 12C0 2.118 2.118 0 12 0s12 2.118 12 12-2.118 12-12 12S0 21.882 0 12zm16.707-3.707a1 1 0 0 1 0 1.414l-5 5a1 1 0 0 1-1.414 0l-2.5-2.5a1 1 0 1 1 1.414-1.414L11 12.586l4.293-4.293a1 1 0 0 1 1.414 0z' clip-rule='evenodd'/%3E%3C/svg%3E") !important;
}

.pros-cons__item--cons .pros-cons__list li::before {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24'%3E%3Cpath fill='%23e85d4a' fill-rule='evenodd' d='M0 12C0 2.118 2.118 0 12 0s12 2.118 12 12-2.118 12-12 12S0 21.882 0 12zm8.465-3.536a1 1 0 0 1 1.414 0L12 10.586l2.121-2.121a1 1 0 1 1 1.415 1.414L13.414 12l2.122 2.121a1 1 0 0 1-1.415 1.415L12 13.414l-2.122 2.122a1 1 0 0 1-1.415-1.415L10.586 12 8.465 9.879a1 1 0 0 1 0-1.415z' clip-rule='evenodd'/%3E%3C/svg%3E") !important;
}

.content .pros-cons__item {
  padding: 1.6rem 1.8rem !important;
  background: #ffffff !important;
  border-radius: 0.85rem !important;
  border: 0.1rem solid rgba(10, 61, 98, 0.08) !important;
  box-shadow: 0 0.35rem 1.4rem rgba(10, 61, 98, 0.08) !important;
}

.content .pros-cons__item--pros {
  border-left: 0.32rem solid #1a5f8a !important;
}

.content .pros-cons__item--cons {
  border-left: 0.32rem solid #ff7e5f !important;
}

.content .pros-cons__title {
  color: #0a3d62 !important;
  font-size: 1.75rem !important;
}

.content .pros-cons__list li {
  padding-left: 3.2rem !important;
  color: #5a7380 !important;
  font-size: 1.45rem !important;
  line-height: 1.6 !important;
}

/* Legal / text subpages */
.content--legal .container > p,
.content--legal .container > ul,
.content--legal .container li,
.content--legal .container h2,
.content--legal .container h3,
.content--legal .container h4 {
  text-align: left !important;
}

.content--legal .heading {
  margin-top: 2.5rem !important;
  text-align: left !important;
}

.content--legal .container > .heading:first-child {
  margin-top: 0.5rem !important;
}

.content--legal .container > p {
  max-width: none !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
}

.content--legal .container ul {
  margin: 0 0 1.4rem 1.4rem !important;
  padding: 0 !important;
}

.content--legal .container li {
  margin-bottom: 0.45rem !important;
  color: #5a7380 !important;
  font-size: 1.45rem !important;
  line-height: 1.65 !important;
}

.content--legal .container a {
  color: #1a5f8a !important;
  text-decoration: underline !important;
  text-decoration-color: rgba(255, 126, 95, 0.55) !important;
}

.content--legal .container a:hover {
  color: #e85d4a !important;
}

/* Stepper — timeline */
.content .stepper__list li {
  padding-left: 4rem !important;
}

.content .stepper__list li:not(:last-child)::before {
  left: 1.45rem !important;
  width: 0.18rem !important;
  background: linear-gradient(180deg, #1a5f8a 0%, rgba(26, 95, 138, 0.2) 100%) !important;
}

.content .stepper__list li::after {
  left: 0.55rem !important;
  width: 1.9rem !important;
  height: 1.9rem !important;
  color: #ffffff !important;
  font-size: 1rem !important;
  font-weight: 700 !important;
  background: #ff7e5f !important;
  border: 0.28rem solid #ffffff !important;
  box-shadow: 0 0 0 0.18rem rgba(26, 95, 138, 0.35) !important;
  border-radius: 50% !important;
  background-image: none !important;
}

.content .stepper__list li:last-child::after {
  background: #0a3d62 !important;
  background-image: none !important;
}

.content .stepper__list li:last-child p,
.content .stepper__list li:last-child .stepper__title {
  color: #0a3d62 !important;
}

.content .stepper__list li {
  color: #5a7380 !important;
  font-size: 1.45rem !important;
  line-height: 1.65 !important;
}

/* FAQ accordion cards */
.content .faq__card {
  padding: 1.2rem 1.4rem 1rem 1.6rem !important;
  background: #ffffff !important;
  border: 0.1rem solid rgba(10, 61, 98, 0.1) !important;
  border-left: 0.32rem solid #1a5f8a !important;
  border-radius: 0.85rem !important;
  box-shadow: 0 0.3rem 1.2rem rgba(10, 61, 98, 0.07) !important;
}

.content .faq__label {
  color: #0a3d62 !important;
  font-size: 1.55rem !important;
}

.content .faq__label:hover,
.content .faq__label:focus {
  color: #e85d4a !important;
}

.content .faq__label::before {
  border-color: #1a5f8a !important;
}

.content .faq__label:hover::before {
  border-color: #ff7e5f !important;
}

.content .faq__body {
  color: #5a7380 !important;
  font-size: 1.45rem !important;
  line-height: 1.65 !important;
}

/* Tables */
.content table {
  width: 100%;
  margin: 0 0 2rem !important;
  border-collapse: collapse;
  font-size: 1.4rem;
  background: #ffffff;
  border-radius: 0.75rem;
  overflow: hidden;
  box-shadow: 0 0.35rem 1.4rem rgba(10, 61, 98, 0.08);
}

.content table th,
.content table td {
  padding: 1rem 1.2rem;
  border: 0.1rem solid rgba(10, 61, 98, 0.08);
  text-align: left;
}

.content table th {
  color: #ffffff;
  font-weight: 700;
  background: linear-gradient(135deg, #0a3d62, #1a5f8a);
}

.content table td {
  color: #5a7380;
}

.content table tbody tr:nth-child(even) td {
  background: #f0f9fb;
}

/* Utility pages — same shell */
.wrapper--utility {
  background: #d4ecef !important;
}

.page-standalone--in-site .container,
.redirection-page--in-site > .container {
  position: relative;
  padding: 2rem 1.6rem !important;
}

.page-standalone--in-site .container::before,
.page-standalone--in-site .container::after,
.redirection-page--in-site > .container::before,
.redirection-page--in-site > .container::after {
  content: "";
  display: none;
  position: absolute;
  top: 0.5rem;
  bottom: 0.5rem;
  width: 0.42rem;
  border-radius: 0.3rem;
  background: linear-gradient(180deg, #1a5f8a 0%, #0a3d62 55%, #ff7e5f 100%);
  opacity: 0.85;
}

.page-standalone--in-site .container::before,
.redirection-page--in-site > .container::before {
  left: 0;
}

.page-standalone--in-site .container::after,
.redirection-page--in-site > .container::after {
  right: 0;
}

.page-standalone__card,
.redirection-page--in-site .redirection-page__card {
  border: 0.1rem solid rgba(10, 61, 98, 0.08) !important;
}

@media screen and (min-width: 768px) {
  .intro-home__title {
    color: #0a3d62 !important;
    font-size: 3.8rem !important;
  }

  .intro-home__text {
    color: #4a6572 !important;
  }

  .content .container {
    padding: 3rem 3.2rem 3.5rem !important;
  }

  .content .container::before,
  .content .container::after {
    display: block;
  }

  .content .heading {
    font-size: 2.8rem !important;
  }

  .page-standalone--in-site .container::before,
  .page-standalone--in-site .container::after,
  .redirection-page--in-site > .container::before,
  .redirection-page--in-site > .container::after {
    display: block;
  }

  .page-standalone--in-site .container,
  .redirection-page--in-site > .container {
    padding-left: 3.5rem !important;
    padding-right: 3.5rem !important;
  }
}

@media screen and (min-width: 1200px) {
  .content .container {
    padding-left: 4.5rem !important;
    padding-right: 4.5rem !important;
  }

  .content .container::before,
  .content .container::after {
    width: 0.5rem;
  }

  .intro-home__title {
    color: #0a3d62 !important;
    font-size: 4.2rem !important;
  }

  .intro-home__text {
    color: #4a6572 !important;
  }
}

/* ── FOOTER: teal outer + white card + dark badge inset ── */
.footer {
  padding: 2.5rem 0 2rem !important;
  color: #1e3a4a !important;
  background-color: #d4ecef !important;
  background-image: none !important;
}

.footer::before {
  content: none !important;
  display: none !important;
}

.footer .container {
  max-width: 98rem !important;
  margin: 0 auto !important;
  padding: 2.4rem 2rem 1.6rem !important;
  background: #ffffff !important;
  border-radius: 1rem !important;
  border: 0.1rem solid rgba(10, 61, 98, 0.1) !important;
  box-shadow: 0 0.6rem 2.5rem rgba(10, 61, 98, 0.12) !important;
}

.footer__nav {
  display: none !important;
}

.footer__tel {
  display: none !important;
}

.footer__subtitle {
  display: inline-block !important;
  margin: 0 0 1.6rem !important;
  padding-bottom: 0.45rem !important;
  color: #0a3d62 !important;
  font-size: 1.45rem !important;
  font-weight: 700 !important;
  line-height: 1.35 !important;
  border-bottom: 0.28rem solid #ff7e5f !important;
}

.footer__info {
  display: flex !important;
  flex-wrap: wrap !important;
  align-items: center !important;
  gap: 1.2rem 1.6rem !important;
  margin-bottom: 1.6rem !important;
}

.footer__info-imgs {
  display: flex !important;
  flex-wrap: wrap !important;
  align-items: center !important;
  gap: 0.85rem !important;
  margin: 0 !important;
  padding: 0.85rem 1rem !important;
  background: #063a4a !important;
  border-radius: 0.65rem !important;
  border-left: 0.35rem solid #ff7e5f !important;
}

.footer__info-imgs img {
  border-radius: 0.35rem !important;
  margin: 0 !important;
}

.footer__info-imgs img:nth-child(n+2) {
  margin-left: 0 !important;
}

.footer__info-help {
  flex: 1 1 14rem !important;
  margin: 0 !important;
  color: #0a3d62 !important;
  font-size: 1.3rem !important;
  line-height: 1.45 !important;
  text-decoration: none !important;
  border-bottom: 0.12rem dashed rgba(10, 61, 98, 0.35) !important;
}

.footer__info-help:hover,
.footer__info-help:focus {
  color: #e85d4a !important;
  border-bottom-color: #ff7e5f !important;
}

.footer__desc {
  margin: 0 0 1.6rem !important;
  padding: 1.1rem 1.25rem !important;
  font-size: 1.2rem !important;
  line-height: 1.65 !important;
  color: #3d5a6a !important;
  background: #f0f9fb !important;
  border-radius: 0.6rem !important;
  border: 0.1rem solid rgba(10, 61, 98, 0.08) !important;
}

.footer__desc b {
  color: #0a3d62 !important;
}

.footer__bottom {
  display: flex !important;
  flex-wrap: wrap !important;
  align-items: center !important;
  justify-content: flex-start !important;
  gap: 0.5rem 1.2rem !important;
  margin: 0 !important;
  padding: 1rem 0 0 !important;
  list-style: none !important;
  font-size: 1.15rem !important;
  border-top: 0.1rem solid rgba(10, 61, 98, 0.1) !important;
}

.footer__bottom li:nth-child(2) {
  margin-left: 0 !important;
  padding-left: 0 !important;
}

.footer__bottom li:nth-child(2)::before {
  display: none !important;
  content: none !important;
}

.footer__bottom li:last-child {
  width: 100% !important;
  margin-top: 0.4rem !important;
  padding-left: 0 !important;
  color: #6a8494 !important;
}

.footer__bottom li:last-child::before {
  display: none !important;
  content: none !important;
}

.footer__bottom a {
  color: #0a3d62 !important;
  font-weight: 600 !important;
  text-decoration: underline !important;
  text-underline-offset: 0.18rem !important;
  text-decoration-color: rgba(255, 126, 95, 0.55) !important;
  transition: color 0.2s, text-decoration-color 0.2s !important;
}

.footer__bottom a:hover,
.footer__bottom a:focus {
  color: #e85d4a !important;
  text-decoration-color: #ff7e5f !important;
}

@media screen and (min-width: 576px) {
  .footer {
    padding: 2.5rem 0 2rem !important;
    background-color: #d4ecef !important;
    background-image: none !important;
  }
}

@media screen and (min-width: 768px) {
  .footer {
    background-color: #d4ecef !important;
    background-image: none !important;
  }

  .footer__bottom li:last-child {
    width: auto !important;
    margin-top: 0 !important;
    margin-left: auto !important;
  }
}

@media screen and (min-width: 992px) {
  .footer {
    padding: 3rem 0 2.5rem !important;
    background-color: #d4ecef !important;
    background-image: none !important;
  }
}

@media screen and (min-width: 1200px) {
  .footer {
    background-color: #d4ecef !important;
    background-image: none !important;
  }
}

/* ── Utility pages ── */
.wrapper--utility {
  min-height: calc(100vh - 7rem);
  padding-top: 7rem !important;
  padding-bottom: 3rem;
}

.page-standalone--in-site {
  padding: 4rem 0;
}

.page-standalone--in-site .container {
  max-width: 56rem;
}

.page-standalone__card {
  padding: 3rem 2.4rem;
  text-align: center;
  background: #ffffff;
  border-radius: 1rem;
  box-shadow: 0 0.5rem 2.2rem rgba(10, 61, 98, 0.12);
  border-left: 0.4rem solid #ff7e5f;
}

.page-standalone__code {
  margin: 0 0 0.5rem;
  color: #0a3d62;
  font-size: 6rem;
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0.04em;
}

.page-standalone__title {
  margin: 0 0 1rem;
  color: #0a3d62;
  font-size: 2.4rem;
  font-weight: 700;
}

.page-standalone__text {
  margin: 0 0 2rem;
  color: #3d5a6a;
  font-size: 1.6rem;
  line-height: 1.5;
}

.page-standalone__actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 1rem;
}

.page-standalone__btn {
  display: inline-block;
  padding: 1rem 2rem;
  color: #fff;
  font-size: 1.4rem;
  font-weight: 600;
  text-decoration: none;
  background: linear-gradient(135deg, #0a3d62, #1a5f8a);
  border-radius: 2rem;
  transition: opacity 0.2s, transform 0.2s;
}

.page-standalone__btn:hover,
.page-standalone__btn:focus {
  opacity: 0.92;
  transform: translateY(-0.1rem);
}

.page-standalone__btn--alt {
  color: #0a3d62;
  background: #f0f9fb;
  border: 0.1rem solid rgba(10, 61, 98, 0.18);
}

.page-standalone__btn--alt:hover,
.page-standalone__btn--alt:focus {
  color: #e85d4a;
  border-color: #ff7e5f;
}

.redirection-page--in-site {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: calc(100vh - 7rem - 18rem);
  padding: 3rem 0;
}

.redirection-page--in-site .redirection-page__card {
  max-width: 48rem;
  width: 100%;
  margin: 0 auto;
  padding: 3rem 2.4rem;
  text-align: center;
  background: #ffffff;
  border-radius: 1rem;
  box-shadow: 0 0.5rem 2.2rem rgba(10, 61, 98, 0.12);
  border-left: 0.35rem solid #1a5f8a;
}

.redirection-page--in-site .wrapper {
  padding-top: 0 !important;
  display: block;
}

.redirection-page--in-site .wrapper img {
  display: block;
  max-width: 20rem;
  height: auto;
  margin: 0 auto 1.5rem;
}

.redirection-page--in-site h1 {
  margin: 0 0 1rem;
  color: #0a3d62;
  font-size: 2.4rem;
  font-weight: 700;
}

.redirection-page--in-site p {
  margin: 0 0 2rem;
  color: #3d5a6a;
  font-size: 1.6rem;
  line-height: 1.5;
}

.redirection-page__progress {
  height: 0.55rem;
  margin-bottom: 2rem;
  background: #d4ecef;
  border-radius: 0.3rem;
  overflow: hidden;
}

.redirection-page__progress-bar {
  display: block;
  height: 100%;
  width: 0;
  background: linear-gradient(90deg, #0a3d62, #ff7e5f);
  border-radius: 0.3rem;
  animation: snf-redirection-progress 2s ease forwards;
}

@keyframes snf-redirection-progress {
  from {
    width: 0;
  }

  to {
    width: 100%;
  }
}

.redirection-page--in-site > .container > a,
.redirection-page--in-site .redirection-page__card > a {
  color: #1a5f8a;
  font-weight: 600;
  text-decoration: none;
}

.redirection-page--in-site > .container > a:hover,
.redirection-page--in-site .redirection-page__card > a:hover {
  color: #e85d4a;
  text-decoration: underline;
}

/* ── Methodology timeline (inside content panel) ── */
.methodology-block {
  position: relative;
  margin: 3rem 0 3.5rem;
  padding: 0;
  background: none;
  border: none;
}

.methodology-block::before,
.methodology-block::after {
  display: none !important;
  content: none !important;
}

.methodology-block__title {
  margin-top: 0 !important;
}

.methodology-block__intro {
  max-width: 72rem;
  margin: 0 auto 2.8rem;
  color: #4a6572;
  font-size: 1.55rem;
  line-height: 1.65;
  text-align: center;
}

.methodology-timeline {
  position: relative;
  max-width: 78rem;
  margin: 0 auto;
  padding: 0 0 0 2.8rem;
  list-style: none;
  counter-reset: methodology-step;
}

.methodology-timeline::before {
  content: "";
  position: absolute;
  left: 0.95rem;
  top: 0.6rem;
  bottom: 0.6rem;
  width: 0.18rem;
  background: linear-gradient(180deg, #1a5f8a 0%, rgba(26, 95, 138, 0.25) 100%);
  border-radius: 0.2rem;
}

.methodology-timeline__item {
  position: relative;
  margin: 0 0 1.8rem;
  padding: 1.6rem 1.8rem 1.5rem;
  background: #ffffff;
  border-radius: 0.85rem;
  border: 0.1rem solid rgba(10, 61, 98, 0.08);
  border-left: 0.32rem solid #1a5f8a;
  box-shadow: 0 0.35rem 1.4rem rgba(10, 61, 98, 0.08);
  transition: border-left-color 0.2s, box-shadow 0.2s, transform 0.2s;
}

.methodology-timeline__item:last-child {
  margin-bottom: 0;
}

.methodology-timeline__item::before {
  content: "";
  position: absolute;
  left: -2.35rem;
  top: 1.85rem;
  width: 1.1rem;
  height: 1.1rem;
  background: #ff7e5f;
  border: 0.28rem solid #ffffff;
  border-radius: 50%;
  box-shadow: 0 0 0 0.22rem rgba(26, 95, 138, 0.35);
  z-index: 1;
}

.methodology-timeline__item:hover {
  border-left-color: #ff7e5f;
  box-shadow: 0 0.5rem 1.8rem rgba(10, 61, 98, 0.12);
  transform: translateX(0.15rem);
}

.methodology-timeline__title {
  margin: 0 0 0.65rem;
  color: #0a3d62;
  font-size: 1.75rem;
  font-weight: 700;
  line-height: 1.35;
}

.methodology-timeline__title::before,
.methodology-timeline__title::after {
  display: none !important;
  content: none !important;
}

.methodology-timeline__text {
  margin: 0;
  color: #5a7380;
  font-size: 1.45rem;
  line-height: 1.65;
}

@media screen and (min-width: 768px) {
  .methodology-block__intro {
    font-size: 1.65rem;
  }

  .methodology-timeline {
    padding-left: 3.2rem;
  }

  .methodology-timeline__item {
    padding: 1.8rem 2.2rem;
  }

  .methodology-timeline__item::before {
    left: -2.65rem;
    width: 1.25rem;
    height: 1.25rem;
  }

  .methodology-timeline__title {
    font-size: 1.9rem;
  }

  .methodology-timeline__text {
    font-size: 1.5rem;
  }
}
