/* =========================================================
   Destiny C3 — Landing Page
   Built on Bootstrap 5 + Jarallax
   Theme: White background with light grey accents
   ========================================================= */

:root {
  --dc3-bg: #ffffff;
  --dc3-bg-2: #f6f6f6;
  --dc3-text: #0a0a0a;
  --dc3-muted: #555555;
  --dc3-muted-2: #8a8a8a;
  --dc3-accent: #0a0a0a;             /* black accent on white */
  --dc3-accent-2: #2a2a2a;
  --dc3-border: rgba(0, 0, 0, 0.1);
  --dc3-border-strong: rgba(0, 0, 0, 0.18);

  --dc3-font-display: "Geist", "Inter", -apple-system, BlinkMacSystemFont,
    "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
  --dc3-font-sans: "Geist", "Inter", -apple-system, BlinkMacSystemFont,
    "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
}

* {
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
}

html {
  scroll-behavior: smooth;
}

body {
  background-color: var(--dc3-bg);
  color: var(--dc3-text);
  font-family: var(--dc3-font-sans);
  font-weight: 400;
  line-height: 1.6;
  letter-spacing: -0.005em;
  font-feature-settings: "kern", "liga", "calt";
  font-variant-ligatures: common-ligatures contextual;
  overflow-x: hidden;
}

h1, h2, h3, .section-title, .hero-title {
  font-family: var(--dc3-font-display);
  font-weight: 700;
  letter-spacing: -0.025em;
  line-height: 1.08;
}

h4, h5, h6 {
  font-family: var(--dc3-font-sans);
  font-weight: 600;
  letter-spacing: -0.015em;
}

.section-title .text-accent {
  font-style: normal !important;
  font-weight: 400 !important;
}

.text-accent {
  color: var(--dc3-accent) !important;
}

.text-muted-2 {
  color: var(--dc3-muted) !important;
}

.py-6 {
  padding-top: 5rem;
  padding-bottom: 5rem;
}
.pt-6 {
  padding-top: 5rem;
}
.mt-6 {
  margin-top: 4rem;
}

@media (min-width: 768px) {
  .py-6 {
    padding-top: 7rem;
    padding-bottom: 7rem;
  }
  .pt-6 {
    padding-top: 7rem;
  }
  .mt-6 {
    margin-top: 5rem;
  }
}

/* =========================================================
   NAVBAR
   - White, dark text. Stays consistent; just adds subtle elevation on scroll.
   ========================================================= */
.dc3-navbar {
  background: rgba(255, 255, 255, 1);
  backdrop-filter: saturate(160%) blur(12px);
  -webkit-backdrop-filter: saturate(160%) blur(12px);
  padding-top: 0.85rem;
  padding-bottom: 0.85rem;
  transition: background-color 0.3s ease, padding 0.3s ease,
    box-shadow 0.3s ease;
}

.dc3-navbar.is-scrolled {
  background: rgba(255, 255, 255, 0.95);
  padding-top: 0.55rem;
  padding-bottom: 0.55rem;
  box-shadow: 0 1px 0 var(--dc3-border),
    0 10px 30px -20px rgba(0, 0, 0, 0.12);
}

.brand-text {
  font-family: var(--dc3-font-display);
  font-weight: 700;
  font-size: 2.25rem;
  letter-spacing: -0.01em;
  color: var(--dc3-text);
}

.brand-text--accent {
  color: var(--dc3-muted-2);
  font-weight: 500;
}

.dc3-navbar .nav-link {
  color: var(--dc3-muted);
  font-weight: 500;
  font-size: 0.95rem;
  padding: 0.5rem 1rem;
  position: relative;
  transition: color 0.2s ease;
}

.dc3-navbar .nav-link:hover,
.dc3-navbar .nav-link:focus {
  color: var(--dc3-text);
}

.dc3-navbar .navbar-nav .nav-link.active,
.dc3-navbar .navbar-nav .nav-link[aria-current="page"] {
  color: var(--dc3-text);
  font-weight: 600;
}

.dc3-navbar .navbar-nav .nav-link.active:not(.dropdown-toggle)::after,
.dc3-navbar .navbar-nav .nav-link[aria-current="page"]:not(.dropdown-toggle)::after {
  transform: scaleX(1);
  background: var(--dc3-text);
}

.dc3-navbar .nav-link:not(.dropdown-toggle)::after {
  content: "";
  position: absolute;
  left: 1rem;
  right: 1rem;
  bottom: 0.25rem;
  height: 1px;
  background: currentColor;
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.25s ease;
}

.dc3-navbar .nav-link:not(.dropdown-toggle):hover::after {
  transform: scaleX(1);
}

.dc3-navbar .dropdown-menu {
  border: 1px solid var(--dc3-border);
  border-radius: 12px;
  padding: 0.35rem;
  margin-top: 0.35rem;
  box-shadow: 0 12px 40px -16px rgba(0, 0, 0, 0.2);
}

@media (min-width: 992px) {
  .dc3-navbar .dropdown-hover {
    position: relative;
  }

  .dc3-navbar .dropdown-hover:hover > .dropdown-menu,
  .dc3-navbar .dropdown-hover:focus-within > .dropdown-menu,
  .dc3-navbar .dropdown-hover > .dropdown-menu.show {
    display: block;
  }

  /* Bridge gap so moving pointer to the menu doesn't close it */
  .dc3-navbar .dropdown-hover > .dropdown-menu {
    margin-top: 0;
    padding-top: 0.5rem;
    border-top: none;
    border-top-left-radius: 0;
    border-top-right-radius: 0;
    box-shadow: 0 12px 40px -16px rgba(0, 0, 0, 0.2);
  }

  .dc3-navbar .dropdown-hover > .dropdown-menu::before {
    content: "";
    display: block;
    height: 0.5rem;
    margin: -0.5rem -0.35rem 0;
  }
}

.dc3-navbar .dropdown-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
  border-radius: 8px;
  font-size: 0.92rem;
  font-weight: 500;
  padding: 0.5rem 0.85rem;
  color: var(--dc3-muted);
}

.dc3-navbar .dropdown-item .bi {
  margin-left: auto;
  font-size: 0.85em;
  opacity: 0.65;
  transition: transform 0.2s ease, opacity 0.2s ease;
}

.dc3-navbar .dropdown-item:hover .bi,
.dc3-navbar .dropdown-item:focus-visible .bi {
  opacity: 1;
  transform: translate(2px, -2px);
}

.dc3-navbar .dropdown-item:hover,
.dc3-navbar .dropdown-item:focus {
  background: var(--dc3-bg-2);
  color: var(--dc3-text);
}

.dc3-navbar .dropdown-item.active {
  background: var(--dc3-bg-2);
  color: var(--dc3-text);
  font-weight: 600;
}

.navbar-toggler {
  filter: invert(1);
}

.navbar-toggler:focus {
  box-shadow: none;
}

/* CTA pill in nav — solid black on white */
.dc3-navbar .btn-dc3 {
  background-color: var(--dc3-accent);
  color: #fff;
  border-color: var(--dc3-accent);
}

.dc3-navbar .btn-dc3:hover {
  background-color: var(--dc3-accent-2);
  border-color: var(--dc3-accent-2);
  color: #fff;
}

.container-fluid {
  max-width: 1200px;
}

/* =========================================================
   BUTTONS
   ========================================================= */
.btn-dc3 {
  background-color: var(--dc3-accent);
  color: #ffffff;
  border: 1px solid var(--dc3-accent);
  font-weight: 600;
  letter-spacing: 0.02em;
  border-radius: 999px;
  padding: 0.6rem 1.4rem;
  transition: transform 0.2s ease, background-color 0.2s ease,
    border-color 0.2s ease, box-shadow 0.2s ease, color 0.2s ease;
}

.btn-dc3:hover,
.btn-dc3:focus {
  background-color: var(--dc3-accent-2);
  border-color: var(--dc3-accent-2);
  color: #ffffff;
  transform: translateY(-1px);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.15);
}

/* Inverted CTA on the white-text-on-light-photo hero */
.dc3-hero .btn-dc3 {
  background-color: #ffffff;
  color: #000;
  border-color: #ffffff;
}

.dc3-hero .btn-dc3:hover,
.dc3-hero .btn-dc3:focus {
  background-color: var(--dc3-accent);
  border-color: var(--dc3-accent);
  color: #ffffff;
  transform: translateY(-1px);
  box-shadow: 0 10px 28px rgba(0, 0, 0, 0.3);
}

.btn-outline-dark {
  border-radius: 999px;
  border-width: 1px;
  border-color: var(--dc3-text);
  color: var(--dc3-text);
  font-weight: 500;
  letter-spacing: 0.02em;
  padding: 0.6rem 1.4rem;
  transition: transform 0.2s ease, background-color 0.2s ease, color 0.2s ease;
}

.btn-outline-dark:hover {
  background-color: var(--dc3-text);
  color: #fff;
  transform: translateY(-1px);
}

.btn-lg {
  padding: 0.85rem 1.8rem;
  font-size: 1rem;
}

/* =========================================================
   HERO — original full-bleed video, white color scheme
   ========================================================= */
.dc3-hero {
  position: relative;
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  background-color: var(--dc3-bg);
}

.dc3-hero .jarallax-img,
.dc3-hero video.jarallax-img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  z-index: 0;
}

.dc3-hero__overlay {
  position: absolute;
  inset: 0;
  z-index: 1;
}

.dc3-hero__curve {
  position: absolute;
  left: 0;
  right: 0;
  bottom: -1px;
  z-index: 3;
  line-height: 0;
  pointer-events: none;
}

.dc3-hero__curve svg {
  display: block;
  width: 100%;
  height: clamp(56px, 10vw, 112px);
}

.dc3-hero__curve path {
  fill: var(--dc3-bg);
}

.dc3-hero__scroll {
  position: absolute;
  left: 50%;
  bottom: clamp(6px, 2vw, 20px);
  transform: translateX(-50%);
  z-index: 4;
  pointer-events: auto;
  cursor: pointer;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0;
  color: #5d5d5d;
  font-size: 1.25rem;
  line-height: 1;
  text-decoration: none;
  opacity: 0.7;
  transition: opacity 0.3s, transform 0.3s;
  animation: dc3-bounce 2s ease-in-out infinite;
}
.dc3-hero__scroll .bi {
  display: block;
  margin-top: -12px;
}
.dc3-hero__scroll .bi:first-child {
  margin-top: 0;
}
.dc3-hero__scroll:hover,
.dc3-hero__scroll:focus-visible {
  color: #000000;
  opacity: 1;
  transform: translateX(-50%) scale(1.15);
  animation: none;
}

@keyframes dc3-bounce {
  0%, 100% { transform: translateX(-50%) translateY(0); }
  50%      { transform: translateX(-50%) translateY(6px); }
}

@media (prefers-reduced-motion: reduce) {
  .dc3-hero__scroll { animation: none; }
}

.dc3-hero__content {
  position: relative;
  z-index: 2;
  padding: clamp(6.5rem, 11vh, 9rem) 1.25rem clamp(5.5rem, 13vw, 8rem);
  max-width: 1920px;
  margin-left: auto;
  margin-right: auto;
  text-align: center;
  color: var(--dc3-text);
  text-shadow: 0 1px 1px rgba(255, 255, 255, 0.6);
}

.dc3-hero__content > * {
  text-align: center;
}

