/* =================================================================
   Pre-footer (newsletter band)
   Large variant on the front page, compact variant on sub pages.
   Both sit directly above the slim footer.
   ================================================================= */
.site-prefooter {
  color: var(--color-text-inverted);
  font-family: var(--font-body);
}

/* ---- Large (front page) ---- */
.site-prefooter--large {
  position: relative;
  overflow: hidden;
  padding: 4.5rem 0 5rem;
  /* Sama gradientti kuin headerilla ja herolla, jotta valkoinen teksti
     säilyttää WCAG AA -kontrastin molemmissa teemoissa. */
  background: linear-gradient(180deg, var(--header-primary-bg) 0%, var(--header-utility-bg) 100%);
}

.site-prefooter--large::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(circle at 92% 18%, rgba(251, 191, 36, 0.18), transparent 45%),
    radial-gradient(circle at 8% 92%, rgba(251, 191, 36, 0.08), transparent 45%);
}

.site-prefooter__inner {
  position: relative;
  display: grid;
  grid-template-columns: 1.15fr 1fr;
  gap: 4rem;
  align-items: center;
}

.site-prefooter__copy {
  display: flex;
  flex-direction: column;
}

.site-prefooter__eyebrow {
  margin: 0 0 0.875rem;
  font-size: 0.75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: var(--color-accent);
}

.site-prefooter__title {
  margin: 0 0 1.125rem;
  font-family: var(--font-heading);
  font-weight: 600;
  font-size: clamp(2rem, 4vw, 2.75rem);
  line-height: 1.08;
  letter-spacing: -0.02em;
  color: var(--color-text-inverted);
  text-wrap: balance;
}

.site-prefooter__title--sm {
  font-size: clamp(1.5rem, 3vw, 1.75rem);
  margin-bottom: 0.375rem;
}

.site-prefooter__desc {
  margin: 0 0 1.375rem;
  max-width: 34rem;
  font-size: 1rem;
  line-height: 1.6;
  color: rgba(255, 255, 255, 0.78);
}

.site-prefooter__desc--sm {
  margin: 0;
  font-size: 0.9rem;
}

.site-prefooter__bullets {
  margin: 0;
  padding: 0;
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  font-size: 0.9rem;
  color: rgba(255, 255, 255, 0.82);
}

.site-prefooter__bullets li {
  display: flex;
  align-items: flex-start;
  gap: 0.625rem;
}

.site-prefooter__bullets li::before {
  content: "\2713";
  color: var(--color-accent);
  font-weight: 800;
}

.site-prefooter__card {
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: var(--radius-l);
  padding: 2rem;
  backdrop-filter: blur(6px);
}

.site-prefooter__disclaimer {
  margin: 0.75rem 0 0;
  font-size: 0.8rem;
  color: rgba(255, 255, 255, 0.5);
  text-align: center;
}

