@import url("https://fonts.googleapis.com/css2?family=Caveat:wght@400;500;600&family=Manrope:wght@400;500;600;700&display=swap");
.alpine-footer {
  font-family: "Manrope", "Segoe UI", sans-serif;
  --footer-cream: #f7f2e8;
  --footer-cream-light: #fffaf2;
  --footer-text: #3e403a;
  --footer-muted: #74766f;
  --footer-green: #5e8ba2;
  --footer-green-dark: #3f6f87;
  --footer-line: rgba(111, 99, 76, 0.16);
  --footer-gold: #c5ad86;
  position: relative;
  left: 50%;
  width: 100vw;
  margin-left: -50vw;
  overflow: hidden;
  background: linear-gradient(180deg, #fbf7ef 0%, var(--footer-cream) 100%);
  color: var(--footer-text);
  font-family: var(--sans, "Manrope", "Segoe UI", sans-serif);
}

.alpine-footer.site-footer {
  padding: 0;
  background: linear-gradient(180deg, #fbf7ef 0%, var(--footer-cream) 100%);
  color: var(--footer-text);
}
.alpine-footer p {
  max-width: none;
}
.alpine-footer .alpine-footer-nav {
  display: flex;
  flex-direction: column;
  gap: 24px;
  justify-content: center;
  font-style: normal;
}
.alpine-footer .alpine-footer-contact {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 22px;
  font-style: normal;
}
.alpine-footer .alpine-footer-legal {
  display: flex;
  flex-direction: row;
  gap: 22px;
  font-style: normal;
}
.alpine-footer .alpine-footer-meta,
.alpine-footer .alpine-footer-right {
  display: flex;
}
.alpine-footer *, .alpine-footer *::before, .alpine-footer *::after { box-sizing: border-box; }
.alpine-footer a { color: inherit; text-decoration: none; }
.alpine-footer svg { fill: none; stroke: currentColor; stroke-linecap: round; stroke-linejoin: round; }
.alpine-footer-main { position: relative; min-height: 500px; padding: clamp(58px, 6vw, 92px) clamp(22px, 5vw, 92px) clamp(50px, 5vw, 76px); isolation: isolate; }
.alpine-footer-main::before { content: ""; position: absolute; inset: 0; width: 100%; background: linear-gradient(90deg, rgba(251,247,239,.96) 0%, rgba(251,247,239,.74) 42%, rgba(251,247,239,.38) 100%), linear-gradient(180deg, rgba(251,247,239,.28), rgba(251,247,239,.62)), url("/assets/images/hero-panorama.jpg") center center / cover no-repeat; opacity: .43; z-index: -2; }
.alpine-footer-main::after { content: ""; position: absolute; inset: 0; background: radial-gradient(circle at 64% 18%, rgba(255,255,255,.74), rgba(255,255,255,0) 34%); z-index: -1; pointer-events: none; }
.alpine-footer-inner { width: min(1760px, 100%); margin: 0 auto; display: grid; grid-template-columns: minmax(250px, 330px) minmax(250px, 340px) minmax(360px, 440px) minmax(250px, 330px); align-items: center; column-gap: clamp(36px, 4vw, 76px); }
.alpine-footer-brand, .alpine-footer-nav, .alpine-footer-contact, .alpine-footer-cta-wrap { position: relative; min-height: 320px; }
.alpine-footer-brand, .alpine-footer-nav, .alpine-footer-contact { padding-right: clamp(28px, 3vw, 58px); }
.alpine-footer-brand::after, .alpine-footer-nav::after { content: ""; position: absolute; top: 8px; right: 0; width: 1px; height: 100%; background: var(--footer-line); }
.alpine-footer-logo { display: inline-flex; flex-direction: column; align-items: center; width: min(300px, 100%); color: #6f91a3; text-align: center; }
.alpine-footer-logo > svg { width: 84px; height: 22px; margin: 0 0 4px; color: #5e8ba2; stroke-width: 1.8; }
.alpine-footer-logo .brand-logo { width: min(250px, 82%); max-width: 100%; height: auto; opacity: .92; filter: brightness(0) saturate(100%) invert(52%) sepia(17%) saturate(892%) hue-rotate(154deg) brightness(91%) contrast(88%); }
.alpine-footer-logo .brand-subtitle { display: block; margin-top: 8px; color: #6f91a3; font-size: 0.72rem; font-weight: 700; letter-spacing: 0.22em; line-height: 1.1; text-transform: uppercase; }
.alpine-footer-leaf, .alpine-footer-heart, .alpine-footer-script-ornament { color: var(--footer-gold); }
.alpine-footer-leaf { width: 76px; height: 30px; margin: 22px auto 14px; }
.alpine-footer-claim { margin: 0; color: #6f91a3; font-family: "Caveat", "Segoe Script", cursive; font-size: clamp(32px, 2.1vw, 44px); font-weight: 500; line-height: 1; white-space: nowrap; }
.alpine-footer-heart { width: 34px; height: 34px; margin: 24px auto 0; stroke-width: 1.5; }
.alpine-footer-nav { display: flex; flex-direction: column; gap: 24px; justify-content: center; }
.alpine-footer-nav a, .alpine-footer-contact-row { display: grid; grid-template-columns: 36px 1fr; align-items: center; gap: 28px; }
.alpine-footer-nav a { min-height: 42px; color: var(--footer-text); font-size: clamp(19px, 1.18vw, 25px); font-weight: 500; transition: color .18s ease, transform .18s ease; }
.alpine-footer-nav a:hover { color: var(--footer-green-dark); transform: translateX(3px); }
.alpine-footer-icon { width: 32px; height: 32px; color: #5e8ba2; stroke-width: 1.75; }
.alpine-footer-contact { display: flex; flex-direction: column; justify-content: center; gap: 22px; }
.alpine-footer-contact-head { margin: -8px 0 34px; text-align: center; }
.alpine-footer-script { margin: 0; color: #6f91a3; font-family: "Caveat", "Segoe Script", cursive; font-size: clamp(34px, 2.35vw, 52px); font-weight: 500; line-height: 1; }
.alpine-footer-script-ornament { width: 176px; height: 32px; margin: 8px auto 0; display: grid; grid-template-columns: 1fr 26px; align-items: center; gap: 42px; }
.alpine-footer-script-ornament::before { content: ""; height: 2px; border-radius: 999px; background: currentColor; transform: rotate(-3deg); opacity: .9; }
.alpine-footer-script-ornament svg { width: 24px; height: 24px; stroke-width: 1.7; }
.alpine-footer-contact-row { color: var(--footer-text); font-size: clamp(18px, 1.05vw, 23px); line-height: 1.45; font-style: normal; }
.alpine-footer-contact-row svg { width: 30px; height: 30px; color: #5e8ba2; stroke-width: 1.85; }
.alpine-footer-cta-wrap { display: flex; align-items: center; justify-content: flex-start; padding-left: 0; }
.alpine-footer-cta { display: inline-flex; align-items: center; justify-content: center; gap: 10px; padding: 15px 22px; border: none; border-radius: 18px; background: linear-gradient(180deg, #5f9bb8 0%, #3f6f87 100%); color: #fffdf8; box-shadow: none; font-family: inherit; font-size: 0.98rem; font-weight: 700; letter-spacing: 0; text-transform: none; white-space: nowrap; cursor: pointer; transition: transform .2s ease, background-color .2s ease, color .2s ease, border-color .2s ease; }
.alpine-footer-cta:hover { transform: translateY(-1px); box-shadow: none; }
.alpine-footer-cta span, .alpine-footer-cta svg { color: #fffdf8; stroke: currentColor; }
.alpine-footer-cta svg { width: 18px; height: 18px; stroke-width: 1.9; }
.alpine-footer-bottom { border-top: 1px solid var(--footer-line); background: rgba(249,244,235,.82); backdrop-filter: blur(2px); }
.alpine-footer-bottom-inner { width: min(1760px, 100%); min-height: 96px; margin: 0 auto; padding: 0 clamp(22px, 5vw, 92px); display: grid; grid-template-columns: minmax(330px, 1fr) minmax(330px, 1fr); align-items: center; gap: 44px; color: #767a75; font-size: clamp(15px, .95vw, 19px); }
.alpine-footer-legal, .alpine-footer-socials, .alpine-footer-meta, .alpine-footer-right { display: flex; align-items: center; }
.alpine-footer-meta { gap: 18px; flex-wrap: wrap; }
.alpine-footer-dot, .alpine-footer-sep { color: var(--footer-gold); }
.alpine-footer-bottom-leaf { justify-self: center; width: 92px; height: auto; max-height: 46px; object-fit: contain; opacity: .9; }
.alpine-footer-right { justify-content: flex-end; gap: 48px; }
.alpine-footer-legal { gap: 22px; white-space: nowrap; }
.alpine-footer-legal a:hover { color: var(--footer-green-dark); }
.alpine-footer-socials { gap: 18px; }
.alpine-footer-social { width: 48px; height: 48px; display: inline-flex; align-items: center; justify-content: center; border: 1.5px solid rgba(79,127,154,.62); border-radius: 50%; color: #6f91a3; transition: background .18s ease, color .18s ease, border-color .18s ease; }
.alpine-footer-social:hover { background: rgba(79,127,154,.1); border-color: rgba(79,127,154,.9); color: var(--footer-green-dark); }
.alpine-footer-social svg { width: 24px; height: 24px; stroke-width: 1.9; }
.alpine-footer-social .social-letter { font-family: Georgia, serif; font-size: 31px; font-weight: 700; line-height: 1; }
@media (max-width: 1279px) { .alpine-footer-main { padding-block: 58px; } .alpine-footer-main::before { width: 100%; opacity: .28; } .alpine-footer-inner { grid-template-columns: minmax(240px, .9fr) minmax(230px, .8fr) minmax(320px, 1.1fr); row-gap: 42px; } .alpine-footer-cta-wrap { grid-column: 1 / -1; min-height: auto; justify-content: flex-start; padding-left: 0; } .alpine-footer-brand, .alpine-footer-nav, .alpine-footer-contact { min-height: 300px; } .alpine-footer-contact { padding-right: 0; } .alpine-footer-nav::after { display: none; } .alpine-footer-bottom-inner { grid-template-columns: 1fr auto; gap: 24px; padding-block: 24px; } }
@media (max-width: 900px) { .alpine-footer-main { padding: 52px 24px 44px; } .alpine-footer-main::before { width: 100%; opacity: .16; } .alpine-footer-inner { grid-template-columns: 1fr 1fr; column-gap: 34px; } .alpine-footer-brand, .alpine-footer-nav, .alpine-footer-contact, .alpine-footer-cta-wrap { min-height: auto; } .alpine-footer-brand::after, .alpine-footer-nav::after { display: none; } .alpine-footer-brand { align-items: flex-start; } .alpine-footer-contact { grid-column: 1 / -1; padding-top: 14px; } .alpine-footer-contact-head { text-align: left; margin-bottom: 22px; } .alpine-footer-script-ornament { margin-left: 0; } .alpine-footer-bottom-inner { grid-template-columns: 1fr; justify-items: center; text-align: center; } .alpine-footer-meta, .alpine-footer-right { justify-content: center; } .alpine-footer-right { flex-wrap: wrap; gap: 24px; } }
@media (max-width: 640px) { .alpine-footer-main { padding-inline: 20px; } .alpine-footer-inner { grid-template-columns: 1fr; gap: 38px; text-align: left; } .alpine-footer-brand { padding-right: 0; align-items: center; text-align: center; } .alpine-footer-logo { margin-inline: auto; } .alpine-footer-claim { white-space: normal; } .alpine-footer-nav { gap: 16px; } .alpine-footer-nav a, .alpine-footer-contact-row { grid-template-columns: 32px 1fr; gap: 18px; } .alpine-footer-contact-head { text-align: center; } .alpine-footer-script-ornament { margin-inline: auto; } .alpine-footer-cta-wrap { justify-content: stretch; } .alpine-footer-cta { width: 100%; min-width: 0; } .alpine-footer-bottom-inner { min-height: auto; padding: 28px 20px; } .alpine-footer-meta { gap: 10px 14px; } .alpine-footer-social { width: 50px; height: 50px; } }

@media (max-width: 640px) {
  .alpine-footer .alpine-footer-nav {
    gap: 16px;
  }
}

@media (min-width: 640px) and (max-width: 959px) {
  .alpine-footer-main {
    padding-inline: 20px;
  }

  .alpine-footer-inner {
    grid-template-columns: 1fr;
    gap: 38px;
    text-align: left;
  }

  .alpine-footer-brand,
  .alpine-footer-nav,
  .alpine-footer-contact {
    padding-right: 0;
  }

  .alpine-footer-brand {
    align-items: center;
    text-align: center;
  }

  .alpine-footer-logo {
    margin-inline: auto;
  }

  .alpine-footer-claim {
    white-space: normal;
  }

  .alpine-footer-nav {
    gap: 16px;
  }

  .alpine-footer-nav a,
  .alpine-footer-contact-row {
    grid-template-columns: 32px 1fr;
    gap: 18px;
  }

  .alpine-footer-contact {
    grid-column: auto;
    padding-top: 0;
  }

  .alpine-footer-contact-head {
    text-align: center;
  }

  .alpine-footer-script-ornament {
    margin-inline: auto;
  }

  .alpine-footer-cta-wrap {
    grid-column: auto;
    justify-content: stretch;
  }

  .alpine-footer-cta {
    width: 100%;
    min-width: 0;
  }

  .alpine-footer-bottom-inner {
    min-height: auto;
    padding: 28px 20px;
  }

  .alpine-footer-meta {
    gap: 10px 14px;
  }

  .alpine-footer-social {
    width: 50px;
    height: 50px;
  }
}

@media (min-width: 960px) and (max-width: 1280px) {
  .alpine-footer-inner {
    align-items: start;
  }

  .alpine-footer-contact {
    grid-column: 3;
    grid-row: 1;
    padding-bottom: 76px;
  }

  .alpine-footer-cta-wrap {
    grid-column: 3;
    grid-row: 1;
    align-self: end;
    min-height: auto;
    padding-left: 58px;
  }
}

@media (max-width: 520px) {
  .alpine-footer-dot {
    display: none;
  }
}