.hero-logo {
  display: block;
  width: clamp(140px, 18vw, 220px);
  height: auto;
  margin: 0 auto clamp(2rem, 4vw, 3.25rem);
  filter: drop-shadow(0 6px 20px rgba(255, 255, 255, 0.55))
    drop-shadow(0 3px 8px rgba(0, 0, 0, 0.15));
  opacity: 0;
  animation: dc3-rise 1s 0.05s ease forwards;
}

.hero-title {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: clamp(0.35rem, 1.4vw, 0.85rem);
  font-size: clamp(2.5rem, 6.5vw, 5.25rem);
  line-height: 1.12;
  text-align: center;
  text-shadow:
    0 1px 0 rgba(255, 255, 255, 0.5),
    0 2px 12px rgba(255, 255, 255, 0.45);
  font-weight: 800;
  letter-spacing: -0.02em;
  color: #FFFFFF;
  margin-left: auto;
  margin-right: auto;
  opacity: 0;
  animation: dc3-rise 1.1s 0.25s ease forwards;
}

h1.hero-title .hero-title__line {
  display: block;
  flex: 0 0 auto;
  width: max-content;
  max-width: 100%;
}

.hero-title__brand {
  display: inline-block;
  font-family: "Fraunces", "Geist", serif;
  font-weight: 700;
  font-style: italic;
  font-size: 1.22em;
  letter-spacing: -0.025em;
  padding: 0 0.04em;
  background: linear-gradient(
    180deg,
    #ffffff 0%,
    #ffe6f1 65%,
    #f7c8e0 100%
  );
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  -webkit-text-fill-color: transparent;
  filter: drop-shadow(0 4px 22px rgba(255, 255, 255, 0.55))
    drop-shadow(0 2px 4px rgba(0, 0, 0, 0.18));
}

.hero-lead {
  font-size: clamp(1rem, 1.6vw, 1.25rem);
  max-width: 720px;
  font-weight: 500;
  color: #FFFFFF;
  margin-left: auto;
  margin-right: auto;
  text-align: center;
  opacity: 0;
  text-shadow: 0 1px 8px rgba(255, 255, 255, 0.6);
  animation: dc3-rise 1.1s 0.45s ease forwards;
}

.hero-cta {
  margin-top: clamp(2rem, 4.5vw, 3.5rem);
  opacity: 0;
  animation: dc3-rise 1.1s 0.6s ease forwards;
}

/* Hero social row — "Follow us" + 4 circular icons under the CTAs */
.hero-socials {
  margin-top: clamp(1.75rem, 3.5vw, 2.75rem);
  text-align: center;
  opacity: 0;
  animation: dc3-rise 1.1s 0.75s ease forwards;
}

.hero-socials__label {
  margin: 0 0 0.85rem;
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.85);
  text-shadow: 0 1px 3px rgba(0, 0, 0, 0.25);
}

.hero-socials__row {
  display: inline-flex;
  gap: 0.6rem;
  justify-content: center;
}

.hero-socials__row a {
  display: inline-flex;
  width: 44px;
  height: 44px;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.95);
  color: var(--dc3-text);
  border: 1px solid rgba(255, 255, 255, 0.95);
  text-decoration: none;
  font-size: 1.15rem;
  transition: transform 0.25s ease, background-color 0.25s ease,
    color 0.25s ease, border-color 0.25s ease, box-shadow 0.25s ease;
}

.hero-socials__row a:hover,
.hero-socials__row a:focus-visible {
  background: var(--dc3-accent);
  color: #ffffff;
  border-color: var(--dc3-accent);
  transform: translateY(-2px);
  box-shadow: 0 10px 24px rgba(0, 0, 0, 0.3);
  outline: none;
}

@keyframes dc3-rise {
  from {
    opacity: 0;
    transform: translateY(18px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* =========================================================
   FEATURE STRIP
   ========================================================= */
.dc3-strip {
  background: var(--dc3-bg);
  border-bottom: 1px solid var(--dc3-border);
}

.strip-item {
  display: block;
  color: inherit;
  text-decoration: none;
  transition: transform 0.25s ease;
}

.strip-item:hover,
.strip-item:focus-visible {
  transform: translateY(-3px);
  color: inherit;
  text-decoration: none;
  outline: none;
}

.strip-item h6 {
  transition: color 0.2s ease;
}

.strip-item:hover h6,
.strip-item:focus-visible h6 {
  color: var(--dc3-text);
}

.strip-icon {
  font-size: 1.7rem;
  color: var(--dc3-text);
  display: inline-flex;
  width: 60px;
  height: 60px;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: var(--dc3-bg-2);
  border: 1px solid var(--dc3-border);
  transition: background-color 0.25s ease, color 0.25s ease,
    border-color 0.25s ease, box-shadow 0.25s ease;
}

.strip-item:hover .strip-icon,
.strip-item:focus-visible .strip-icon {
  background: var(--dc3-text);
  color: #fff;
  border-color: var(--dc3-text);
  box-shadow: 0 12px 24px -14px rgba(0, 0, 0, 0.35);
}

/* =========================================================
   SECTION HEADINGS (eyebrow + title)
   ========================================================= */
.section-eyebrow {
  text-transform: uppercase;
  letter-spacing: 0.35em;
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--dc3-muted);
  margin-bottom: 1rem;
}

.section-title {
  font-size: clamp(2rem, 5vw, 3.75rem);
  line-height: 1.1;
  font-weight: 700;
  letter-spacing: -0.02em;
  color: var(--dc3-text);
}

.section-title .text-accent {
  color: var(--dc3-muted-2);
}

/* =========================================================
   WATCH / JOIN FROM ANYWHERE
   - Two-column: text + laptop mockup bleeding off the right edge
   ========================================================= */
.dc3-watch {
  background: var(--dc3-bg);
  position: relative;
  overflow: hidden;
}

.dc3-watch__container {
  max-width: 1400px;
  padding-left: 1.5rem;
  padding-right: 0;
}

.dc3-watch__copy {
  max-width: 560px;
  padding-right: 1rem;
}

.dc3-watch__copy .section-title {
  font-size: clamp(2rem, 4.2vw, 3rem);
  line-height: 1.1;
  color: var(--dc3-text);
}

.dc3-watch__copy .lead {
  font-size: 1.05rem;
  line-height: 1.7;
  color: var(--dc3-muted);
}

.dc3-watch__media {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  overflow: visible;
}

.dc3-watch__mockup {
  display: block;
  width: 145%;
  max-width: none;
  height: auto;
  margin-right: -35%;
  filter: drop-shadow(0 30px 60px rgba(0, 0, 0, 0.18))
    drop-shadow(0 10px 20px rgba(0, 0, 0, 0.08));
  transition: transform 0.6s cubic-bezier(0.2, 0.7, 0.2, 1);
}

@media (min-width: 1400px) {
  .dc3-watch__mockup {
    width: 130%;
    margin-right: -30%;
  }
}

.dc3-watch:hover .dc3-watch__mockup {
  transform: translateY(-4px);
}

/* YouTube red CTA */
.btn-youtube {
  background-color: #ff0033;
  color: #ffffff;
  border: 1px solid #ff0033;
  border-radius: 999px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  padding: 0.95rem 1.75rem;
  font-size: 0.9rem;
  display: inline-flex;
  align-items: center;
  box-shadow: 0 14px 30px -12px rgba(255, 0, 51, 0.45),
    0 4px 10px -4px rgba(255, 0, 51, 0.25);
  transition: transform 0.2s ease, box-shadow 0.2s ease,
    background-color 0.2s ease, border-color 0.2s ease;
}

.btn-youtube:hover,
.btn-youtube:focus {
  background-color: #e60029;
  border-color: #e60029;
  color: #ffffff;
  transform: translateY(-1px);
  box-shadow: 0 20px 40px -14px rgba(255, 0, 51, 0.55),
    0 6px 14px -6px rgba(255, 0, 51, 0.3);
}

.btn-youtube i {
  font-size: 1.25rem;
  line-height: 1;
}

@media (max-width: 991.98px) {
  .dc3-watch__container {
    padding-left: 1rem;
    padding-right: 1rem;
  }
  .dc3-watch__copy {
    max-width: none;
    padding-right: 0;
    text-align: center;
    margin: 0 auto;
  }
  .dc3-watch__copy .lead {
    max-width: 640px;
    margin-left: auto;
    margin-right: auto;
  }
  .dc3-watch__media {
    justify-content: center;
  }
  .dc3-watch__mockup {
    margin-right: 0;
    max-width: 100%;
  }
}

/* =========================================================
   CONNECT / FORM
   ========================================================= */
.dc3-connect {
  background: var(--dc3-bg);
}

.connect-perks li {
  padding: 0.4rem 0;
  color: var(--dc3-muted);
}

.connect-perks li i {
  color: var(--dc3-text);
}

.dc3-form {
  background: var(--dc3-bg-2);
  border: 1px solid var(--dc3-border);
  border-radius: 18px;
  box-shadow: 0 30px 80px -40px rgba(0, 0, 0, 0.25);
}

.dc3-form .form-label {
  font-size: 0.85rem;
  font-weight: 500;
  color: var(--dc3-muted);
  margin-bottom: 0.4rem;
  letter-spacing: 0.02em;
}

.dc3-form .form-control {
  background-color: #ffffff;
  border: 1px solid var(--dc3-border);
  color: var(--dc3-text);
  padding: 0.7rem 0.9rem;
  border-radius: 10px;
  transition: border-color 0.2s ease, background 0.2s ease, box-shadow 0.2s ease;
}

.dc3-form .form-control:focus {
  background-color: #ffffff;
  border-color: var(--dc3-text);
  color: var(--dc3-text);
  box-shadow: 0 0 0 3px rgba(0, 0, 0, 0.08);
}

.dc3-form .form-control::placeholder {
  color: var(--dc3-muted-2);
}

.alert-success {
  background: rgba(40, 167, 69, 0.1);
  color: #1f6f3d;
  border: 1px solid rgba(40, 167, 69, 0.25);
}

/* =========================================================
   FOOTER (dark)
   ========================================================= */
.dc3-footer {
  background: #000000;
  color: rgba(255, 255, 255, 0.65);
  border-top: 1px solid rgba(255, 255, 255, 0.08);
}

.dc3-footer .brand-text,
.dc3-footer .text-white {
  color: #ffffff !important;
}

.dc3-footer .brand-text--accent {
  color: rgba(255, 255, 255, 0.55);
}

.dc3-footer .text-muted-2 {
  color: rgba(255, 255, 255, 0.55) !important;
}

.footer-heading {
  color: #ffffff;
  font-size: 0.85rem;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 1rem;
  font-weight: 600;
}

.footer-links li {
  margin-bottom: 0.5rem;
}

.footer-links a {
  color: rgba(255, 255, 255, 0.65);
  text-decoration: none;
  font-size: 0.92rem;
  transition: color 0.2s ease;
}

.footer-links a:hover {
  color: #ffffff;
}

.footer-socials {
  display: flex;
  gap: 0.75rem;
}

.footer-socials a {
  display: inline-flex;
  width: 40px;
  height: 40px;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.06);
  color: rgba(255, 255, 255, 0.7);
  border: 1px solid rgba(255, 255, 255, 0.12);
  text-decoration: none;
  transition: all 0.25s ease;
}

.footer-socials a:hover {
  color: #000000;
  border-color: #ffffff;
  background: #ffffff;
  transform: translateY(-2px);
}

.footer-affiliates__label {
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.55);
  margin-bottom: 0.65rem;
}

