/* ============================================================
   LIBERTY TEMPLE NJ — SHARED DESIGN SYSTEM v5
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Instrument+Serif:ital@0;1&family=Montserrat:ital,wght@0,300;0,400;0,500;0,600;1,300&family=League+Spartan:wght@400;500;600;700;800&display=swap');

:root {
  --forest:    #2B563D;
  --forest-dk: #1e3d2a;
  --forest-lt: #3a7054;
  --forest-xlt:#e8f0eb;
  --cream:     #FFFCF2;
  --cream-dk:  #f4f0e3;
  --warm-gray: #EDEBE3;
  --dark:      #1D1815;
  --dark-mid:  #2a2420;
  --gold:      #FFAA33;
  --gold-dk:   #cc8822;
  --slate:     #4B5B82;
  --white:     #ffffff;
  --muted:     #5a5248;
  --border:    rgba(29,24,21,0.08);
  --border-lt: rgba(255,252,242,0.1);

  --font-heading: 'Instrument Serif', Georgia, serif;
  --font-ui:      'League Spartan', sans-serif;
  --font-body:    'Montserrat', sans-serif;

  --nav-h: 68px;
  --max:   1160px;
  --r-xs:  2px;
  --r-sm:  4px;
  --r-md:  8px;
  --r-lg:  12px;
}

/* ============================================================
   RESET
   ============================================================ */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; font-size:16px; }
body {
  font-family:var(--font-body);
  background:var(--cream);
  color:var(--dark);
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}
img { max-width:100%; display:block; }
a { text-decoration:none; color:inherit; }
button { font-family:var(--font-body); cursor:pointer; border:none; background:none; }

/* ============================================================
   LAYOUT
   ============================================================ */