/* ---- Compact (sub pages) ---- */
.site-prefooter--compact {
  padding: 2.25rem 0;
  background: var(--header-primary-bg);
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

.site-prefooter__row {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: 2.5rem;
  align-items: center;
}

.site-prefooter--compact .site-footer__newsletter-form {
  max-width: 30rem;
}

/* =================================================================
   Slim footer (all pages)
   Three-part grid: brand · navigation · contact + social.
   ================================================================= */
.site-footer {
  background: var(--footer-bg);
  color: var(--color-text-light);
  padding: 1.75rem 0 1.25rem;
  margin-top: 0;
}

.site-footer a {
  color: var(--color-text-light);
  text-decoration: none;
}

.site-footer a:hover,
.site-footer a:focus-visible {
  text-decoration: underline;
}

.site-footer__inner {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 4rem;
}

.site-footer__brand {
  display: flex;
  align-items: center;
  gap: 0.9rem;
}

.site-footer__brand .site-logo {
  padding: 0;
  background: transparent;
  border: 0;
  border-radius: 0;
  box-shadow: none;
}

.site-logo--footer img {
  max-height: 56px;
  border-radius: 0;
  background: transparent;
}

.site-footer__brand-text {
  display: flex;
  flex-direction: column;
  gap: 0.15rem;
  line-height: 1.35;
}

.site-footer__brand-text strong {
  font-weight: 700;
  color: var(--color-text-inverted);
}

.site-footer__brand-text span {
  font-size: 0.875rem;
  color: rgba(255, 255, 255, 0.65);
}

.site-logo__link--footer {
  color: var(--color-text-light);
}

.site-footer__nav {
  display: flex;
  justify-content: center;
}

.site-footer__menu {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 0.5rem 1.375rem;
  list-style: none;
  margin: 0;
  padding: 0;
}

.site-footer__menu a {
  font-size: 0.9rem;
  font-weight: 500;
  color: rgba(255, 255, 255, 0.85);
}

.site-footer__menu a:hover {
  color: var(--color-text-inverted);
}

.site-footer__meta {
  display: flex;
  align-items: center;
  gap: 1.75rem;
}

.site-footer__contact {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.875rem;
  font-weight: 500;
  color: rgba(255, 255, 255, 0.85);
}

.site-footer__contact-icon {
  width: 18px;
  height: 18px;
  flex-shrink: 0;
  opacity: 0.7;
}

.site-footer__contact:hover .site-footer__contact-icon {
  opacity: 1;
}

.site-footer__social-list {
  display: flex;
  align-items: center;
  gap: 0.625rem;
  list-style: none;
  padding: 0;
  margin: 0;
}

.site-footer__social-link {
  display: grid;
  place-items: center;
  width: 40px;
  height: 40px;
  border-radius: var(--radius-pill);
  border: 1px solid rgba(255, 255, 255, 0.12);
  background: rgba(255, 255, 255, 0.02);
  color: var(--color-text-light);
  transition: transform var(--transition-hover), background var(--transition-hover), border-color var(--transition-hover), box-shadow var(--transition-hover);
}

.site-footer__social-link:hover,
.site-footer__social-link:focus-visible {
  background: rgba(255, 255, 255, 0.06);
  border-color: rgba(255, 255, 255, 0.28);
  box-shadow: 0 12px 26px rgba(0, 0, 0, 0.28);
  transform: translateY(-1px);
  text-decoration: none;
}

.site-footer__social-link svg {
  display: block;
  width: 28px;
  height: 28px;
  fill: currentColor;
}

.site-footer__legal {
  margin-top: 1.125rem;
  padding-top: 0.875rem;
  border-top: 1px solid rgba(255, 255, 255, 0.08);
  text-align: center;
  font-size: 0.8rem;
  color: rgba(255, 255, 255, 0.5);
}

/* =================================================================
   Newsletter form (AcyMailing) — shared by both pre-footer variants.
   Styles the AcyMailing-rendered fields, the logged-in button form and
   the status message on the dark/blue pre-footer background.
   ================================================================= */
.site-footer__newsletter-form {
  min-width: 0;
}

.site-footer__newsletter-form [id^="acym_fulldiv_"] {
  display: block !important;
  width: 100% !important;
  height: auto !important;
  min-height: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  background: transparent !important;
  color: var(--color-text-light) !important;
}

.site-footer__newsletter-form form,
.site-footer__newsletter-form .acym_module_form,
.site-footer__newsletter-form .acym_form {
  display: grid;
  gap: 0.7rem;
  width: 100% !important;
  margin: 0 !important;
}

.site-footer__newsletter-action {
  display: grid;
  gap: 0.7rem;
}

.site-footer__newsletter-status {
  min-height: 1.4em;
  margin: 0;
  color: var(--color-text-light);
}

.site-footer__newsletter-form .acym__subscription__form__fields {
  display: grid !important;
  gap: 0.7rem !important;
  width: 100% !important;
  margin: 0 !important;
}

.site-footer__newsletter-form .onefield,
.site-footer__newsletter-form .acym__subscription__form__termscond,
.site-footer__newsletter-form .acym__subscription__form__button {
  width: 100% !important;
  margin: 0 !important;
}

.site-footer__newsletter-form input[type="email"],
.site-footer__newsletter-form input[type="text"] {
  width: 100% !important;
  min-height: 48px;
  box-sizing: border-box;
  border: 1px solid rgba(255, 255, 255, 0.24);
  border-radius: var(--radius-medium);
  background: rgba(255, 255, 255, 0.08);
  color: var(--color-text-inverted);
  padding: 0.65rem 0.8rem;
}

.site-footer__newsletter-form .onefield input:not([type="radio"]):not([type="checkbox"]):not([type="hidden"]) {
  width: 100% !important;
  margin: 0 !important;
}

.site-footer__newsletter-form input[type="email"]::placeholder,
.site-footer__newsletter-form input[type="text"]::placeholder {
  color: rgba(255, 255, 255, 0.72);
}

.site-footer__newsletter-form input[type="email"]:focus-visible,
.site-footer__newsletter-form input[type="text"]:focus-visible {
  outline: 3px solid var(--color-accent);
  outline-offset: 3px;
}

.site-footer__newsletter-form button,
.site-footer__newsletter-form input[type="submit"],
.site-footer__newsletter-form .acym_button,
.site-footer__newsletter-button {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  min-height: 52px;
  border: 2px solid var(--color-accent) !important;
  border-radius: var(--radius-pill) !important;
  background: var(--color-accent) !important;
  color: var(--color-primary-deeper) !important;
  padding: 0.45rem 1rem;
  font-weight: 800;
  cursor: pointer;
  text-decoration: none;
  transition: background-color var(--transition-normal), border-color var(--transition-normal), color var(--transition-normal);
}

.site-footer__newsletter-form button:hover,
.site-footer__newsletter-form button:focus-visible,
.site-footer__newsletter-form button:disabled,
.site-footer__newsletter-form input[type="submit"]:hover,
.site-footer__newsletter-form input[type="submit"]:focus-visible,
.site-footer__newsletter-form input[type="submit"]:disabled,
.site-footer__newsletter-form .acym_button:hover,
.site-footer__newsletter-form .acym_button:focus-visible,
.site-footer__newsletter-button:hover,
.site-footer__newsletter-button:focus-visible,
.site-footer__newsletter-button:disabled {
  background: var(--color-accent-hover) !important;
  border-color: var(--color-accent-hover) !important;
  color: var(--color-primary-deeper) !important;
  text-decoration: none;
}

.site-footer__newsletter-form button:disabled,
.site-footer__newsletter-form input[type="submit"]:disabled,
.site-footer__newsletter-button:disabled {
  cursor: wait;
  opacity: 0.9;
}

.site-footer__newsletter-form label,
.site-footer__newsletter-form .acym__users__creation__fields__title,
.site-footer__newsletter-form .acym__field__error {
  color: var(--color-text-light) !important;
}

.site-footer__newsletter-form .acym__subscription__form__termscond label {
  display: flex;
  align-items: flex-start;
  gap: 0.45rem;
  line-height: 1.4;
}

.site-footer__newsletter-form .acym__subscription__form__termscond input[type="checkbox"] {
  flex: 0 0 auto;
  margin-top: 0.2rem !important;
}

.site-footer__newsletter-form .acym__subscription__form__termscond a {
  display: inline !important;
  color: var(--color-text-inverted) !important;
  text-decoration: underline;
}

/* =================================================================
   Responsive
   ================================================================= */
@media (max-width: 64rem) {
  .site-prefooter__inner {
    grid-template-columns: 1fr;
    gap: 2.25rem;
  }
}

@media (max-width: 48rem) {
  .site-prefooter--large {
    padding: 3rem 0 3.5rem;
  }

  .site-prefooter__card {
    padding: 1.375rem;
  }

  .site-prefooter__row {
    grid-template-columns: 1fr;
    gap: 1.5rem;
  }

  .site-prefooter--compact .site-footer__newsletter-form {
    max-width: none;
  }

  .site-footer__inner {
    grid-template-columns: 1fr;
    gap: 1.75rem;
    text-align: center;
    justify-items: center;
  }

  .site-footer__nav {
    justify-content: center;
  }

  .site-footer__meta {
    flex-direction: column;
    gap: 1rem;
  }
}