.footer-affiliates__links {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}

.footer-affiliates__links a {
  display: inline-flex;
  align-items: center;
  font-size: 0.85rem;
  font-weight: 500;
  padding: 0.35rem 0.85rem;
  border: 1px solid rgba(255, 255, 255, 0.18);
  border-radius: 999px;
  color: rgba(255, 255, 255, 0.8);
  text-decoration: none;
  transition: color 0.2s ease, border-color 0.2s ease,
    background-color 0.2s ease, transform 0.2s ease;
}

.footer-affiliates__links a:hover,
.footer-affiliates__links a:focus-visible {
  color: #ffffff;
  border-color: rgba(255, 255, 255, 0.45);
  background: rgba(255, 255, 255, 0.06);
  transform: translateY(-1px);
}

.footer-affiliates__links a i {
  font-size: 0.85rem;
  line-height: 1;
}

.footer-divider {
  border-color: rgba(255, 255, 255, 0.12);
  opacity: 1;
  margin: 2.5rem 0 1.5rem;
}

/* =========================================================
   JARALLAX RESET
   ========================================================= */
.jarallax {
  position: relative;
}

.jarallax > .jarallax-img {
  position: absolute;
  object-fit: cover;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: -100;
}

/* =========================================================
   RESPONSIVE TWEAKS
   ========================================================= */
@media (max-width: 991.98px) {
  .dc3-navbar .navbar-collapse {
    background: rgba(255, 255, 255, 1);
    backdrop-filter: blur(10px);
    margin-top: 0.75rem;
    border-radius: 14px;
    padding: 1rem 1rem 1.25rem;
    border: 1px solid var(--dc3-border);
    box-shadow: 0 20px 50px -20px rgba(0, 0, 0, 0.2);
    margin-right: 0.75rem;
  }
  .dc3-navbar .navbar-collapse .nav-link {
    color: var(--dc3-muted);
  }
  .dc3-navbar .navbar-collapse .nav-link:hover {
    color: var(--dc3-text);
  }
  .dc3-navbar .navbar-collapse .btn-dc3 {
    background-color: var(--dc3-accent);
    color: #fff;
    border-color: var(--dc3-accent);
  }
  .dc3-navbar .nav-link:not(.dropdown-toggle)::after {
    display: none;
  }

  .dc3-navbar .dropdown-menu {
    border: none;
    box-shadow: none;
    padding: 0;
    margin: 0.25rem 0 0;
    background: transparent;
  }

  .dc3-navbar .dropdown-item {
    padding: 0.5rem 1rem;
  }
}

@media (max-width: 575.98px) {
  .dc3-hero {
    min-height: 92vh;
  }
}

@media (min-width: 992px) {
  .dc3-hero {
    min-height: 100svh;
    height: 100svh;
  }

  .dc3-hero__content {
    padding-top: clamp(5rem, 8vh, 6.5rem);
    padding-bottom: calc(clamp(56px, 6vw, 88px) + 2rem);
  }

  .dc3-hero__curve svg {
    height: clamp(56px, 6vw, 88px);
  }

  .dc3-hero__scroll {
    bottom: clamp(12px, 1.5vw, 22px);
    color: #333;
    opacity: 0.85;
  }

  .hero-title {
    gap: 0.3em;
    font-size: clamp(2.75rem, 3.6vw, 3.85rem);
    line-height: 1;
    margin-bottom: 0;
  }

  .hero-logo {
    width: clamp(140px, 18vw, 220px);
    margin-bottom: clamp(1.5rem, 2.5vh, 2.25rem);
  }

  .hero-cta {
    margin-top: clamp(2rem, 3.5vh, 2.75rem);
  }

  .dc3-hero .hero-cta {
    gap: 1.25rem;
  }

  .hero-socials {
    margin-top: clamp(1.5rem, 2.5vh, 2rem);
  }
}

@media (min-width: 992px) and (max-height: 820px) {
  .dc3-hero__content {
    padding-top: clamp(4.5rem, 7vh, 5.5rem);
    padding-bottom: calc(clamp(48px, 5vw, 72px) + 1.5rem);
  }

  .hero-logo {
    width: clamp(100px, 11vw, 140px);
    margin-bottom: 1.25rem;
  }

  .hero-title {
    gap: 0.22em;
    font-size: clamp(2.35rem, 3.2vw, 3.1rem);
  }

  .hero-cta {
    margin-top: 1.5rem;
  }

  .hero-socials {
    margin-top: 1.25rem;
  }
}

/* =========================================================
   ACCESSIBILITY
   ========================================================= */
@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.001ms !important;
    transition-duration: 0.001ms !important;
    scroll-behavior: auto !important;
  }
}

:focus-visible {
  outline: 2px solid var(--dc3-text);
  outline-offset: 3px;
  border-radius: 4px;
}

/* =========================================================
   ABOUT PAGE
   ========================================================= */
.dc3-page {
  padding-top: 0;
}

/* --- Page hero / banner --- */
.dc3-page-hero {
  position: relative;
  overflow: hidden;
  background: var(--dc3-bg-2);
  padding: 9rem 0 5rem;
  border-bottom: 1px solid var(--dc3-border);
}

.dc3-page-hero .jarallax-img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  z-index: 0;
  opacity: 0.1;
  filter: grayscale(1) contrast(1.1);
}

.dc3-page-hero .dc3-section__overlay {
  position: absolute;
  inset: 0;
  z-index: 1;
  background: linear-gradient(
    to bottom,
    rgba(255, 255, 255, 0.8) 0%,
    rgba(246, 246, 246, 0.92) 100%
  );
}

.dc3-page-hero .container {
  z-index: 2;
}

.dc3-page-hero .section-title {
  font-size: clamp(2.5rem, 6vw, 4.5rem);
  line-height: 1.05;
}

@media (min-width: 768px) {
  .dc3-page-hero {
    padding: 11rem 0 6rem;
  }
}

/* Anchor offset so deep-linked sections clear the fixed navbar */
.dc3-about-believe,
.dc3-about-ministries {
  scroll-margin-top: 84px;
}

/* --- Ministries grid --- */
.dc3-about-ministries {
  background: var(--dc3-bg-2);
  border-top: 1px solid var(--dc3-border);
}

.dc3-ministry-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0.85rem;
}

@media (min-width: 576px) {
  .dc3-ministry-grid {
    gap: 1rem;
  }
}

@media (min-width: 768px) {
  .dc3-ministry-grid {
    grid-template-columns: repeat(5, 1fr);
    gap: 1rem;
  }
}

@media (min-width: 992px) {
  .dc3-ministry-grid {
    gap: 1.25rem;
  }
}

.dc3-ministry-card {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 0.85rem;
  padding: 1.85rem 1rem 1.5rem;
  background: var(--dc3-bg);
  border: 1px solid var(--dc3-border);
  border-radius: 16px;
  overflow: hidden;
  transition: transform 0.3s ease, border-color 0.3s ease,
    box-shadow 0.3s ease, background-color 0.3s ease;
}

.dc3-ministry-card[data-ministry] {
  cursor: pointer;
}

.dc3-ministry-card[data-ministry]:focus-visible {
  outline: 2px solid var(--dc3-text);
  outline-offset: 3px;
  border-color: var(--dc3-border-strong);
}

.dc3-ministry-card::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(
    circle at 50% 0%,
    rgba(0, 0, 0, 0.04) 0%,
    transparent 70%
  );
  opacity: 0;
  transition: opacity 0.35s ease;
  pointer-events: none;
}

.dc3-ministry-card:hover {
  transform: translateY(-4px);
  border-color: var(--dc3-border-strong);
  box-shadow: 0 22px 48px -24px rgba(0, 0, 0, 0.22);
}

.dc3-ministry-card:hover::before {
  opacity: 1;
}

.dc3-ministry-card__arrow {
  position: absolute;
  top: 0.85rem;
  right: 0.95rem;
  font-size: 0.95rem;
  color: var(--dc3-muted-2);
  opacity: 0;
  transform: translate(-4px, 4px);
  transition: opacity 0.25s ease, transform 0.25s ease, color 0.25s ease;
}

.dc3-ministry-card:hover .dc3-ministry-card__arrow {
  opacity: 1;
  transform: translate(0, 0);
  color: var(--dc3-text);
}

.dc3-ministry-card__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 3.5rem;
  height: 3.5rem;
  border-radius: 50%;
  background: var(--dc3-bg-2);
  border: 1px solid var(--dc3-border);
  color: var(--dc3-text);
  font-size: 1.5rem;
  transition: background-color 0.3s ease, color 0.3s ease,
    border-color 0.3s ease, transform 0.3s ease;
}

.dc3-ministry-card:hover .dc3-ministry-card__icon {
  background: var(--dc3-text);
  color: #fff;
  border-color: var(--dc3-text);
  transform: scale(1.05);
}

.dc3-ministry-card__name {
  margin: 0;
  font-size: 1rem;
  font-weight: 700;
  letter-spacing: -0.01em;
  color: var(--dc3-text);
  line-height: 1.3;
}

@media (min-width: 768px) {
  .dc3-ministry-card__name {
    font-size: 1.05rem;
  }
}

.dc3-ministry-card__tagline {
  margin: -0.25rem 0 0;
  font-size: 0.8rem;
  font-weight: 500;
  color: var(--dc3-muted);
  line-height: 1.35;
}

/* --- We Believe / numbered statement cards --- */
.dc3-about-believe {
  background: var(--dc3-bg);
}

.dc3-belief-grid {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  grid-template-columns: 1fr;
  gap: 1rem;
  counter-reset: belief;
}

@media (min-width: 768px) {
  .dc3-belief-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 1.25rem;
  }
}

@media (min-width: 1200px) {
  .dc3-belief-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

.dc3-belief-card {
  position: relative;
  display: flex;
  flex-direction: column;
  padding: 1.85rem 1.75rem 1.75rem;
  background: var(--dc3-bg);
  border: 1px solid var(--dc3-border);
  border-radius: 16px;
  overflow: hidden;
  transition: transform 0.3s ease, border-color 0.3s ease,
    box-shadow 0.3s ease;
}

.dc3-belief-card::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 3px;
  background: var(--dc3-text);
  transform: scaleY(0);
  transform-origin: bottom;
  transition: transform 0.35s cubic-bezier(0.2, 0.7, 0.2, 1);
}

.dc3-belief-card:hover {
  transform: translateY(-3px);
  border-color: var(--dc3-border-strong);
  box-shadow: 0 22px 48px -24px rgba(0, 0, 0, 0.22);
}

.dc3-belief-card:hover::before {
  transform: scaleY(1);
}

.dc3-belief-card__number {
  display: block;
  margin: 0 0 0.85rem;
  padding-bottom: 0.85rem;
  border-bottom: 1px solid var(--dc3-border);
  font-family: var(--dc3-font-display);
  font-size: 2rem;
  font-style: italic;
  font-weight: 800;
  line-height: 1;
  letter-spacing: -0.03em;
  color: var(--dc3-text);
  font-variant-numeric: tabular-nums;
  transition: color 0.25s ease, border-color 0.25s ease;
}

.dc3-belief-card:hover .dc3-belief-card__number {
  border-bottom-color: var(--dc3-border-strong);
}

.dc3-belief-card__text {
  margin: 0;
  color: var(--dc3-muted);
  font-size: 0.96rem;
  line-height: 1.65;
}