.wrap     { max-width:var(--max); margin:0 auto; padding:0 48px; }
.wrap-sm  { max-width:740px; margin:0 auto; padding:0 48px; }
.grid-2   { display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:center; }
.grid-3   { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.section  { padding:96px 0; }
.section-sm { padding:60px 0; }

/* ============================================================
   TYPOGRAPHY
   ============================================================ */
h1, h2, h3, .t-heading, .section-headline, .page-hero-title {
  font-family:var(--font-heading);
  font-weight:400;
  line-height:1.08;
}
.t-display  { font-family:var(--font-heading); font-weight:400; line-height:0.96; }
.t-ui       { font-family:var(--font-ui); font-weight:600; letter-spacing:0.02em; }
.t-body     { font-family:var(--font-body); font-weight:400; line-height:1.82; font-size:15px; color:var(--muted); }
.t-label    { font-family:var(--font-ui); font-size:10px; font-weight:700; letter-spacing:0.16em; text-transform:uppercase; }

.section-label    { display:block; margin-bottom:16px; }
.section-headline { font-size:clamp(28px,4.5vw,52px); margin-bottom:20px; }
.section-sub      { font-size:15px; font-weight:400; color:var(--muted); line-height:1.8; max-width:540px; }
p { color:var(--muted); line-height:1.82; font-weight:400; }

/* ============================================================
   TAGS
   ============================================================ */
.tag {
  display:inline-flex; align-items:center;
  font-family:var(--font-ui); font-size:9px; font-weight:700;
  letter-spacing:0.16em; text-transform:uppercase;
  padding:4px 12px; border-radius:var(--r-xs);
}
.tag-forest { background:rgba(43,86,61,0.1);   color:var(--forest); }
.tag-gold   { background:rgba(255,170,51,0.13); color:#7a4800; }
.tag-cream  { background:rgba(255,252,242,0.12); color:var(--cream); border:1px solid rgba(255,252,242,0.16); }
.tag-slate  { background:rgba(75,91,130,0.1);   color:var(--slate); }

/* ============================================================
   BUTTONS
   ============================================================ */
.btn {
  display:inline-flex; align-items:center; gap:8px;
  font-family:var(--font-ui); font-size:11px; font-weight:700;
  letter-spacing:0.09em; text-transform:uppercase;
  padding:13px 28px; border-radius:var(--r-xs);
  transition:all 0.2s cubic-bezier(0.4,0,0.2,1);
  white-space:nowrap; cursor:pointer;
}
.btn-primary        { background:var(--forest); color:var(--cream); border:1.5px solid var(--forest); }
.btn-primary:hover  { background:var(--forest-dk); border-color:var(--forest-dk); transform:translateY(-1px); box-shadow:0 8px 22px rgba(43,86,61,0.26); }
.btn-outline-cream  { background:transparent; color:var(--cream); border:1.5px solid rgba(255,252,242,0.3); }
.btn-outline-cream:hover { background:rgba(255,252,242,0.08); border-color:rgba(255,252,242,0.55); }
.btn-outline-dark   { background:transparent; color:var(--dark); border:1.5px solid rgba(29,24,21,0.18); }
.btn-outline-dark:hover { background:var(--dark); color:var(--cream); border-color:var(--dark); }

/* ============================================================
   NAVIGATION
   ============================================================ */
#nav {
  position:fixed; top:0; left:0; right:0; z-index:900;
  height:var(--nav-h);
  background:rgba(29,24,21,0.92);
  backdrop-filter:blur(20px) saturate(160%);
  -webkit-backdrop-filter:blur(20px) saturate(160%);
  border-bottom:1px solid var(--border-lt);
  transition:background 0.3s, border-color 0.3s;
}
#nav.nav-light { background:rgba(255,252,242,0.97); border-bottom-color:var(--border); }
.nav-inner { height:var(--nav-h); display:flex; align-items:center; justify-content:space-between; }

.nav-logo { display:flex; align-items:center; }
.nav-wordmark-img { height:34px; width:auto; max-width:200px; object-fit:contain; filter:brightness(0) invert(1); transition:filter 0.3s; }
#nav.nav-light .nav-wordmark-img { filter:none; }
.nav-logo-text { display:flex; align-items:center; gap:10px; }
.nav-logo-mark {
  width:34px; height:34px; background:var(--forest); border-radius:var(--r-sm);
  display:flex; align-items:center; justify-content:center;
  font-family:var(--font-ui); font-size:14px; font-weight:800;
  color:var(--cream); flex-shrink:0; overflow:hidden;
}
.nav-logo-mark img { width:100%; height:100%; object-fit:cover; }
.nav-logo-name { font-family:var(--font-ui); font-size:12px; font-weight:700; letter-spacing:0.01em; line-height:1.1; color:var(--cream); transition:color 0.3s; }
#nav.nav-light .nav-logo-name { color:var(--dark); }
.nav-logo-sub  { font-size:8px; font-weight:500; letter-spacing:0.12em; text-transform:uppercase; color:rgba(255,252,242,0.38); transition:color 0.3s; }
#nav.nav-light .nav-logo-sub { color:rgba(29,24,21,0.38); }

.nav-links { display:flex; align-items:center; gap:0; list-style:none; }
.nav-links li a {
  font-family:var(--font-ui); font-size:11px; font-weight:600;
  letter-spacing:0.07em; text-transform:uppercase;
  padding:7px 11px; border-radius:var(--r-xs);
  color:rgba(255,252,242,0.62); transition:all 0.18s; display:block;
}
#nav.nav-light .nav-links li a { color:rgba(29,24,21,0.58); }
.nav-links li a:hover { color:var(--cream); background:rgba(255,252,242,0.07); }
#nav.nav-light .nav-links li a:hover { color:var(--dark); background:rgba(29,24,21,0.05); }
.nav-links .active-page { color:rgba(255,252,242,0.92) !important; }
#nav.nav-light .nav-links .active-page { color:var(--forest) !important; }
.nav-links .nav-cta {
  margin-left:6px; background:var(--forest) !important;
  color:var(--cream) !important; font-weight:700 !important;
  padding:7px 15px !important; border-radius:var(--r-xs) !important;
}
.nav-links .nav-cta:hover { background:var(--forest-dk) !important; }

.hamburger { display:none; flex-direction:column; gap:5px; padding:8px; cursor:pointer; }
.hamburger span { width:20px; height:1.5px; background:rgba(255,252,242,0.75); display:block; transition:all 0.25s; border-radius:1px; }
#nav.nav-light .hamburger span { background:var(--dark); }

.mobile-nav {
  display:none; position:fixed; top:var(--nav-h); left:0; right:0;
  background:rgba(24,20,17,0.98); backdrop-filter:blur(16px);
  z-index:899; padding:12px 20px 20px; flex-direction:column;
  border-bottom:1px solid var(--border-lt);
}
.mobile-nav.open { display:flex; }
.mobile-nav a {
  font-family:var(--font-ui); font-size:13px; font-weight:600;
  letter-spacing:0.04em; text-transform:uppercase;
  padding:13px 12px; color:rgba(255,252,242,0.62);
  border-bottom:1px solid rgba(255,252,242,0.05); transition:color 0.18s;
}
.mobile-nav a:hover { color:var(--cream); }
.mobile-nav a:last-child { border-bottom:none; }
.mobile-nav .nav-cta-mobile {
  margin-top:8px; background:var(--forest); color:var(--cream) !important;
  text-align:center; border-radius:var(--r-sm); border-bottom:none !important;
}

/* ============================================================
   PAGE HERO
   ============================================================ */
.page-hero {
  position:relative; overflow:hidden;
  padding:148px 0 72px; background:var(--dark);
  min-height:280px; display:flex; align-items:flex-end;
}
.page-hero-bg {
  position:absolute; inset:0;
  background-size:cover; background-position:center; opacity:0.24;
  /* NO background-attachment:fixed — that causes the scroll-lock bug on mobile */
}
.page-hero-overlay {
  position:absolute; inset:0;
  background:linear-gradient(to bottom, rgba(29,24,21,0.5) 0%, rgba(29,24,21,0.88) 100%);
}
.page-hero-inner    { position:relative; z-index:1; }
.page-hero-eyebrow  { margin-bottom:16px; }
.page-hero-title {
  font-family:var(--font-heading); font-weight:400;
  font-size:clamp(32px,5vw,66px); line-height:1.06;
  color:var(--cream); margin-bottom:14px;
}
.page-hero-sub { font-size:15px; font-weight:400; color:rgba(255,252,242,0.52); line-height:1.75; max-width:480px; }

/* ============================================================
   IMAGE PLACEHOLDER
   ============================================================ */
.img-ph {
  width:100%; height:100%; background:rgba(43,86,61,0.04);
  border:1.5px dashed rgba(43,86,61,0.18); border-radius:inherit;
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:10px; text-align:center; padding:24px;
}
.img-ph-icon { width:36px; height:36px; border-radius:50%; border:1px solid rgba(43,86,61,0.2); display:flex; align-items:center; justify-content:center; }
.img-ph-icon svg { width:16px; height:16px; stroke:rgba(43,86,61,0.45); fill:none; stroke-width:1.5; }
.img-ph-label { font-family:var(--font-ui); font-size:9px; font-weight:700; letter-spacing:0.12em; text-transform:uppercase; color:rgba(43,86,61,0.38); line-height:1.5; }

/* ============================================================
   SERVICE STRIP
   ============================================================ */
.service-strip { background:var(--forest); }
.strip-inner   { display:flex; align-items:stretch; overflow-x:auto; scrollbar-width:none; }
.strip-inner::-webkit-scrollbar { display:none; }
.strip-item    { flex:1; min-width:150px; padding:14px 24px; border-right:1px solid rgba(255,252,242,0.09); }
.strip-item:last-child { border-right:none; }
.strip-day     { font-family:var(--font-ui); font-size:8px; font-weight:700; letter-spacing:0.16em; text-transform:uppercase; color:rgba(255,252,242,0.42); margin-bottom:2px; }
.strip-time    { font-family:var(--font-ui); font-size:11px; font-weight:600; letter-spacing:0.01em; color:rgba(255,252,242,0.9); }

/* ============================================================
   BELIEVE CARDS
   ============================================================ */
.believe-card { background:var(--white); border-radius:var(--r-xs); padding:18px 22px; border-left:2px solid var(--forest); box-shadow:0 1px 8px rgba(29,24,21,0.05); transition:transform 0.2s ease, box-shadow 0.2s ease; }
.believe-card:nth-child(2) { border-left-color:var(--gold); }
.believe-card:nth-child(3) { border-left-color:var(--slate); }
.believe-card:hover { transform:translateX(4px); box-shadow:0 4px 14px rgba(29,24,21,0.08); }
.believe-card h3 { font-family:var(--font-ui); font-size:11px; font-weight:700; letter-spacing:0.07em; text-transform:uppercase; color:var(--dark); margin-bottom:5px; }
.believe-card p  { font-size:13px; color:var(--muted); line-height:1.7; font-weight:400; }

/* ============================================================
   PLATFORM LINKS
   ============================================================ */
.platform-link { display:flex; align-items:center; gap:12px; background:rgba(255,255,255,0.04); border:1px solid var(--border-lt); border-radius:var(--r-xs); padding:12px 15px; transition:all 0.2s; color:var(--cream); }
.platform-link:hover { background:rgba(255,255,255,0.07); border-color:rgba(43,86,61,0.45); transform:translateX(3px); }
.platform-logo  { width:32px; height:32px; border-radius:var(--r-sm); flex-shrink:0; display:flex; align-items:center; justify-content:center; font-size:13px; color:#fff; }
.platform-name  { font-family:var(--font-ui); font-size:12px; font-weight:700; letter-spacing:0.03em; color:var(--cream); }
.platform-handle { font-size:11px; color:rgba(255,252,242,0.36); font-weight:400; margin-top:1px; }
.platform-arrow { margin-left:auto; color:rgba(255,252,242,0.18); font-size:11px; }

/* ============================================================
   VALUE CARDS
   ============================================================ */
.value-card { background:var(--white); border-radius:var(--r-xs); padding:28px; box-shadow:0 1px 8px rgba(29,24,21,0.05); }
.value-card-bar { width:32px; height:2px; background:var(--forest); margin-bottom:16px; }
.value-card:nth-child(2) .value-card-bar { background:var(--gold); }
.value-card:nth-child(3) .value-card-bar { background:var(--slate); }
.value-card h3 { font-family:var(--font-ui); font-size:12px; font-weight:700; letter-spacing:0.05em; text-transform:uppercase; margin-bottom:9px; color:var(--dark); }
.value-card p  { font-size:14px; color:var(--muted); line-height:1.75; font-weight:400; }

/* ============================================================
   LEADER CARD
   ============================================================ */
.leader-card { background:var(--white); border-radius:var(--r-xs); overflow:hidden; box-shadow:0 1px 10px rgba(29,24,21,0.06); }
.leader-card-photo { overflow:hidden; background:var(--dark-mid); }
.leader-card-photo img { width:100%; height:100%; object-fit:cover; }
.leader-card-body  { padding:24px; }
.leader-role { font-family:var(--font-ui); font-size:9px; font-weight:700; letter-spacing:0.16em; text-transform:uppercase; color:var(--forest); display:block; margin-bottom:5px; }
.leader-name { font-family:var(--font-heading); font-size:20px; font-weight:400; color:var(--dark); margin-bottom:10px; }
.leader-bio  { font-size:14px; font-weight:400; color:var(--muted); line-height:1.8; }

/* ============================================================
   FAQ
   ============================================================ */
.faq-item { border-bottom:1px solid var(--border); }
.faq-q { display:flex; align-items:center; justify-content:space-between; gap:16px; padding:20px 0; cursor:pointer; font-family:var(--font-heading); font-size:16px; font-weight:400; color:var(--dark); user-select:none; }
.faq-toggle { width:24px; height:24px; flex-shrink:0; border:1px solid var(--border); border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:16px; color:var(--muted); transition:transform 0.22s, border-color 0.18s, color 0.18s; }
.faq-item.open .faq-toggle { transform:rotate(45deg); border-color:var(--forest); color:var(--forest); }
.faq-a { font-size:14px; font-weight:400; color:var(--muted); line-height:1.8; max-height:0; overflow:hidden; transition:max-height 0.3s ease, padding 0.18s; }
.faq-item.open .faq-a { max-height:200px; padding-bottom:20px; }

/* ============================================================
   SCHEDULE
   ============================================================ */
.schedule-row { display:flex; gap:16px; padding:20px 0; border-bottom:1px solid var(--border); }
.schedule-row:last-child { border-bottom:none; }
.schedule-pip  { width:8px; height:8px; border-radius:50%; flex-shrink:0; background:var(--forest); margin-top:5px; }
.schedule-pip.gold { background:var(--gold); }
.schedule-day  { font-family:var(--font-ui); font-size:11px; font-weight:700; letter-spacing:0.05em; text-transform:uppercase; color:var(--dark); margin-bottom:4px; }
.schedule-detail { font-size:14px; color:var(--muted); font-weight:400; line-height:1.65; }

/* ============================================================
   CONTACT BOX
   ============================================================ */
.contact-box { background:var(--dark); border-radius:var(--r-sm); padding:36px; }
.contact-box h3 { font-family:var(--font-heading); font-size:22px; font-weight:400; color:var(--cream); margin-bottom:24px; }
.contact-row   { margin-bottom:15px; }
.contact-row-label { font-family:var(--font-ui); font-size:8px; font-weight:700; letter-spacing:0.16em; text-transform:uppercase; color:var(--gold); margin-bottom:3px; display:block; }
.contact-row-val   { font-size:13px; color:rgba(255,252,242,0.7); font-weight:400; line-height:1.5; }
.contact-row-val a { color:rgba(255,252,242,0.7); }
.contact-row-val a:hover { color:var(--gold); }

/* ============================================================
   FOOTER
   ============================================================ */
footer { background:var(--dark); padding:64px 0 36px; border-top:1px solid var(--border-lt); }
.footer-grid { display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:52px; padding-bottom:44px; border-bottom:1px solid var(--border-lt); }
.footer-brand-desc { font-size:13px; font-weight:400; color:rgba(255,252,242,0.38); line-height:1.75; max-width:260px; margin:12px 0 18px; }
.social-row  { display:flex; gap:7px; }
.social-btn  { width:32px; height:32px; border-radius:var(--r-xs); border:1px solid var(--border-lt); background:transparent; display:flex; align-items:center; justify-content:center; color:rgba(255,252,242,0.4); transition:all 0.18s; text-decoration:none; font-size:12px; }
.social-btn:hover { background:var(--forest); border-color:var(--forest); color:var(--cream); transform:translateY(-2px); }
.footer-col h4 { font-family:var(--font-ui); font-size:9px; font-weight:700; letter-spacing:0.16em; text-transform:uppercase; color:rgba(255,252,242,0.3); margin-bottom:13px; }
.footer-col ul { list-style:none; }
.footer-col ul li { margin-bottom:8px; }
.footer-col ul li a { font-size:13px; font-weight:400; color:rgba(255,252,242,0.48); transition:color 0.18s; }
.footer-col ul li a:hover { color:var(--cream); }
.footer-bottom { padding-top:28px; display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:8px; }
.footer-bottom p { font-size:11px; font-weight:400; color:rgba(255,252,242,0.18); }

/* ============================================================
   LOADING
   ============================================================ */
.site-loading { position:fixed; inset:0; background:var(--dark); display:flex; align-items:center; justify-content:center; z-index:9999; transition:opacity 0.35s ease; }
.site-loading.hidden { opacity:0; pointer-events:none; }
.loading-inner { text-align:center; }
.loading-mark  { width:44px; height:44px; background:var(--forest); border-radius:var(--r-sm); display:flex; align-items:center; justify-content:center; font-family:var(--font-ui); font-size:18px; font-weight:800; color:var(--cream); margin:0 auto 13px; overflow:hidden; animation:loadPulse 1.4s ease-in-out infinite; }
.loading-mark img { width:100%; height:100%; object-fit:cover; }
@keyframes loadPulse { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:0.72;transform:scale(0.95)} }
.loading-text  { font-family:var(--font-ui); font-size:9px; font-weight:700; letter-spacing:0.2em; text-transform:uppercase; color:rgba(255,252,242,0.22); }

/* ============================================================
   SCROLL ANIMATIONS
   ============================================================ */
.fade-up          { opacity:0; transform:translateY(20px); transition:opacity 0.55s ease, transform 0.55s ease; }
.fade-up.visible  { opacity:1; transform:translateY(0); }
.fade-up-delay-1  { transition-delay:0.08s; }
.fade-up-delay-2  { transition-delay:0.16s; }
.fade-up-delay-3  { transition-delay:0.24s; }
.fade-up-delay-4  { transition-delay:0.32s; }
.fade-up-delay-5  { transition-delay:0.40s; }
.fade-up-delay-6  { transition-delay:0.48s; }

/* ============================================================
   RESPONSIVE — DESKTOP LARGE (1200px+)
   ============================================================ */
@media (min-width:1200px) {
  .wrap { padding:0 56px; }
}

/* ============================================================
   RESPONSIVE — TABLET LANDSCAPE (1024px)
   ============================================================ */
@media (max-width:1024px) {
  .wrap { padding:0 36px; }
  .wrap-sm { padding:0 36px; }
  .footer-grid { grid-template-columns:1fr 1fr; gap:36px; }
  .section { padding:80px 0; }
  /* About page story image: disable sticky on tablet — causes scroll-lock */
  .story-img-sticky { position:static !important; }
}

/* ============================================================
   RESPONSIVE — TABLET PORTRAIT (768px)
   ============================================================ */
@media (max-width:768px) {
  :root { --nav-h:60px; }

  .wrap, .wrap-sm { padding:0 20px; }

  /* Nav */
  .nav-links  { display:none; }
  .hamburger  { display:flex; }

  /* Sections */
  .section    { padding:60px 0; }
  .section-sm { padding:44px 0; }

  /* Grid — single column on mobile */
  .grid-2 { grid-template-columns:1fr; gap:36px; }
  .grid-3 { grid-template-columns:1fr 1fr; }

  /* All sticky images become static — prevents scroll-lock */
  [style*="position:sticky"],
  .story-img-sticky,
  .sticky-img { position:static !important; top:auto !important; }

  /* Aspect ratios: let images scale naturally, don't lock height */
  .believe-img-wrap,
  .story-img-wrap,
  [style*="aspect-ratio:3/4"] { aspect-ratio:4/3 !important; }

  /* Page hero */
  .page-hero { padding:110px 0 48px; }
  .page-hero-title { font-size:clamp(28px,9vw,48px); }
  .page-hero-sub   { font-size:14px; }

  /* Footer */
  .footer-grid { grid-template-columns:1fr; gap:28px; }
  .footer-brand-desc { max-width:100%; }

  /* Service strip: allow horizontal scroll */
  .strip-item { min-width:140px; padding:12px 18px; }

  /* Buttons: full-width on small screens when stacked */
  .hero-btns { gap:8px; }
  .hero-btns .btn { padding:12px 22px; font-size:10px; }

  /* Contact box */
  .contact-box { padding:28px 24px; }

  /* Tags */
  .tag { font-size:8px; padding:4px 10px; }
}

/* ============================================================
   RESPONSIVE — MOBILE (540px)
   ============================================================ */
@media (max-width:540px) {
  .wrap, .wrap-sm { padding:0 16px; }

  .grid-3 { grid-template-columns:1fr; }

  /* Sections tighter */
  .section { padding:48px 0; }

  /* Page hero tighter */
  .page-hero { padding:96px 0 40px; min-height:auto; }
  .page-hero-title { font-size:clamp(26px,10vw,42px); }

  /* Hero headline handled per-page */

  /* Full-width buttons */
  .hero-btns { flex-direction:column; align-items:flex-start; }

  /* FAQ question smaller */
  .faq-q { font-size:15px; }

  /* Footer bottom stacked */
  .footer-bottom { flex-direction:column; align-items:flex-start; gap:4px; }

  /* Cards: no hover translate on touch */
  .believe-card:hover { transform:none; }
  .platform-link:hover { transform:none; }
}

/* ============================================================
   RESPONSIVE — MOBILE SMALL (375px)
   ============================================================ */
@media (max-width:375px) {
  .wrap, .wrap-sm { padding:0 14px; }
  .section { padding:40px 0; }
  .page-hero { padding:88px 0 36px; }
  .strip-item { min-width:120px; padding:10px 14px; }
  .strip-time { font-size:10px; }
  .btn { padding:11px 18px; }
}

/* ============================================================
   TOUCH: disable hover effects on touch devices
   (prevents elements staying "stuck" in hover state)
   ============================================================ */
@media (hover:none) {
  .believe-card:hover,
  .ministry-card:hover,
  .platform-link:hover,
  .btn-primary:hover,
  .btn-outline-dark:hover,
  .btn-outline-cream:hover { transform:none; box-shadow:none; }
  .social-btn:hover { transform:none; }
}

/* ============================================================
   REDUCED MOTION: respect user preference
   ============================================================ */
@media (prefers-reduced-motion:reduce) {
  .fade-up { opacity:1; transform:none; transition:none; }
  .fade-up.visible { opacity:1; transform:none; }
  * { animation-duration:0.01ms !important; transition-duration:0.01ms !important; }
}