/* =========================================================
   OUR TEAM PAGE — lead feature + region directory
   ========================================================= */
.dc3-our-team-lead {
  background: var(--dc3-bg);
}

.dc3-our-team-feature {
  position: relative;
  margin: 0 auto;
  max-width: 600px;
  border-radius: 22px;
  overflow: hidden;
  background: var(--dc3-bg);
  border: 1px solid var(--dc3-border);
  box-shadow: 0 30px 70px -34px rgba(0, 0, 0, 0.28);
}

.dc3-our-team-feature__img {
  display: block;
  width: 100%;
  height: auto;
  max-width: 600px;
  aspect-ratio: 1 / 1;
  object-fit: cover;
}

.dc3-our-team-directory {
  background: var(--dc3-bg-2);
  border-top: 1px solid var(--dc3-border);
}

.dc3-our-team-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1rem;
}

@media (min-width: 576px) {
  .dc3-our-team-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 1.25rem;
  }
}

@media (min-width: 1100px) {
  .dc3-our-team-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

.dc3-our-team-card {
  display: flex;
  align-items: flex-start;
  gap: 1.1rem;
  background: var(--dc3-bg);
  border: 1px solid var(--dc3-border);
  border-radius: 16px;
  padding: 1.25rem 1.35rem;
  transition: transform 0.25s ease, border-color 0.25s ease,
    box-shadow 0.25s ease;
}

.dc3-our-team-card:hover {
  transform: translateY(-3px);
  border-color: var(--dc3-border-strong);
  box-shadow: 0 18px 40px -22px rgba(0, 0, 0, 0.18);
}

.dc3-our-team-card__photo {
  width: 120px;
  height: 120px;
  flex-shrink: 0;
  border-radius: 14px;
  overflow: hidden;
  background: var(--dc3-bg-2);
  border: 1px solid var(--dc3-border);
  display: flex;
  align-items: center;
  justify-content: center;
}

.dc3-our-team-card__photo img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.dc3-our-team-card__photo--placeholder {
  color: var(--dc3-muted-2);
  font-size: 3rem;
}

.dc3-our-team-card__content {
  flex: 1;
  min-width: 0;
}

.dc3-our-team-card__church {
  margin: 0 0 0.4rem;
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--dc3-muted);
}

.dc3-our-team-card__names {
  margin: 0 0 0.35rem;
  font-size: 1.05rem;
  font-weight: 700;
  letter-spacing: -0.01em;
  color: var(--dc3-text);
  line-height: 1.3;
  word-break: break-word;
}

.dc3-our-team-card__city {
  margin: 0;
  font-size: 0.85rem;
  color: var(--dc3-muted);
}

@media (max-width: 575.98px) {
  .dc3-our-team-card__photo {
    width: 96px;
    height: 96px;
  }
  .dc3-our-team-card__photo--placeholder {
    font-size: 2.4rem;
  }
}

/* Clickable pastor photo — opens lightbox */
.dc3-our-team-card__photo.is-clickable {
  cursor: zoom-in;
  position: relative;
  transition: transform 0.25s ease, box-shadow 0.25s ease;
}
.dc3-our-team-card__photo.is-clickable img {
  transition: transform 0.4s ease;
}
.dc3-our-team-card__photo.is-clickable:hover img,
.dc3-our-team-card__photo.is-clickable:focus-visible img {
  transform: scale(1.06);
}
.dc3-our-team-card__photo.is-clickable:focus-visible {
  outline: 2px solid var(--dc3-accent);
  outline-offset: 3px;
}

/* --- Pastor photo lightbox --- */
.dc3-pastor-modal .modal-dialog {
  margin: 1rem auto;
}
.dc3-pastor-modal__content {
  position: relative;
  background: var(--dc3-bg);
  border: 1px solid var(--dc3-border);
  border-radius: 18px;
  overflow: hidden;
  box-shadow: 0 40px 90px -30px rgba(0, 0, 0, 0.45);
}
.dc3-pastor-modal__close {
  position: absolute;
  top: 14px;
  right: 14px;
  z-index: 2;
  width: 40px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 0;
  border-radius: 50%;
  background: rgba(0, 0, 0, 0.6);
  color: #fff;
  font-size: 1.05rem;
  line-height: 1;
  cursor: pointer;
  transition: background 0.2s ease, transform 0.2s ease;
}
.dc3-pastor-modal__close:hover,
.dc3-pastor-modal__close:focus-visible {
  background: rgba(0, 0, 0, 0.85);
  transform: scale(1.05);
  outline: none;
}
.dc3-pastor-modal__figure {
  margin: 0;
  padding: 3.25rem 0 0;
  background: var(--dc3-bg);
  display: flex;
  align-items: center;
  justify-content: center;
}

@media (max-width: 575.98px) {
  .dc3-pastor-modal__figure {
    padding-top: 4.5rem;
  }
}
.dc3-pastor-modal__img {
  display: block;
  width: auto;
  max-width: 100%;
  height: auto;
  max-height: 75vh;
  object-fit: contain;
  border-radius: 14px;
  box-shadow: 0 18px 40px -20px rgba(0, 0, 0, 0.35);
}
.dc3-pastor-modal__meta {
  padding: 1.25rem 1.5rem 1.5rem;
  text-align: center;
}
.dc3-pastor-modal__title {
  margin: 0 0 0.25rem;
  font-size: 1.35rem;
  font-weight: 700;
  color: var(--dc3-text);
}
.dc3-pastor-modal__subtitle {
  margin: 0;
  color: var(--dc3-muted);
  font-size: 0.9rem;
}

/* --- About final CTA --- */
.dc3-about-cta {
  background: var(--dc3-bg);
}

.dc3-about-cta__card {
  background: var(--dc3-bg-2);
  border: 1px solid var(--dc3-border);
  border-radius: 24px;
  padding: 4rem 1.5rem;
  box-shadow: 0 40px 80px -50px rgba(0, 0, 0, 0.2);
}

@media (min-width: 768px) {
  .dc3-about-cta__card {
    padding: 5rem 3rem;
  }
}

/* =========================================================
   LOCATIONS PAGE — explorer + church cards
   ========================================================= */
.dc3-locations-page {
  background: var(--dc3-bg-2);
}

/* ---------- Country pills (sticky bar) ---------- */
.dc3-country-pills-wrap {
  position: sticky;
  top: 64px;
  z-index: 20;
  background: rgba(246, 246, 246, 0.92);
  backdrop-filter: saturate(160%) blur(10px);
  -webkit-backdrop-filter: saturate(160%) blur(10px);
  padding: 1.1rem 0;
  border-bottom: 1px solid var(--dc3-border);
}

.dc3-country-pills {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 0.5rem;
}

.dc3-country-pill {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.5rem 1.05rem 0.5rem 0.5rem;
  font-family: inherit;
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--dc3-muted);
  background: var(--dc3-bg);
  border: 1px solid var(--dc3-border);
  border-radius: 999px;
  cursor: pointer;
  transition: color 0.2s ease, background-color 0.2s ease,
    border-color 0.2s ease, transform 0.2s ease;
}

.dc3-country-pill__flag {
  display: inline-block;
  width: 1.25rem;
  height: 1.25rem;
  border-radius: 50%;
  flex-shrink: 0;
  object-fit: cover;
  box-shadow: inset 0 0 0 1px rgba(0, 0, 0, 0.06);
}

.dc3-country-pill:hover,
.dc3-country-pill:focus-visible {
  color: var(--dc3-text);
  border-color: var(--dc3-border-strong);
  outline: none;
  transform: translateY(-1px);
}

.dc3-country-pill.is-active {
  color: #fff;
  background: var(--dc3-text);
  border-color: var(--dc3-text);
}

.dc3-country-pill__count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.5rem;
  height: 1.5rem;
  padding: 0 0.45rem;
  font-size: 0.72rem;
  font-weight: 700;
  border-radius: 999px;
  background: var(--dc3-bg-2);
  color: var(--dc3-muted);
  transition: background-color 0.2s ease, color 0.2s ease;
}

.dc3-country-pill:hover .dc3-country-pill__count,
.dc3-country-pill:focus-visible .dc3-country-pill__count {
  color: var(--dc3-text);
}

.dc3-country-pill.is-active .dc3-country-pill__count {
  background: rgba(255, 255, 255, 0.18);
  color: #fff;
}

@media (max-width: 575.98px) {
  .dc3-country-pills-wrap {
    padding: 0.85rem 0;
  }
  .dc3-country-pill {
    padding: 0.4rem 0.85rem 0.4rem 0.45rem;
    font-size: 0.88rem;
  }
  .dc3-country-pill__flag {
    width: 1.1rem;
    height: 1.1rem;
  }
}

.dc3-region-summary {
  padding-top: 2.5rem;
}

/* Connect Groups page no longer has the pill bar above the heading,
   so drop the floating divider line + its compensating padding. */
.dc3-connect-page .dc3-region-summary {
  border-top: none;
  padding-top: 0;
}

.dc3-region-summary__head {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 1rem;
}

.dc3-region-summary__head .section-title {
  font-size: clamp(1.75rem, 4vw, 2.75rem);
}

.dc3-region-summary__title-block {
  min-width: 0;
}

.dc3-region-summary__title {
  display: inline-flex;
  align-items: center;
  gap: 0.65rem;
}

.dc3-region-summary__flag {
  display: inline-block;
  width: clamp(1.75rem, 3.5vw, 2.25rem);
  height: clamp(1.75rem, 3.5vw, 2.25rem);
  border-radius: 50%;
  flex-shrink: 0;
  object-fit: cover;
  box-shadow: inset 0 0 0 1px rgba(0, 0, 0, 0.08),
    0 4px 14px -8px rgba(0, 0, 0, 0.25);
}

.dc3-region-summary__count {
  display: inline-flex;
  align-items: center;
  padding: 0.5rem 1rem;
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #fff;
  background: var(--dc3-text);
  border-radius: 999px;
  white-space: nowrap;
}

.dc3-region-summary__note {
  display: flex;
  align-items: flex-start;
  gap: 0.65rem;
  margin: 1.25rem 0 0;
  max-width: 64ch;
  padding: 0.85rem 1.1rem;
  border: 1px solid rgba(10, 10, 10, 0.12);
  border-left: 4px solid var(--dc3-accent, #0a0a0a);
  border-radius: 0.6rem;
  background: rgba(10, 10, 10, 0.04);
  font-size: 0.975rem;
  line-height: 1.55;
  font-weight: 500;
  color: var(--dc3-text, #0a0a0a);
}

.dc3-region-summary__note::before {
  content: "\F430"; /* bootstrap-icons info-circle-fill */
  font-family: "bootstrap-icons" !important;
  flex: 0 0 auto;
  font-size: 1.05rem;
  line-height: 1.4;
  color: var(--dc3-accent, #0a0a0a);
}

.dc3-region-summary__note[hidden] {
  display: none;
}

/* ---------- Church cards grid ---------- */
.dc3-church-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.25rem;
}

@media (min-width: 768px) {
  .dc3-church-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 1.5rem;
  }
}

@media (min-width: 1200px) {
  .dc3-church-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

@media (min-width: 1500px) {
  .dc3-church-grid {
    grid-template-columns: repeat(4, 1fr);
  }
}

.dc3-church-card {
  display: flex;
  flex-direction: column;
  background: var(--dc3-bg);
  border: 1px solid var(--dc3-border);
  border-radius: 18px;
  padding: 1.75rem 1.5rem 1.5rem;
  transition: transform 0.3s ease, box-shadow 0.3s ease,
    border-color 0.3s ease;
}

.dc3-church-card:hover {
  transform: translateY(-3px);
  border-color: var(--dc3-border-strong);
  box-shadow: 0 24px 50px -28px rgba(0, 0, 0, 0.25);
}

.dc3-church-card__head {
  margin-bottom: 1.25rem;
  padding-bottom: 1.25rem;
  border-bottom: 1px solid var(--dc3-border);
}

.dc3-church-card__name {
  font-size: 1.15rem;
  font-weight: 700;
  letter-spacing: -0.01em;
  color: var(--dc3-text);
  margin: 0 0 0.65rem;
  line-height: 1.3;
}

.dc3-church-card__tags {
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem;
}

.dc3-church-card__tag {
  display: inline-flex;
  align-items: center;
  padding: 0.2rem 0.6rem;
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--dc3-muted);
  background: var(--dc3-bg-2);
  border: 1px solid var(--dc3-border);
  border-radius: 999px;
}

.dc3-church-card__body {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  flex: 1;
}

.dc3-church-card__row {
  display: flex;
  align-items: flex-start;
  gap: 0.85rem;
}

.dc3-church-card__icon {
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: var(--dc3-bg-2);
  border: 1px solid var(--dc3-border);
  color: var(--dc3-text);
  font-size: 0.95rem;
}

.dc3-church-card__content {
  display: flex;
  flex-direction: column;
  gap: 0.15rem;
  min-width: 0;
}

.dc3-church-card__label {
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--dc3-muted-2);
}

.dc3-church-card__value {
  font-size: 0.95rem;
  color: var(--dc3-text);
  line-height: 1.45;
  word-break: break-word;
}

.dc3-church-card__sub {
  font-size: 0.85rem;
  color: var(--dc3-muted);
  line-height: 1.4;
}

/* Pastors row — single clickable photo icon (replaces the static people icon).
   Same footprint as .dc3-church-card__icon so the row layout is unchanged. */
.dc3-pastor-icon {
  flex-shrink: 0;
  width: 36px;
  height: 36px;
  padding: 0;
  border: 1px solid var(--dc3-border);
  border-radius: 50%;
  overflow: hidden;
  background: var(--dc3-bg-2);
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.dc3-pastor-icon img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.dc3-pastor-icon.is-clickable {
  cursor: zoom-in;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.dc3-pastor-icon.is-clickable:hover,
.dc3-pastor-icon.is-clickable:focus-visible {
  transform: scale(1.12);
  box-shadow: 0 6px 14px -6px rgba(0, 0, 0, 0.35);
  outline: none;
}

.dc3-pastor-icon.is-clickable:focus-visible {
  outline: 2px solid var(--dc3-accent);
  outline-offset: 2px;
}

.dc3-church-card__foot {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 1rem;
  margin-top: 1.5rem;
  padding-top: 1.25rem;
  border-top: 1px solid var(--dc3-border);
}

.dc3-church-card__socials {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.dc3-church-card__social {
  display: inline-flex;
  width: 36px;
  height: 36px;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: var(--dc3-bg-2);
  border: 1px solid var(--dc3-border);
  color: var(--dc3-text);
  font-size: 1rem;
  text-decoration: none;
  transition: background-color 0.2s ease, color 0.2s ease,
    border-color 0.2s ease, transform 0.2s ease;
}

.dc3-church-card__social:hover,
.dc3-church-card__social:focus-visible {
  background: var(--dc3-text);
  color: #fff;
  border-color: var(--dc3-text);
  transform: translateY(-1px);
}

.dc3-church-card__cta {
  display: inline-flex;
  align-items: center;
  font-weight: 600;
  font-size: 0.9rem;
  letter-spacing: 0.02em;
  color: var(--dc3-text);
  text-decoration: none;
  border-bottom: 1px solid transparent;
  padding-bottom: 2px;
  transition: border-color 0.2s ease, transform 0.2s ease;
}

.dc3-church-card__cta:hover,
.dc3-church-card__cta:focus-visible {
  color: var(--dc3-text);
  border-color: var(--dc3-text);
  transform: translateX(2px);
}

/* ---------- Empty state ---------- */
.dc3-church-empty {
  text-align: center;
  padding: 3rem 1.5rem;
  background: var(--dc3-bg);
  border: 1px dashed var(--dc3-border-strong);
  border-radius: 18px;
  color: var(--dc3-muted);
}

.dc3-church-empty i {
  display: block;
  font-size: 2rem;
  margin-bottom: 0.75rem;
  color: var(--dc3-muted-2);
}

/* =========================================================
   EVENTS PAGE (events.html)
   - Month-grouped agenda. The next upcoming event is shown
     as a featured row; the rest are compact horizontal rows.
   ========================================================= */
.dc3-events-page {
  background: var(--dc3-bg-2);
}

.dc3-events-loading {
  text-align: center;
  padding: 3rem 1.5rem;
  color: var(--dc3-muted);
}

.dc3-events-loading .spinner-border {
  width: 2rem;
  height: 2rem;
  color: var(--dc3-accent);
}

/* ---------- Agenda + month groups ---------- */
.dc3-events-agenda {
  display: flex;
  flex-direction: column;
  gap: 2.5rem;
}

.dc3-events-month__title {
  font-family: var(--dc3-font-display);
  font-size: clamp(1.4rem, 3.5vw, 1.9rem);
  font-weight: 700;
  letter-spacing: -0.01em;
  margin: 0 0 1.25rem;
  padding-bottom: 0.75rem;
  border-bottom: 1px solid var(--dc3-border);
}

.dc3-events-list {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

/* ---------- Event row ---------- */
.dc3-event-row {
  display: flex;
  align-items: center;
  gap: 1.25rem;
  background: var(--dc3-bg);
  border: 1px solid var(--dc3-border);
  border-radius: 16px;
  padding: 1.1rem 1.25rem;
  transition: transform 0.25s ease, box-shadow 0.25s ease,
    border-color 0.25s ease;
}

.dc3-event-row:hover {
  transform: translateY(-2px);
  border-color: var(--dc3-border-strong);
  box-shadow: 0 18px 40px -28px rgba(0, 0, 0, 0.25);
}

.dc3-event-row.is-featured {
  padding: 1.5rem;
  border-color: var(--dc3-border-strong);
  box-shadow: 0 24px 50px -30px rgba(0, 0, 0, 0.3);
}

/* Date badge */
.dc3-event-row__date {
  flex-shrink: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  width: 64px;
  height: 64px;
  border-radius: 14px;
  background: var(--dc3-bg-2);
  border: 1px solid var(--dc3-border);
  line-height: 1;
}

.dc3-event-row.is-featured .dc3-event-row__date {
  width: 76px;
  height: 76px;
  background: var(--dc3-text);
  border-color: var(--dc3-text);
  color: #fff;
}

.dc3-event-row__day {
  font-size: 1.6rem;
  font-weight: 700;
}

.dc3-event-row.is-featured .dc3-event-row__day {
  font-size: 2rem;
}

.dc3-event-row__weekday {
  margin-top: 0.25rem;
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--dc3-muted-2);
}

.dc3-event-row.is-featured .dc3-event-row__weekday {
  color: rgba(255, 255, 255, 0.7);
}

/* Main content */
.dc3-event-row__main {
  flex: 1 1 240px;
  min-width: 0;
}

.dc3-event-row__meta {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  flex-wrap: wrap;
  margin: 0 0 0.25rem;
  font-size: 0.8rem;
  font-weight: 600;
  letter-spacing: 0.02em;
  color: var(--dc3-muted);
}

.dc3-event-row__title {
  font-size: 1.15rem;
  font-weight: 700;
  letter-spacing: -0.01em;
  color: var(--dc3-text);
  margin: 0;
  line-height: 1.3;
}

.dc3-event-row.is-featured .dc3-event-row__title {
  font-size: 1.4rem;
}

.dc3-event-row__location {
  display: inline-flex;
  align-items: flex-start;
  gap: 0.4rem;
  margin: 0.45rem 0 0;
  font-size: 0.9rem;
  color: var(--dc3-muted);
  text-decoration: none;
  transition: color 0.2s ease;
}

.dc3-event-row__location i {
  margin-top: 0.12rem;
  color: var(--dc3-muted-2);
  transition: color 0.2s ease;
}

.dc3-event-row__location:hover,
.dc3-event-row__location:focus-visible {
  color: var(--dc3-text);
  text-decoration: underline;
}

.dc3-event-row__location:hover i,
.dc3-event-row__location:focus-visible i {
  color: var(--dc3-text);
}

.dc3-event-row__desc {
  margin: 0.6rem 0 0;
  font-size: 0.92rem;
  line-height: 1.5;
  color: var(--dc3-muted);
}

/* Actions */
.dc3-event-row__actions {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  gap: 0.85rem;
  margin-left: auto;
}

.dc3-event-row__add {
  white-space: nowrap;
}

/* ---------- Mobile ---------- */
@media (max-width: 575.98px) {
  .dc3-event-row {
    flex-wrap: wrap;
    align-items: flex-start;
    gap: 1rem 1rem;
    padding: 1.1rem;
  }

  .dc3-event-row.is-featured {
    padding: 1.25rem;
  }

  .dc3-event-row__date,
  .dc3-event-row.is-featured .dc3-event-row__date {
    width: 56px;
    height: 56px;
  }

  .dc3-event-row__day,
  .dc3-event-row.is-featured .dc3-event-row__day {
    font-size: 1.45rem;
  }

  .dc3-event-row__actions {
    margin-left: 0;
    width: 100%;
    gap: 1rem;
  }

  .dc3-event-row__add {
    flex: 1 1 auto;
    text-align: center;
  }
}

/* ---------- Row highlight (when jumped to from calendar) ---------- */
.dc3-event-row.is-highlighted {
  border-color: var(--dc3-text);
  box-shadow: 0 0 0 2px var(--dc3-text);
}

/* ---------- Month calendar widget ---------- */
.dc3-events-cal {
  position: sticky;
  top: 96px;
  background: var(--dc3-bg);
  border: 1px solid var(--dc3-border);
  border-radius: 18px;
  padding: 1.25rem;
}

.dc3-events-cal__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 1rem;
}

.dc3-events-cal__title {
  font-family: var(--dc3-font-display);
  font-weight: 700;
  font-size: 1.05rem;
  letter-spacing: -0.01em;
}

.dc3-events-cal__nav {
  width: 32px;
  height: 32px;
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  border: 1px solid var(--dc3-border);
  background: var(--dc3-bg);
  color: var(--dc3-text);
  cursor: pointer;
  transition: background-color 0.2s ease, color 0.2s ease,
    border-color 0.2s ease;
}

.dc3-events-cal__nav:hover,
.dc3-events-cal__nav:focus-visible {
  background: var(--dc3-text);
  color: #fff;
  border-color: var(--dc3-text);
  outline: none;
}

.dc3-events-cal__grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 0.2rem;
  text-align: center;
}

.dc3-events-cal__dow {
  font-size: 0.62rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--dc3-muted-2);
  padding-bottom: 0.4rem;
}

.dc3-events-cal__day {
  aspect-ratio: 1 / 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 0.85rem;
  color: var(--dc3-muted);
  background: transparent;
  border: none;
  border-radius: 50%;
  padding: 0;
}

.dc3-events-cal__day.is-empty {
  visibility: hidden;
}

.dc3-events-cal__day.is-today {
  box-shadow: inset 0 0 0 1px var(--dc3-border-strong);
  font-weight: 700;
  color: var(--dc3-text);
}

/* Weekend distinction (Sat & Sun) */
.dc3-events-cal__dow.is-weekend {
  color: var(--dc3-text);
}

.dc3-events-cal__day.is-weekend {
  background: var(--dc3-bg-2);
}

button.dc3-events-cal__day.has-event {
  background: var(--dc3-text);
  color: #fff;
  font-weight: 700;
  cursor: pointer;
  transition: transform 0.15s ease;
}

button.dc3-events-cal__day.has-event:hover,
button.dc3-events-cal__day.has-event:focus-visible {
  transform: scale(1.08);
  outline: none;
}

/* Collapsible toggle — desktop hides it (calendar always open). */
.dc3-events-cal__toggle {
  display: none;
  width: 100%;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  background: transparent;
  border: none;
  padding: 0;
  color: var(--dc3-text);
  font-family: var(--dc3-font-display);
  font-weight: 700;
  font-size: 1rem;
  cursor: pointer;
}

.dc3-events-cal__toggle-label {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
}

.dc3-events-cal__toggle-icon {
  transition: transform 0.25s ease;
}

.dc3-events-cal.is-open .dc3-events-cal__toggle-icon {
  transform: rotate(180deg);
}

@media (max-width: 991.98px) {
  .dc3-events-cal {
    position: static;
  }

  .dc3-events-cal__toggle {
    display: flex;
  }

  /* Collapsed by default on mobile; expands when opened. */
  .dc3-events-cal__body {
    display: none;
  }

  .dc3-events-cal.is-open .dc3-events-cal__toggle {
    margin-bottom: 1rem;
  }

  .dc3-events-cal.is-open .dc3-events-cal__body {
    display: block;
  }
}

/* =========================================================
   HOMEPAGE — "What's Happening" teaser
   ========================================================= */
.dc3-home-events {
  background: var(--dc3-bg-2);
  border-top: 1px solid var(--dc3-border);
  border-bottom: 1px solid var(--dc3-border);
}

.dc3-home-events__head {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 1rem;
  margin-bottom: 2rem;
}

.dc3-home-events__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1rem;
}

@media (min-width: 768px) {
  .dc3-home-events__grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

.dc3-teaser-event {
  display: flex;
  align-items: center;
  gap: 1rem;
  background: var(--dc3-bg);
  border: 1px solid var(--dc3-border);
  border-radius: 16px;
  padding: 1.1rem 1.25rem;
  text-decoration: none;
  transition: transform 0.25s ease, box-shadow 0.25s ease,
    border-color 0.25s ease;
}

.dc3-teaser-event:hover {
  transform: translateY(-3px);
  border-color: var(--dc3-border-strong);
  box-shadow: 0 24px 50px -28px rgba(0, 0, 0, 0.25);
}

.dc3-teaser-event__date {
  flex-shrink: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  width: 58px;
  height: 58px;
  border-radius: 14px;
  background: var(--dc3-bg-2);
  border: 1px solid var(--dc3-border);
  color: var(--dc3-text);
  line-height: 1;
}

.dc3-teaser-event.is-featured .dc3-teaser-event__date {
  background: var(--dc3-text);
  border-color: var(--dc3-text);
  color: #fff;
}

.dc3-teaser-event__day {
  font-size: 1.45rem;
  font-weight: 700;
}

.dc3-teaser-event__month {
  margin-top: 0.2rem;
  font-size: 0.65rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--dc3-muted-2);
}

.dc3-teaser-event.is-featured .dc3-teaser-event__month {
  color: rgba(255, 255, 255, 0.7);
}

.dc3-teaser-event__body {
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}

.dc3-teaser-event__title {
  font-weight: 700;
  font-size: 1rem;
  letter-spacing: -0.01em;
  color: var(--dc3-text);
  line-height: 1.3;
}

.dc3-teaser-event__meta {
  font-size: 0.82rem;
  color: var(--dc3-muted);
}

/* ---------- Locations page: country list tweaks ---------- */
/* =========================================================
   CONNECT GROUPS PAGE
   ========================================================= */
.dc3-connect-page {
  background: var(--dc3-bg-2);
}

/* =========================================================
   INDEX PAGE — locations teaser
   ========================================================= */
.dc3-locations-teaser {
  background: var(--dc3-bg-2);
  border-top: 1px solid var(--dc3-border);
  border-bottom: 1px solid var(--dc3-border);
}

.dc3-locations-teaser__map {
  position: relative;
  max-width: 460px;
  margin: 0 auto;
  border-radius: 18px;
  overflow: hidden;
  background: var(--dc3-bg);
  border: 1px solid var(--dc3-border);
  box-shadow: 0 24px 50px -28px rgba(0, 0, 0, 0.18);
  isolation: isolate;
}

.dc3-locations-teaser__map-base {
  display: block;
  width: 100%;
  height: auto;
  position: relative;
  z-index: 1;
  filter: grayscale(1) brightness(1.02) contrast(0.95);
  transition: filter 0.4s ease;
}

.dc3-locations-teaser__map-overlay {
  display: block;
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  z-index: 2;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.35s cubic-bezier(0.2, 0.7, 0.2, 1);
}

[data-locations-teaser][data-hovered-region] .dc3-locations-teaser__map-base {
  filter: grayscale(1) brightness(1.08) contrast(0.85);
}

[data-locations-teaser][data-hovered-region="malaysia"]
  .dc3-locations-teaser__map-overlay[data-region="malaysia"],
[data-locations-teaser][data-hovered-region="india"]
  .dc3-locations-teaser__map-overlay[data-region="india"],
[data-locations-teaser][data-hovered-region="thailand"]
  .dc3-locations-teaser__map-overlay[data-region="thailand"],
[data-locations-teaser][data-hovered-region="cambodia"]
  .dc3-locations-teaser__map-overlay[data-region="cambodia"] {
  opacity: 1;
}

/* Mobile: use the static "all-countries-highlighted" map and hide the
   hover overlays since touch devices can't hover. */
@media (max-width: 991.98px) {
  .dc3-locations-teaser__map-base {
    filter: none;
  }
  .dc3-locations-teaser__map-overlay {
    display: none;
  }
}

.dc3-locations-teaser__grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0.85rem;
}

@media (min-width: 576px) {
  .dc3-locations-teaser__grid {
    gap: 1rem;
  }
}

.dc3-locations-teaser__chip {
  display: flex;
  align-items: center;
  gap: 0.85rem;
  padding: 1rem 1.15rem;
  border-radius: 14px;
  background: var(--dc3-bg);
  border: 1px solid var(--dc3-border);
  color: var(--dc3-text);
  text-decoration: none;
  transition: transform 0.25s ease, border-color 0.25s ease,
    box-shadow 0.25s ease;
}

.dc3-locations-teaser__chip-flag {
  display: inline-block;
  width: 1.5rem;
  height: 1.5rem;
  border-radius: 50%;
  flex-shrink: 0;
  object-fit: cover;
  box-shadow: inset 0 0 0 1px rgba(0, 0, 0, 0.08),
    0 4px 12px -8px rgba(0, 0, 0, 0.25);
}

.dc3-locations-teaser__chip-text {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
  min-width: 0;
}

.dc3-locations-teaser__chip:hover,
.dc3-locations-teaser__chip:focus-visible {
  transform: translateY(-3px);
  border-color: var(--dc3-border-strong);
  box-shadow: 0 18px 40px -22px rgba(0, 0, 0, 0.25);
  color: var(--dc3-text);
}

.dc3-locations-teaser__chip-name {
  font-size: 1.05rem;
  font-weight: 700;
  letter-spacing: -0.01em;
}

.dc3-locations-teaser__chip-count {
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--dc3-muted);
}

/* =========================================================
   GIVE PAGE — methods grid + bank details
   ========================================================= */
.dc3-give-page {
  background: var(--dc3-bg-2);
}

/* Important note about transaction description */
.dc3-give-note {
  display: flex;
  align-items: flex-start;
  gap: 1rem;
  padding: 1.25rem 1.5rem;
  background: var(--dc3-bg);
  border: 1px solid var(--dc3-border);
  border-left: 3px solid var(--dc3-text);
  border-radius: 14px;
}

.dc3-give-note__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.25rem;
  height: 2.25rem;
  flex-shrink: 0;
  border-radius: 50%;
  background: var(--dc3-bg-2);
  color: var(--dc3-text);
  font-size: 1.1rem;
}

.dc3-give-note__body {
  flex: 1;
  min-width: 0;
}

.dc3-give-note__title {
  font-size: 1rem;
  font-weight: 700;
  letter-spacing: -0.01em;
  color: var(--dc3-text);
  margin: 0 0 0.35rem;
}

.dc3-give-note__text {
  font-size: 0.92rem;
  color: var(--dc3-muted);
  line-height: 1.5;
}

.dc3-give-note__tags {
  list-style: none;
  padding: 0;
  margin: 0.85rem 0 0;
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem;
}

.dc3-give-note__tags li {
  display: inline-flex;
  align-items: center;
  padding: 0.3rem 0.7rem;
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.02em;
  color: var(--dc3-text);
  background: var(--dc3-bg-2);
  border: 1px solid var(--dc3-border);
  border-radius: 999px;
}

@media (max-width: 575.98px) {
  .dc3-give-note {
    padding: 1.1rem 1.15rem;
  }
  .dc3-give-note__icon {
    width: 2rem;
    height: 2rem;
    font-size: 1rem;
  }
}

.dc3-give-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.5rem;
}

@media (min-width: 768px) {
  .dc3-give-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (min-width: 1100px) {
  .dc3-give-grid {
    grid-template-columns: repeat(3, 1fr);
    gap: 1.75rem;
  }
}

.dc3-give-card {
  display: flex;
  flex-direction: column;
  background: var(--dc3-bg);
  border: 1px solid var(--dc3-border);
  border-radius: 22px;
  padding: 2rem 1.75rem;
  transition: transform 0.3s ease, box-shadow 0.3s ease,
    border-color 0.3s ease;
}

.dc3-give-card:hover {
  transform: translateY(-3px);
  border-color: var(--dc3-border-strong);
  box-shadow: 0 26px 55px -28px rgba(0, 0, 0, 0.22);
}

.dc3-give-card__head {
  text-align: center;
  margin-bottom: 1.25rem;
}

.dc3-give-card__badge {
  display: inline-block;
  padding: 0.25rem 0.7rem;
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--dc3-muted);
  background: var(--dc3-bg-2);
  border: 1px solid var(--dc3-border);
  border-radius: 999px;
  margin-bottom: 0.75rem;
}

.dc3-give-card__name {
  font-size: 1.25rem;
  font-weight: 700;
  letter-spacing: -0.01em;
  color: var(--dc3-text);
  margin: 0 0 0.4rem;
  line-height: 1.3;
}

.dc3-give-card__sub {
  font-size: 0.92rem;
  color: var(--dc3-muted);
  margin: 0;
  line-height: 1.45;
}

/* QR image area (DuitNow + TNG) */
.dc3-give-card__media {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0.75rem;
  margin: 0 auto 1.25rem;
  max-width: 320px;
  background: var(--dc3-bg);
  border: 1px solid var(--dc3-border);
  border-radius: 18px;
}

.dc3-give-card__media img {
  display: block;
  width: 100%;
  height: auto;
  border-radius: 12px;
}

.dc3-give-card__steps {
  list-style: decimal;
  padding-left: 1.25rem;
  margin: 0;
  color: var(--dc3-muted);
  font-size: 0.92rem;
  line-height: 1.55;
}

.dc3-give-card__steps li + li {
  margin-top: 0.35rem;
}

/* Bank-transfer card */
.dc3-give-card--bank .dc3-give-card__bank-logo {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 80px;
  margin: 0 auto 1.25rem;
  padding: 0.75rem 1.25rem;
  background: var(--dc3-bg);
  border: 1px solid var(--dc3-border);
  border-radius: 14px;
  max-width: 220px;
}

.dc3-give-card--bank .dc3-give-card__bank-logo img {
  display: block;
  max-height: 100%;
  width: auto;
  object-fit: contain;
  border-radius: 10px;
  box-shadow: 0 2px 6px -2px rgba(0, 0, 0, 0.12);
}

.dc3-give-card__details {
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 0.85rem;
}

.dc3-give-card__row {
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
  padding-bottom: 0.85rem;
  border-bottom: 1px solid var(--dc3-border);
}

.dc3-give-card__row:last-child {
  border-bottom: none;
  padding-bottom: 0;
}

.dc3-give-card__row dt {
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--dc3-muted);
  margin: 0;
}

.dc3-give-card__row dd {
  margin: 0;
  font-size: 0.98rem;
  font-weight: 600;
  color: var(--dc3-text);
  word-break: break-word;
}

.dc3-give-card__copy-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
}

.dc3-give-card__value {
  font-variant-numeric: tabular-nums;
  letter-spacing: 0.02em;
}

.dc3-give-card__copy {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  padding: 0.4rem 0.75rem;
  font-family: inherit;
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--dc3-muted);
  background: var(--dc3-bg-2);
  border: 1px solid var(--dc3-border);
  border-radius: 999px;
  cursor: pointer;
  flex-shrink: 0;
  transition: color 0.2s ease, background-color 0.2s ease,
    border-color 0.2s ease;
}

.dc3-give-card__copy:hover,
.dc3-give-card__copy:focus-visible {
  color: var(--dc3-text);
  border-color: var(--dc3-border-strong);
  outline: none;
}

.dc3-give-card__copy.is-copied {
  color: #fff;
  background: var(--dc3-text);
  border-color: var(--dc3-text);
}

.dc3-give-card__copy .bi {
  font-size: 0.95rem;
}

@media (max-width: 575.98px) {
  .dc3-give-card {
    padding: 1.5rem 1.25rem;
  }
  .dc3-give-card__copy-label {
    display: none;
  }
}

/* =========================================================
   LEGAL / LONG-FORM PROSE PAGE (Privacy Notice, Terms, etc.)
   ========================================================= */
.dc3-legal-page {
  background: var(--dc3-bg);
}

.dc3-legal {
  max-width: 760px;
  color: var(--dc3-text);
  font-size: 1rem;
  line-height: 1.7;
}

.dc3-legal__updated {
  display: inline-block;
  margin: 0 0 2rem;
  padding: 0.35rem 0.85rem;
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--dc3-muted);
  background: var(--dc3-bg-2);
  border: 1px solid var(--dc3-border);
  border-radius: 999px;
}

.dc3-legal h2 {
  font-family: var(--dc3-font-display);
  font-size: clamp(1.35rem, 2.4vw, 1.7rem);
  font-weight: 700;
  letter-spacing: -0.01em;
  color: var(--dc3-text);
  margin: 2.5rem 0 1rem;
  padding-top: 1.25rem;
  border-top: 1px solid var(--dc3-border);
}

.dc3-legal h2:first-of-type {
  margin-top: 2rem;
}

.dc3-legal p {
  margin: 0 0 1.1rem;
  color: var(--dc3-muted);
}

.dc3-legal p:last-child {
  margin-bottom: 0;
}

.dc3-legal ul {
  margin: 0 0 1.1rem 0;
  padding-left: 1.4rem;
  color: var(--dc3-muted);
}

.dc3-legal li {
  margin-bottom: 0.4rem;
}

.dc3-legal a {
  color: var(--dc3-text);
  text-decoration: underline;
  text-underline-offset: 2px;
  transition: color 0.2s ease;
}

.dc3-legal a:hover,
.dc3-legal a:focus-visible {
  color: var(--dc3-accent);
}

/* Tiny inline link for the copyright row in the footer */
.footer-legal-link {
  color: inherit;
  text-decoration: none;
  border-bottom: 1px solid transparent;
  transition: color 0.2s ease, border-color 0.2s ease;
}

.footer-legal-link:hover,
.footer-legal-link:focus-visible {
  color: #fff;
  border-bottom-color: rgba(255, 255, 255, 0.5);
  outline: none;
}

/* Credit line */
.footer-credit {
  font-size: 0.78rem;
  letter-spacing: 0.02em;
  opacity: 0.75;
}

@media (min-width: 768px) {
  .footer-bottom-row .footer-credit {
    order: 2;
  }
  .footer-bottom-row .footer-bottom-row__privacy {
    order: 3;
  }
}

.footer-credit .footer-legal-link {
  color: #ffa302;
}

.footer-credit .footer-legal-link:hover,
.footer-credit .footer-legal-link:focus-visible {
  color: #f0c75a;
  border-bottom-color: rgba(240, 199, 90, 0.6);
}

/* =========================================================
   MINISTRY DETAIL MODAL (about.html)
   ========================================================= */
.dc3-ministry-modal .modal-dialog {
  max-width: 620px;
}

.dc3-ministry-modal__content {
  position: relative;
  border: 1px solid var(--dc3-border);
  border-radius: 22px;
  background: var(--dc3-bg);
  padding: 2.5rem 1.75rem 1.85rem;
  overflow: hidden;
}

@media (min-width: 576px) {
  .dc3-ministry-modal__content {
    padding: 3rem 2.75rem 2.25rem;
  }
}

.dc3-ministry-modal__close {
  position: absolute;
  top: 1rem;
  right: 1rem;
  z-index: 3;
  padding: 0.65rem;
  border-radius: 999px;
  opacity: 0.6;
  transition: opacity 0.2s ease, background-color 0.2s ease;
}

.dc3-ministry-modal__close:hover,
.dc3-ministry-modal__close:focus-visible {
  opacity: 1;
  background: var(--dc3-bg-2);
}

.dc3-ministry-modal__hero {
  text-align: center;
  margin-bottom: 1.5rem;
  padding-bottom: 1.5rem;
  border-bottom: 1px solid var(--dc3-border);
}

.dc3-ministry-modal__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 4.25rem;
  height: 4.25rem;
  border-radius: 50%;
  background: var(--dc3-bg-2);
  border: 1px solid var(--dc3-border);
  color: var(--dc3-text);
  font-size: 1.9rem;
  margin-bottom: 1.1rem;
}

.dc3-ministry-modal__eyebrow {
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--dc3-muted);
  margin: 0 0 0.6rem;
}

.dc3-ministry-modal__name {
  font-family: var(--dc3-font-display);
  font-size: clamp(1.5rem, 3.5vw, 2rem);
  font-weight: 800;
  letter-spacing: -0.02em;
  color: var(--dc3-text);
  margin: 0;
  line-height: 1.15;
}

.dc3-ministry-modal__body {
  font-size: 0.98rem;
  line-height: 1.65;
  color: var(--dc3-muted);
  margin-bottom: 1.75rem;
}

.dc3-ministry-modal__body p {
  margin: 0 0 1rem;
}

.dc3-ministry-modal__body p:last-child {
  margin-bottom: 0;
}

.dc3-ministry-modal__cta {
  text-align: center;
  padding-top: 1.5rem;
  border-top: 1px solid var(--dc3-border);
}

.dc3-ministry-modal__cta-text {
  font-size: 0.95rem;
  color: var(--dc3-text);
  margin: 0 0 1.1rem;
  font-weight: 500;
}

/* Softer modal backdrop blur on supported browsers */
.dc3-ministry-modal + .modal-backdrop,
body > .modal-backdrop.show {
  background: rgba(0, 0, 0, 0.55);
}

/* =========================================================
   CONTACT SUCCESS MODAL (contact.html)
   ========================================================= */
.dc3-success-modal .modal-dialog {
  max-width: 480px;
}

.dc3-success-modal__content {
  position: relative;
  border: 1px solid var(--dc3-border);
  border-radius: 22px;
  background: var(--dc3-bg);
  padding: 3rem 1.75rem 2.25rem;
  text-align: center;
  overflow: hidden;
}

@media (min-width: 576px) {
  .dc3-success-modal__content {
    padding: 3.25rem 2.75rem 2.5rem;
  }
}

.dc3-success-modal__close {
  position: absolute;
  top: 1rem;
  right: 1rem;
  z-index: 3;
  padding: 0.65rem;
  border-radius: 999px;
  opacity: 0.6;
  transition: opacity 0.2s ease, background-color 0.2s ease;
}

.dc3-success-modal__close:hover,
.dc3-success-modal__close:focus-visible {
  opacity: 1;
  background: var(--dc3-bg-2);
}

.dc3-success-modal__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 4.5rem;
  height: 4.5rem;
  border-radius: 50%;
  background: #e8f6ec;
  color: #1d8a4a;
  font-size: 2.4rem;
  margin-bottom: 1.4rem;
  animation: dc3-success-pop 0.35s ease;
}

@media (prefers-reduced-motion: reduce) {
  .dc3-success-modal__icon {
    animation: none;
  }
}

@keyframes dc3-success-pop {
  0% {
    transform: scale(0.6);
    opacity: 0;
  }
  60% {
    transform: scale(1.08);
    opacity: 1;
  }
  100% {
    transform: scale(1);
  }
}

.dc3-success-modal__eyebrow {
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--dc3-muted);
  margin: 0 0 0.6rem;
}

.dc3-success-modal__title {
  font-family: var(--dc3-font-display);
  font-size: clamp(1.4rem, 3.5vw, 1.85rem);
  font-weight: 800;
  letter-spacing: -0.02em;
  color: var(--dc3-text);
  margin: 0 0 0.85rem;
  line-height: 1.15;
}

.dc3-success-modal__text {
  font-size: 0.98rem;
  line-height: 1.6;
  color: var(--dc3-muted);
  margin: 0 0 1.75rem;
}

/* Submit button loading spinner (shared) */
.dc3-spin {
  display: inline-block;
  animation: dc3-spin 0.8s linear infinite;
}

@keyframes dc3-spin {
  to {
    transform: rotate(360deg);
  }
}

@media (prefers-reduced-motion: reduce) {
  .dc3-spin {
    animation: none;
  }
}

/* =========================================================
   CONTACT PAGE — direct contact info cards
   ========================================================= */
.dc3-contact-info {
  background: var(--dc3-bg-2);
  border-top: 1px solid var(--dc3-border);
}

.dc3-contact-info__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.25rem;
}

@media (min-width: 768px) {
  .dc3-contact-info__grid {
    grid-template-columns: repeat(3, 1fr);
    gap: 1.5rem;
  }
}

.dc3-contact-info__card {
  display: flex;
  flex-direction: column;
  background: var(--dc3-bg);
  border: 1px solid var(--dc3-border);
  border-radius: 18px;
  padding: 2rem 1.75rem 1.75rem;
  transition: transform 0.25s ease, border-color 0.25s ease,
    box-shadow 0.25s ease;
}

.dc3-contact-info__card:hover {
  transform: translateY(-3px);
  border-color: var(--dc3-border-strong);
  box-shadow: 0 22px 48px -24px rgba(0, 0, 0, 0.2);
}

.dc3-contact-info__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 3rem;
  height: 3rem;
  border-radius: 12px;
  background: var(--dc3-bg-2);
  border: 1px solid var(--dc3-border);
  color: var(--dc3-text);
  font-size: 1.25rem;
  margin-bottom: 1.25rem;
}

.dc3-contact-info__label {
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--dc3-muted);
  margin: 0 0 0.4rem;
}

.dc3-contact-info__name {
  font-size: 1.1rem;
  font-weight: 700;
  letter-spacing: -0.01em;
  color: var(--dc3-text);
  margin: 0 0 0.65rem;
  line-height: 1.3;
}

.dc3-contact-info__text {
  margin: 0;
  font-size: 0.95rem;
  color: var(--dc3-muted);
  line-height: 1.55;
}

.dc3-contact-info__list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.dc3-contact-info__list li {
  display: flex;
  align-items: baseline;
  gap: 0.6rem;
  flex-wrap: wrap;
}

.dc3-contact-info__list a {
  font-size: 1rem;
  font-weight: 600;
  font-variant-numeric: tabular-nums;
  color: var(--dc3-text);
  text-decoration: none;
  border-bottom: 1px solid transparent;
  transition: color 0.2s ease, border-color 0.2s ease;
}

.dc3-contact-info__list a:hover,
.dc3-contact-info__list a:focus-visible {
  color: var(--dc3-accent);
  border-bottom-color: var(--dc3-text);
  outline: none;
}

.dc3-contact-info__note {
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--dc3-muted-2);
}

.dc3-contact-info__email {
  display: inline-block;
  font-size: 1rem;
  font-weight: 600;
  color: var(--dc3-text);
  text-decoration: none;
  word-break: break-word;
  border-bottom: 1px solid transparent;
  transition: color 0.2s ease, border-color 0.2s ease;
}

.dc3-contact-info__email:hover,
.dc3-contact-info__email:focus-visible {
  color: var(--dc3-accent);
  border-bottom-color: var(--dc3-text);
  outline: none;
}

.dc3-contact-info__link {
  display: inline-flex;
  align-items: center;
  margin-top: auto;
  padding-top: 0.85rem;
  font-size: 0.88rem;
  font-weight: 600;
  letter-spacing: 0.02em;
  color: var(--dc3-text);
  text-decoration: none;
  transition: color 0.2s ease, transform 0.2s ease;
}

.dc3-contact-info__link:hover,
.dc3-contact-info__link:focus-visible {
  color: var(--dc3-accent);
  outline: none;
}

.dc3-contact-info__link:hover .bi {
  transform: translate(2px, -2px);
}

.dc3-contact-info__link .bi {
  transition: transform 0.2s ease;
}

/* =========================================================
   SERMONS PAGE — grid + cards + lightbox modal
   ========================================================= */
.dc3-sermons-page {
  background: var(--dc3-bg-2);
}

.dc3-sermons-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.25rem;
}

@media (min-width: 576px) {
  .dc3-sermons-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 1.5rem;
  }
}

@media (min-width: 992px) {
  .dc3-sermons-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

/* ---------- Sermon card ---------- */
.dc3-sermon-card {
  display: flex;
  flex-direction: column;
  background: var(--dc3-bg);
  border: 1px solid var(--dc3-border);
  border-radius: 16px;
  overflow: hidden;
  transition: transform 0.25s ease, border-color 0.25s ease,
    box-shadow 0.25s ease;
}

.dc3-sermon-card:hover,
.dc3-sermon-card:focus-within {
  transform: translateY(-3px);
  border-color: var(--dc3-border-strong);
  box-shadow: 0 22px 48px -24px rgba(0, 0, 0, 0.22);
}

.dc3-sermon-card__thumb {
  position: relative;
  display: block;
  width: 100%;
  aspect-ratio: 16 / 9;
  padding: 0;
  margin: 0;
  border: none;
  background: var(--dc3-bg-2);
  cursor: pointer;
  overflow: hidden;
}

.dc3-sermon-card__thumb:focus-visible {
  outline: 2px solid var(--dc3-text);
  outline-offset: 2px;
}

.dc3-sermon-card__thumb img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.55s ease;
}

.dc3-sermon-card:hover .dc3-sermon-card__thumb img,
.dc3-sermon-card:focus-within .dc3-sermon-card__thumb img {
  transform: scale(1.04);
}

.dc3-sermon-card__play {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 3.5rem;
  height: 3.5rem;
  padding-left: 0.18rem; /* optical centring for the play glyph */
  border-radius: 50%;
  background: rgba(0, 0, 0, 0.78);
  color: #fff;
  font-size: 1.4rem;
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  transition: transform 0.25s ease, background-color 0.25s ease;
}

.dc3-sermon-card:hover .dc3-sermon-card__play,
.dc3-sermon-card:focus-within .dc3-sermon-card__play {
  background: var(--dc3-accent);
  transform: translate(-50%, -50%) scale(1.08);
}

.dc3-sermon-card__meta {
  padding: 1.1rem 1.25rem 1.25rem;
}

.dc3-sermon-card__title {
  margin: 0 0 0.4rem;
  font-size: 1.02rem;
  font-weight: 700;
  letter-spacing: -0.01em;
  color: var(--dc3-text);
  line-height: 1.4;
  display: -webkit-box;
  line-clamp: 2;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.dc3-sermon-card__date {
  margin: 0;
  font-size: 0.74rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--dc3-muted);
}

/* ---------- Load More button ---------- */
.dc3-sermons-load-more {
  display: flex;
  justify-content: center;
  margin-top: 2.5rem;
}

.dc3-sermons-load-more[hidden] {
  display: none;
}

.dc3-sermons-load-more .btn {
  min-width: 12rem;
  font-weight: 600;
  letter-spacing: 0.01em;
}

.dc3-sermons-load-more .btn:disabled {
  opacity: 0.7;
  cursor: progress;
}

.dc3-sermons-load-more .spinner-border-sm {
  width: 1rem;
  height: 1rem;
  border-width: 2px;
  vertical-align: -0.15em;
}

/* ---------- Empty / Loading / Error state ---------- */
.dc3-sermons-state {
  grid-column: 1 / -1;
  text-align: center;
  padding: 3rem 1.5rem;
  color: var(--dc3-muted);
}

.dc3-sermons-state > i {
  display: inline-block;
  font-size: 2.5rem;
  margin-bottom: 1rem;
  color: var(--dc3-muted-2);
}

.dc3-sermons-state__text {
  margin: 0;
  font-size: 1rem;
  max-width: 32rem;
  margin-left: auto;
  margin-right: auto;
}

.dc3-sermons-state .spinner-border {
  width: 2.5rem;
  height: 2.5rem;
  color: var(--dc3-muted-2);
  margin-bottom: 1rem;
}

/* ---------- Lightbox modal ---------- */
.dc3-sermon-modal .modal-dialog {
  max-width: 960px;
}

.dc3-sermon-modal__content {
  position: relative;
  border: 1px solid var(--dc3-border);
  border-radius: 18px;
  background: var(--dc3-bg);
  padding: 0;
  overflow: hidden;
}

.dc3-sermon-modal__close {
  position: absolute;
  top: 0.85rem;
  right: 0.85rem;
  z-index: 10;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.4rem;
  height: 2.4rem;
  padding: 0;
  background: rgba(255, 255, 255, 0.95);
  border: 1px solid rgba(0, 0, 0, 0.08);
  border-radius: 999px;
  color: var(--dc3-text);
  font-size: 1rem;
  line-height: 1;
  cursor: pointer;
  box-shadow: 0 6px 18px -6px rgba(0, 0, 0, 0.45);
  transition: background-color 0.2s ease, transform 0.2s ease,
    box-shadow 0.2s ease;
}

.dc3-sermon-modal__close:hover,
.dc3-sermon-modal__close:focus-visible {
  background: #fff;
  transform: scale(1.06);
  outline: none;
  box-shadow: 0 10px 24px -8px rgba(0, 0, 0, 0.5);
}

.dc3-sermon-modal__close .bi {
  font-size: 1rem;
}

.dc3-sermon-modal__player {
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 9;
  background: #000;
}

.dc3-sermon-modal__player iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: 0;
}

.dc3-sermon-modal__meta {
  padding: 1.5rem 1.75rem 1.75rem;
}

.dc3-sermon-modal__title {
  margin: 0 0 0.5rem;
  font-family: var(--dc3-font-display);
  font-size: clamp(1.15rem, 2vw, 1.45rem);
  font-weight: 700;
  letter-spacing: -0.01em;
  color: var(--dc3-text);
  line-height: 1.3;
}

.dc3-sermon-modal__date {
  margin: 0 0 1rem;
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--dc3-muted);
}

.dc3-sermon-modal__link {
  display: inline-flex;
  align-items: center;
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--dc3-text);
  text-decoration: none;
  border-bottom: 1px solid transparent;
  transition: color 0.2s ease, border-color 0.2s ease;
}

.dc3-sermon-modal__link:hover,
.dc3-sermon-modal__link:focus-visible {
  color: var(--dc3-accent);
  border-bottom-color: var(--dc3-text);
  outline: none;
}

.dc3-sermon-modal__link .bi {
  transition: transform 0.2s ease;
}

.dc3-sermon-modal__link:hover .bi {
  transform: translate(2px, -2px);
}

@media (max-width: 575.98px) {
  .dc3-sermon-modal__meta {
    padding: 1.25rem 1.25rem 1.5rem;
  }
}

/* =========================================================
   BACK TO TOP BUTTON
   ========================================================= */
.dc3-back-to-top {
  position: fixed;
  right: 1.5rem;
  bottom: 1.5rem;
  z-index: 1040;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 3rem;
  height: 3rem;
  padding: 0;
  border: 1px solid var(--dc3-border-strong);
  border-radius: 50%;
  background-color: var(--dc3-accent);
  color: #ffffff;
  font-size: 1.25rem;
  line-height: 1;
  cursor: pointer;
  box-shadow: 0 6px 20px rgba(0, 0, 0, 0.18);
  opacity: 0;
  visibility: hidden;
  transform: translateY(12px);
  transition: opacity 0.25s ease, transform 0.25s ease,
    visibility 0.25s ease, background-color 0.2s ease;
}

.dc3-back-to-top.is-visible {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.dc3-back-to-top:hover,
.dc3-back-to-top:focus-visible {
  background-color: var(--dc3-accent-2);
  outline: none;
}

.dc3-back-to-top:focus-visible {
  box-shadow: 0 0 0 3px rgba(0, 0, 0, 0.25);
}

.dc3-back-to-top .bi {
  transition: transform 0.2s ease;
}

.dc3-back-to-top:hover .bi {
  transform: translateY(-2px);
}

@media (max-width: 575.98px) {
  .dc3-back-to-top {
    right: 1rem;
    bottom: 1rem;
    width: 2.75rem;
    height: 2.75rem;
    font-size: 1.1rem;
  }
}

@media (prefers-reduced-motion: reduce) {
  .dc3-back-to-top {
    transition: opacity 0.25s ease, visibility 0.25s ease;
    transform: none;
  }
  .dc3-back-to-top.is-visible {
    transform: none;
  }
}
