/* ============================================================
   about/index.blade.php & contact/index.blade.php
   Responsive grid helpers
   ============================================================ */
@media(max-width:900px){
  .r-grid-2{grid-template-columns:1fr!important;gap:32px!important}
  .r-grid-3{grid-template-columns:1fr 1fr!important;gap:20px!important}
  .r-grid-4{grid-template-columns:1fr 1fr!important}
  .r-split-img{min-height:280px!important}
  .r-pad{padding:36px 28px!important}
}
@media(max-width:600px){
  .r-grid-2,.r-grid-3,.r-grid-4{grid-template-columns:1fr!important}
  .r-split-img{min-height:220px!important}
}

/* ============================================================
   GALLERY INDEX — gallery/index.blade.php
   ============================================================ */

/* Hero */
.gal-index-hero {
  background: var(--wlsa-red);
  padding: var(--section-lg) 0 56px;
  position: relative;
}
.gal-index-hero .breadcrumb {
  color: rgba(255,255,255,.78);
}
.gal-index-hero .breadcrumb a {
  color: var(--wlsa-gold);
}
.gal-index-hero .breadcrumb span {
  color: rgba(255,255,255,.45);
}
.gal-index-hero-title {
  font-family:var(--wlsa-font-heading);
  font-size: clamp(34px, 5vw, 56px);
  font-weight: 800;
  color: #fff;
  line-height: 1.1;
  margin: 12px 0 14px;
}
.gal-index-hero-title em {
  font-style: italic;
  color: var(--wlsa-gold);
}
.gal-index-hero-sub {
  font-size: clamp(15px, 2vw, 18px);
  color: rgba(255,255,255,.8);
  max-width: 540px;
}

/* Albums section */
.gal-albums {
  padding: var(--section-lg) 0 80px;
  background: var(--wlsa-cream);
}

/* Album cards grid */
.gal-albums-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}

/* Album card */
.gal-album-card {
  display: block;
  text-decoration: none;
  color: inherit;
  background: #fff;
  border-bottom: 3px solid transparent;
  transition: border-color .25s, box-shadow .25s;
  box-shadow: 0 2px 8px rgba(0,0,0,.06);
}
.gal-album-card:hover {
  border-bottom-color: var(--wlsa-gold);
  box-shadow: 0 8px 28px rgba(0,0,0,.13);
}

/* Image wrapper — 60% aspect ratio */
.gal-album-img-wrap {
  position: relative;
  overflow: hidden;
  padding-top: 62%;
}
.gal-album-img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .45s ease;
}
.gal-album-card:hover .gal-album-img {
  transform: scale(1.05);
}
.gal-album-img-placeholder {
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, var(--wlsa-brown) 0%, var(--wlsa-red) 100%);
}

/* Gradient overlay with title */
.gal-album-overlay {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: 52px 18px 16px;
  background: linear-gradient(to top, rgba(0,0,0,.78) 0%, transparent 100%);
}
.gal-album-title-text {
  font-family:var(--wlsa-font-heading);
  font-size: 18px;
  font-weight: 700;
  color: #fff;
  line-height: 1.3;
  margin: 0;
}

/* Photo count badge */
.gal-album-count {
  position: absolute;
  top: 12px;
  right: 12px;
  background: rgba(0,0,0,.62);
  color: #fff;
  font-family:var(--wlsa-font-condensed);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 1px;
  text-transform: uppercase;
  padding: 4px 10px;
  backdrop-filter: blur(4px);
}

/* Meta row below image */
.gal-album-meta {
  padding: 12px 16px 16px;
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}
.gal-album-meta-item {
  display: flex;
  align-items: center;
  gap: 5px;
  font-size: 13px;
  color: var(--text-sec);
}
.gal-album-meta-item svg {
  width: 13px;
  height: 13px;
  flex-shrink: 0;
  stroke: var(--text-sec);
}

/* Empty state (shared by both pages) */
.gal-empty {
  text-align: center;
  padding: 60px 0;
}
.gal-empty-icon {
  width: 72px;
  height: 72px;
  margin: 0 auto 20px;
  background: rgba(153,31,6,.08);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
}
.gal-empty-icon svg {
  width: 32px;
  height: 32px;
  stroke: var(--wlsa-red);
}
.gal-empty-title {
  font-family:var(--wlsa-font-heading);
  font-size: 22px;
  font-weight: 700;
  color: var(--text-dark);
  margin-bottom: 10px;
}
.gal-empty-text {
  font-size: 16px;
  color: var(--text-sec);
  max-width: 380px;
  margin: 0 auto;
  line-height: 1.65;
}

/* Paginator */
.gal-paginator {
  margin-top: 52px;
  text-align: center;
}

/* ============================================================
   ALBUM DETAIL — gallery/show.blade.php
   ============================================================ */

/* Description */
.gal-show-section {
  padding: 64px 0 80px;
  background: var(--wlsa-cream);
}
.gal-show-description {
  font-size: 17px;
  color: var(--text-sec);
  max-width: 720px;
  margin: 0 auto 48px;
  text-align: center;
  line-height: 1.75;
}

/* Hero meta bar */
.gal-show-hero-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 20px;
  margin-top: 12px;
}
.gal-show-hero-meta-item {
  display: flex;
  align-items: center;
  gap: 6px;
  font-family:var(--wlsa-font-condensed);
  font-size: 14px;
  font-weight: 600;
  letter-spacing: .5px;
  color: rgba(255,255,255,.8);
}
.gal-show-hero-meta-item svg {
  width: 15px;
  height: 15px;
  flex-shrink: 0;
}

/* Masonry grid */
.gal-masonry {
  columns: 3;
  column-gap: 12px;
}
.gal-masonry-item {
  break-inside: avoid;
  margin-bottom: 12px;
  cursor: pointer;
  overflow: hidden;
  position: relative;
  background: rgba(0,0,0,.04);
}
.gal-masonry-item img {
  width: 100%;
  height: auto;
  display: block;
  transition: filter .25s ease;
}
.gal-masonry-item:hover img {
  filter: brightness(1.08);
}
.gal-masonry-caption {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: 24px 12px 10px;
  background: linear-gradient(to top, rgba(0,0,0,.65), transparent);
  font-size: 13px;
  color: #fff;
  opacity: 0;
  transition: opacity .25s;
}
.gal-masonry-item:hover .gal-masonry-caption {
  opacity: 1;
}

/* Back link */
.gal-show-back {
  margin-top: 56px;
  text-align: center;
}
.gal-back-link {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  font-family:var(--wlsa-font-condensed);
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: var(--wlsa-red);
  text-decoration: none;
  border: 1.5px solid var(--wlsa-red);
  padding: 12px 28px;
  transition: background .2s, color .2s;
}
.gal-back-link:hover {
  background: var(--wlsa-red);
  color: #fff;
}
.gal-back-link svg {
  width: 16px;
  height: 16px;
  flex-shrink: 0;
}

/* ============================================================
   LIGHTBOX
   ============================================================ */
.gal-lb {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 9999;
  align-items: center;
  justify-content: center;
}
.gal-lb.gal-lb-open {
  display: flex;
}

/* Dark backdrop */
.gal-lb-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,.95);
}

/* Close button */
.gal-lb-close {
  position: fixed;
  top: 18px;
  right: 20px;
  z-index: 1;
  background: rgba(255,255,255,.12);
  border: 1px solid rgba(255,255,255,.25);
  color: #fff;
  width: 44px;
  height: 44px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: background .2s;
}
.gal-lb-close:hover {
  background: var(--wlsa-red);
  border-color: var(--wlsa-red);
}
.gal-lb-close svg {
  width: 20px;
  height: 20px;
}

/* Prev / Next buttons */
.gal-lb-btn {
  position: fixed;
  top: 50%;
  transform: translateY(-50%);
  z-index: 1;
  background: rgba(255,255,255,.10);
  border: 1px solid rgba(255,255,255,.2);
  color: #fff;
  width: 48px;
  height: 72px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: background .2s;
}
.gal-lb-btn:hover {
  background: rgba(255,255,255,.22);
}
.gal-lb-btn svg {
  width: 22px;
  height: 22px;
}
.gal-lb-prev { left: 0; }
.gal-lb-next { right: 0; }

/* Inner content: image + footer */
.gal-lb-inner {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  max-width: calc(100vw - 120px);
  max-height: 100vh;
  padding: 60px 0 20px;
}
.gal-lb-img-wrap {
  display: flex;
  align-items: center;
  justify-content: center;
  flex: 1;
  min-height: 0;
}
.gal-lb-img {
  max-width: 100%;
  max-height: 80vh;
  object-fit: contain;
  display: block;
  transition: opacity .18s ease;
}
.gal-lb-img.gal-lb-fading {
  opacity: 0;
}

/* Caption + counter */
.gal-lb-footer {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 4px 0;
  gap: 20px;
  min-height: 32px;
}
.gal-lb-caption {
  font-size: 14px;
  color: rgba(255,255,255,.75);
  line-height: 1.5;
  flex: 1;
}
.gal-lb-counter {
  font-family:var(--wlsa-font-condensed);
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 1px;
  color: var(--wlsa-gold);
  white-space: nowrap;
  flex-shrink: 0;
}

/* Responsive */
@media(max-width:900px) {
  .gal-albums-grid { grid-template-columns: repeat(2, 1fr); gap: 20px; }
  .gal-masonry { columns: 2; }
  .gal-lb-inner { max-width: calc(100vw - 80px); }
  .gal-lb-btn { width: 40px; height: 56px; }
}
@media(max-width:600px) {
  .gal-albums { padding: var(--section-sm) 0 56px; }
  .gal-albums-grid { grid-template-columns: 1fr; gap: 16px; }
  .gal-masonry { columns: 1; }
  .gal-lb-inner { max-width: 100vw; padding: 52px 0 16px; }
  .gal-lb-prev { left: 0; }
  .gal-lb-next { right: 0; }
  .gal-lb-btn { width: 36px; height: 48px; }
  .gal-index-hero { padding: 52px 0 40px; }
}

/* ============================================================
   Mobile friendliness hardening
   ============================================================ */
.mobile-hidden{}

@media(max-width:768px){
  .mobile-hidden{display:none!important}
  .mobile-stack{grid-template-columns:1fr!important;flex-direction:column!important}
  .mobile-full{width:100%!important;max-width:100%!important;flex-basis:100%!important}

  [style*="grid-template-columns:1fr 1fr"],
  [style*="grid-template-columns: 1fr 1fr"],
  [style*="grid-template-columns:repeat(2"],
  [style*="grid-template-columns: repeat(2"],
  [style*="grid-template-columns:repeat(3"],
  [style*="grid-template-columns: repeat(3"],
  [style*="grid-template-columns:repeat(4"],
  [style*="grid-template-columns: repeat(4"]{
    grid-template-columns:1fr!important;
  }

  [style*="display:flex"]{
    max-width:100%;
  }

  [style*="width:200px"],
  [style*="width: 200px"],
  [style*="height:480px"],
  [style*="height: 480px"]{
    max-width:100%!important;
  }

  .home-gallery-preview{
    display:none!important;
  }

  .upcoming-events-grid > *:nth-child(n+2){
    display:none!important;
  }

  .home-events-empty{
    display:none!important;
  }

  .news-sec,
  .thematic,
  .about,
  .legal,
  .donate,
  .impact,
  .quote-sec{
    padding-top:48px!important;
    padding-bottom:48px!important;
  }

  .gallery-mosaic{
    height:auto!important;
    grid-template-rows:none!important;
  }

  .gallery-mosaic a{
    min-height:220px;
  }

  .news-slider-wrap{
    overflow:hidden!important;
  }

  .news-slider{
    gap:16px!important;
  }

  .news-slider .nc{
    flex:0 0 100%!important;
    min-width:100%!important;
  }

  .nc,
  .t-card,
  .ev-card{
    width:100%;
  }

  .nc-img,
  .nc-iw,
  .ev-img,
  .nc-img-wrap{
    min-height:190px;
  }

  .art-grid,
  .event-detail-grid{
    padding:40px 0!important;
  }

  .art-content,
  .event-detail-content{
    font-size:16px!important;
    line-height:1.75!important;
  }

  .share-bar,
  .hero-btns,
  .d-amts,
  .legal-svcs{
    width:100%;
  }

  .share-bar .sbtn,
  .hero-btns a,
  .d-submit{
    width:100%;
    justify-content:center;
  }

  .d-amts{
    grid-template-columns:1fr!important;
  }

  .hero{
    min-height:520px!important;
    height:auto!important;
    max-height:none!important;
  }

  .hero-content{
    min-height:520px;
    padding-top:38px!important;
    padding-bottom:60px!important;
  }

  .hero-dot{
    width:14px!important;
    height:14px!important;
    min-width:44px;
    min-height:44px;
    border-radius:0!important;
    background:transparent!important;
    position:relative;
  }

  .hero-dot::after{
    content:'';
    position:absolute;
    inset:15px;
    border-radius:50%;
    background:rgba(255,255,255,.45);
  }

  .hero-dot.on::after,
  .hero-dot.active::after{
    background:var(--gold);
  }

  .scroll-hint{
    display:none!important;
  }

  form input,
  form select,
  form textarea{
    width:100%!important;
    font-size:16px!important;
  }

  [style*="font-size:10px"],
  [style*="font-size:11px"],
  [style*="font-size:12px"],
  .nc-date-month,
  .ev-date-m,
  .ev-type,
  .s-card-tag,
  .impact-mini-l,
  .f-col h4{
    font-size:14px!important;
    letter-spacing:1px!important;
  }

  .responsive-inline-form{
    gap:10px;
  }
}

@media(max-width:1024px){
  .hero-dot{
    min-width:44px;
    min-height:44px;
    position:relative;
  }

  .hero-dot::after{
    content:'';
    position:absolute;
    left:50%;
    top:50%;
    width:10px;
    height:10px;
    border-radius:50%;
    transform:translate(-50%,-50%);
    background:currentColor;
  }

  .see-all,
  .nfbtn,
  .story-toggle,
  .breadcrumb a,
  a[href^="tel:"],
  a[href^="mailto:"],
  a[href*="wa.me"],
  a[href][style*="font-family:var(--wlsa-font-condensed)"],
  a[href][style*="font-family:var(--wlsa-font-heading)"],
  a[href][style*="font-size:18px"],
  .f-contact-item a{
    min-height:44px;
    min-width:44px;
    display:inline-flex!important;
    align-items:center;
  }

  .breadcrumb a{
    padding-left:8px;
    padding-right:8px;
    margin-left:-8px;
  }

  .hero > .container > a[href="/contact"]{
    min-height:44px;
    display:inline-flex!important;
    align-items:center;
  }

  a[style*="width:40px"][style*="height:40px"]{
    width:44px!important;
    height:44px!important;
  }

  .page-hero + section a[style*="font-size:18px"]{
    min-height:44px;
    min-width:44px;
    display:inline-flex!important;
    align-items:center;
  }
}

@media(max-width:430px){
  .container{padding-left:16px!important;padding-right:16px!important}
  .hero-h1{font-size:36px!important}
  .hero-p{font-size:16px!important}
  .eyebrow{letter-spacing:2.2px}
  .sec-head{align-items:flex-start}
  .sec-head h2{font-size:30px}
}

/* ============================================================
   impact/index.blade.php
   Story toggle, impact responsive
   ============================================================ */
.story-body{display:none;margin-top:16px}
.story-body.open{display:block}
.story-toggle{display:inline-flex;align-items:center;gap:8px;font-family:var(--wlsa-font-condensed);font-size:13px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--maroon);cursor:pointer;background:none;border:1.5px solid var(--maroon);padding:10px 20px;margin-top:16px;transition:.2s}
.story-toggle:hover{background:var(--maroon);color:#fff}

@media(max-width:900px){
  .impact-stats-grid{grid-template-columns:1fr 1fr!important}
  .impact-mini-grid{grid-template-columns:1fr 1fr!important}
  .impact-story-grid{grid-template-columns:1fr!important}
  .impact-story-grid img{height:300px!important}
  .impact-videos{grid-template-columns:1fr!important}
  .impact-split{grid-template-columns:1fr!important;gap:36px!important}
}
@media(max-width:600px){
  .impact-stats-grid{grid-template-columns:1fr!important}
  .impact-mini-grid{grid-template-columns:1fr!important}
}

/* ============================================================
   HOME — gallery mosaic hover
   ============================================================ */
.gallery-mosaic a:hover img{transform:scale(1.04);opacity:1}


/* ============================================================
   HOME - extracted from resources/views/welcome.blade.php
   ============================================================ */

/* Homepage Hero */
.hero{
  position:relative;
  min-height:calc(100vh - var(--nav-h));
  height:calc(100vh - var(--nav-h));
  min-height:580px;
  max-height:820px;
  overflow:hidden;
  background:var(--maroon-deep);
}
.hero-slide{
  position:absolute;
  inset:0;
  background-size:cover;
  background-position:center;
  opacity:0;
  transition:opacity 1.2s ease;
  z-index:0;
}
.hero-slide::after{
  content:'';
  position:absolute;
  inset:0;
  background:linear-gradient(110deg,rgba(122,0,0,.9) 0%,rgba(153,31,6,.75) 45%,rgba(34,34,34,.2) 100%);
}
.hero-slide.active{
  opacity:1;
  z-index:1;
}
.hero-content{
  position:relative;
  z-index:2;
  display:flex;
  flex-direction:column;
  justify-content:center;
  height:100%;
  max-width:1200px;
  margin:0 auto;
  padding:0 28px;
}
.hero-tag{
  display:inline-flex;
  align-items:center;
  gap:12px;
  margin-bottom:22px;
  animation:fadeUp .8s ease both;
}
.hero-tag span{
  font-family:var(--wlsa-font-condensed);
  font-size:12px;
  font-weight:700;
  letter-spacing:3px;
  text-transform:uppercase;
  color:var(--gold);
}
.hero-tag::before{
  content:'';
  display:block;
  width:44px;
  height:2px;
  background:var(--gold);
}
.hero-h1{
  font-family:var(--wlsa-font-heading);
  font-size:clamp(38px,6vw,72px);
  font-weight:800;
  line-height:1.07;
  color:var(--white);
  max-width:700px;
  margin-bottom:24px;
  animation:fadeUp .8s .15s ease both;
}
.hero-h1 em{font-style:italic;color:var(--gold-light)}
.hero-p{
  font-family:var(--wlsa-font-body);
  font-size:clamp(15px,1.8vw,18px);
  line-height:1.7;
  color:rgba(255,255,255,.87);
  max-width:540px;
  font-weight:300;
  margin-bottom:38px;
  animation:fadeUp .8s .3s ease both;
}
.hero-btns{
  display:flex;
  gap:16px;
  flex-wrap:wrap;
  animation:fadeUp .8s .45s ease both;
}
.hero-dots{
  position:absolute;
  bottom:32px;
  left:50%;
  transform:translateX(-50%);
  display:flex;
  gap:10px;
  z-index:3;
}
.hero-dot{
  width:8px;
  height:8px;
  background:rgba(255,255,255,.35);
  border-radius:50%;
  cursor:pointer;
  border:none;
  transition:background .3s,transform .3s;
  padding:0;
}
.hero-dot.active,
.hero-dot.on{
  background:var(--gold);
  transform:scale(1.4);
}
.scroll-hint{
  position:absolute;
  bottom:34px;
  right:44px;
  z-index:3;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:6px;
  color:rgba(255,255,255,.45);
  font-family:var(--wlsa-font-condensed);
  font-size:10px;
  letter-spacing:2px;
  text-transform:uppercase;
}
.scroll-line{
  width:1px;
  height:44px;
  background:linear-gradient(to bottom,rgba(255,255,255,.4),transparent);
  animation:pulse 2s ease infinite;
}

@media(max-width:900px){
  .hero{
    min-height:540px;
    height:auto;
  }
  .hero-content{
    padding:0 24px;
  }
  .hero-h1{
    font-size:clamp(34px,7vw,56px);
    max-width:620px;
  }
  .hero-p{
    max-width:520px;
  }
  .scroll-hint{
    right:24px;
  }
}

@media(max-width:600px){
  .hero{
    min-height:520px;
  }
  .hero-content{
    padding:0 18px;
  }
  .hero-tag{
    gap:10px;
    margin-bottom:18px;
  }
  .hero-tag span{
    font-size:11px;
    letter-spacing:2.5px;
  }
  .hero-tag::before{
    width:34px;
  }
  .hero-h1{
    font-size:clamp(32px,11vw,42px);
    max-width:100%;
    margin-bottom:18px;
  }
  .hero-p{
    font-size:16px;
    line-height:1.65;
    margin-bottom:28px;
  }
  .hero-btns{
    gap:12px;
  }
  .hero-dots{
    bottom:22px;
  }
  .scroll-hint{
    right:18px;
    bottom:22px;
    font-size:9px;
    gap:4px;
  }
  .scroll-line{
    height:34px;
  }
}

/* ABOUT SPLIT */
.about{padding:var(--section-lg) 0;background:var(--white)}
.about-grid{display:grid;grid-template-columns:1fr 1fr;align-items:stretch}
.about-img{position:relative;overflow:hidden;min-height:520px}
.about-img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .6s ease}
.about-img:hover img{transform:scale(1.03)}
.about-badge{position:absolute;bottom:32px;left:-16px;background:var(--gold);color:var(--text-dark);padding:20px 28px;box-shadow:4px 4px 0 rgba(0,0,0,.15)}
.about-badge strong{font-family:var(--wlsa-font-heading);font-size:40px;font-weight:800;display:block;line-height:1}
.about-badge span{font-family:var(--wlsa-font-condensed);font-size:12px;font-weight:700;letter-spacing:2px;text-transform:uppercase}
.about-text{padding:44px 44px;display:flex;flex-direction:column;justify-content:center;background:var(--white)}
.about-text h2{font-family:var(--wlsa-font-heading);font-size:clamp(26px,3vw,38px);font-weight:800;line-height:1.2;color:var(--text-dark);margin:14px 0 20px}
.about-text h2 span{color:var(--maroon)}
.about-text>p{font-size:17px;line-height:1.75;color:var(--text-body);margin-bottom:28px}
.pillars{display:flex;flex-direction:column;margin-bottom:32px}
.pillar{display:flex;align-items:flex-start;gap:16px;padding:16px 0;border-bottom:1px solid var(--border)}
.pillar:last-child{border-bottom:none}
.p-icon{width:40px;height:40px;flex-shrink:0;background:var(--gold-bg);border-left:3px solid var(--gold);display:flex;align-items:center;justify-content:center}
.p-icon svg,.p-icon [data-lucide]{width:20px;height:20px;stroke:var(--maroon);fill:none;stroke-width:1.5}
.pillar h4{font-family:var(--wlsa-font-condensed);font-size:14px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;color:var(--maroon);margin-bottom:3px}
.pillar p{font-size:15.5px;color:var(--text-sec);line-height:1.5}


/* THEMATIC CARD ICON HERO */
.t-card-icon-hero{background:linear-gradient(135deg,var(--maroon-deep) 0%,var(--maroon) 100%);padding:52px 28px 40px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;position:relative;min-height:220px;transition:background .3s}
.t-card-num-top{position:absolute;top:14px;left:14px;background:var(--gold);color:var(--text-dark);font-family:var(--wlsa-font-heading);font-size:16px;font-weight:800;width:34px;height:34px;display:flex;align-items:center;justify-content:center}
.t-hero-svg{width:40px;height:40px;stroke:#ffffff;fill:none;stroke-width:1.5;transition:stroke .3s}
.t-hero-label{font-family:var(--wlsa-font-condensed);font-size:13px;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:rgba(255,255,255,.6)}
.t-card:hover .t-card-icon-hero{background:linear-gradient(135deg,#5a0000 0%,var(--maroon-deep) 100%)}
.t-card:hover .t-hero-svg{stroke:#ffffff}

/* THEMATIC */
.thematic{padding:var(--section-lg) 0;background:var(--gold-bg)}
.sec-head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:36px;gap:20px;flex-wrap:wrap}
.sec-head h2{font-family:var(--wlsa-font-heading);font-size:clamp(28px,3.5vw,44px);font-weight:800;line-height:1.15;color:var(--text-dark);margin-top:12px}
.sec-head h2 span{color:var(--maroon)}
.t-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.t-card{background:var(--white);overflow:hidden;border:1px solid var(--border);text-decoration:none;display:block;transition:box-shadow .3s,transform .3s,border-color .3s}
.t-card:hover{box-shadow:0 12px 40px rgba(166,0,0,.12);transform:translateY(-4px);border-color:var(--maroon)}
.t-card-img-wrap{overflow:hidden;position:relative}
.t-card-img{width:100%;height:220px;object-fit:cover;display:block;transition:transform .5s ease}
.t-card:hover .t-card-img{transform:scale(1.05)}
.t-card-num{position:absolute;top:14px;left:14px;background:var(--gold);color:var(--text-dark);font-family:var(--wlsa-font-heading);font-size:16px;font-weight:800;width:34px;height:34px;display:flex;align-items:center;justify-content:center}
.t-card-body{padding:28px 26px 26px}
.t-icon{width:44px;height:44px;background:var(--gold-bg);border:1.5px solid var(--gold-border);display:flex;align-items:center;justify-content:center;margin-bottom:16px}
.t-icon svg,.t-icon [data-lucide]{width:40px;height:40px;stroke:var(--maroon);fill:none;stroke-width:1.8}
.t-card h3{font-family:var(--wlsa-font-heading);font-size:22px;font-weight:700;color:var(--text-dark);margin-bottom:10px;line-height:1.3}
.t-card p{font-size:16px;color:var(--text-sec);line-height:1.65;margin-bottom:18px}
.t-link{display:inline-flex;align-items:center;gap:6px;font-family:var(--wlsa-font-condensed);font-size:12px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--maroon);transition:gap .2s}
.t-link svg{width:14px;height:14px;stroke:var(--maroon);transition:transform .2s}
.t-card:hover .t-link{gap:10px}
.t-card:hover .t-link svg{transform:translateX(3px)}

/* IMPACT — stats only, dark maroon, maximum contrast */
.impact{background:#6e0000;padding:64px 0;position:relative;overflow:hidden}
.impact::before{content:'';position:absolute;inset:0;background:url('/images/wlsa/wlsa-community-paralegal.jpg') center/cover;opacity:.06;pointer-events:none}
.impact .container{position:relative;z-index:1}
.impact-head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:36px;flex-wrap:wrap;gap:16px}
.impact-head-left h2{font-family:var(--wlsa-font-heading);font-size:clamp(28px,3.5vw,46px);font-weight:800;color:#ffffff;margin-top:10px;line-height:1.1}
.impact-head-left h2 em{font-style:italic;color:var(--gold)}
.impact-head p{font-size:16.5px;color:rgba(255,255,255,.7);max-width:340px;line-height:1.65;text-align:right}
.impact-divider{width:100%;height:1px;background:rgba(255,255,255,.15);margin-bottom:36px}
/* stat grid */
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0}
.s-card{padding:44px 36px 40px;border-right:1px solid rgba(255,255,255,.15);position:relative;transition:background .3s}
.s-card:last-child{border-right:none}
.s-card:hover{background:rgba(0,0,0,.15)}
.s-card-top{display:flex;align-items:center;gap:12px;margin-bottom:28px}
/* Icon: white bg so always visible */
.s-card-icon{width:48px;height:48px;background:rgba(255,255,255,.15);border:2px solid rgba(255,255,255,.35);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.s-card-icon svg,.s-card-icon [data-lucide]{width:24px;height:24px;stroke:#ffffff;fill:none;stroke-width:1.5}
.s-card-tag{font-family:var(--wlsa-font-condensed);font-size:10px;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;color:#ffffff;background:rgba(255,255,255,.15);border:1px solid rgba(255,255,255,.3);padding:4px 12px}
/* Number: pure white, huge */
.s-num{font-family:var(--wlsa-font-numbers);font-size:clamp(52px,5.5vw,80px);font-weight:700;color:#ffffff;line-height:1;display:block;margin-bottom:10px;letter-spacing:-0.02em}
/* Label: gold, clear */
.s-label{font-family:var(--wlsa-font-condensed);font-size:13px;font-weight:700;letter-spacing:1.8px;text-transform:uppercase;color:var(--gold);display:block;margin-bottom:12px}
.s-desc{font-size:15.5px;color:rgba(255,255,255,.65);line-height:1.65}
.s-card-bar{position:absolute;bottom:0;left:0;right:0;height:4px;background:var(--gold);transform:scaleX(0);transform-origin:left;transition:transform .5s ease}
.s-card:hover .s-card-bar{transform:scaleX(1)}
/* footer row */
.impact-footer{display:flex;justify-content:space-between;align-items:center;margin-top:36px;padding-top:36px;border-top:1px solid rgba(255,255,255,.15);flex-wrap:wrap;gap:18px}
.impact-mini-stats{display:flex;gap:0;flex-wrap:wrap}
.impact-footer-stat{padding:0 28px;border-right:1px solid rgba(255,255,255,.18)}
.impact-footer-stat:first-child{padding-left:0}
.impact-footer-stat:last-child{border-right:none}
.impact-mini-n{font-family:var(--wlsa-font-numbers);font-size:30px;font-weight:700;color:var(--gold);line-height:1;display:block;letter-spacing:-0.02em}
.impact-mini-l{font-family:var(--wlsa-font-condensed);font-size:11px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:#ffffff;margin-top:4px;display:block}

/* QUOTE */
.quote-sec{padding:64px 0;background:var(--white);position:relative;overflow:hidden}
.quote-bg{position:absolute;right:0;top:0;bottom:0;width:45%;background-image:url('/images/wlsa/wlsa-community-paralegal.jpg');background-size:cover;background-position:center}
.quote-bg::before{content:'';position:absolute;left:0;top:0;bottom:0;width:140px;background:linear-gradient(to right,#fff,transparent)}
.q-inner{position:relative;z-index:1;max-width:580px}
.q-bar{width:52px;height:4px;background:var(--maroon);margin-bottom:28px}
.q-big{font-family:var(--wlsa-font-heading);font-size:clamp(80px,12vw,140px);font-weight:800;line-height:.7;color:var(--gold-bg);position:absolute;top:-10px;left:-20px;pointer-events:none}
.q-text{position:relative;z-index:1;font-family:var(--wlsa-font-heading);font-size:clamp(20px,2.4vw,26px);font-style:italic;font-weight:600;color:var(--text-dark);line-height:1.65;margin-bottom:28px}
.q-attr{display:flex;align-items:center;gap:12px}
.q-attr::before{content:'';display:block;width:28px;height:2px;background:var(--gold);flex-shrink:0}
.q-attr span{font-family:var(--wlsa-font-condensed);font-size:13px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--maroon)}

/* NEWS — 3 equal cards, date badge on photo, author, excerpt, read more */
.news-sec{padding:var(--section-lg) 0;background:var(--white)}
.see-all{display:inline-flex;align-items:center;gap:6px;font-family:var(--wlsa-font-condensed);font-size:13px;font-weight:600;letter-spacing:1px;text-transform:uppercase;color:var(--text-sec);text-decoration:none;transition:color .2s}
.see-all [data-lucide]{width:14px;height:14px;stroke:currentColor;stroke-width:2}
.see-all:hover{color:var(--maroon)}
.news-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.news-slider .nc{flex:0 0 calc(25% - 15px);min-width:calc(25% - 15px)}
.nc{background:var(--white);border:1px solid var(--border);text-decoration:none;display:flex;flex-direction:column;transition:box-shadow .3s,transform .3s}
.nc:hover{box-shadow:0 8px 32px rgba(0,0,0,.1);transform:translateY(-3px)}
/* photo + date badge */
.nc-img-wrap{position:relative;overflow:hidden}
.nc-img{width:100%;height:220px;object-fit:cover;display:block;transition:transform .5s}
.nc:hover .nc-img{transform:scale(1.04)}
.nc-date{position:absolute;bottom:0;right:0;background:var(--maroon);color:#fff;font-family:var(--wlsa-font-condensed);font-weight:700;text-align:center;padding:8px 12px;min-width:52px;line-height:1}
.nc-date-day{font-size:22px;display:block;letter-spacing:-0.5px}
.nc-date-month{font-size:11px;letter-spacing:2px;text-transform:uppercase;opacity:.9}
/* card body */
.nc-body{padding:22px 22px 20px;flex:1;display:flex;flex-direction:column}
.nc-author{display:flex;align-items:center;gap:7px;font-size:13px;color:var(--text-sec);margin-bottom:12px}
.nc-author [data-lucide]{width:15px;height:15px;stroke:var(--text-sec);fill:none;stroke-width:2;flex-shrink:0}
.nc-title{font-family:var(--wlsa-font-heading);font-size:20px;font-weight:700;color:var(--maroon);line-height:1.4;margin-bottom:12px;text-decoration:underline;text-underline-offset:3px;text-decoration-color:transparent;transition:text-decoration-color .2s}
.nc:hover .nc-title{text-decoration-color:var(--maroon)}
.nc-excerpt{font-size:16px;color:var(--text-sec);line-height:1.65;margin-bottom:18px;flex:1}
.nc-read{display:inline-flex;align-items:center;gap:6px;font-family:var(--wlsa-font-condensed);font-size:13px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--maroon);margin-top:auto;border-top:1px solid var(--border);padding-top:16px}
.nc-read [data-lucide]{width:14px;height:14px;stroke:var(--maroon);stroke-width:2.5;fill:none;transition:transform .2s}
.nc:hover .nc-read [data-lucide]{transform:translateX(4px)}

/* LEGAL AID SPLIT */
.legal{padding:var(--section-lg) 0;background:var(--white)}
.legal-grid{display:grid;grid-template-columns:1fr 1fr;align-items:stretch}
.legal-img{position:relative;overflow:hidden;min-height:480px}
.legal-img img{width:100%;height:100%;object-fit:cover;display:block}
.legal-img::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(166,0,0,.45) 0%,rgba(166,0,0,.1) 100%)}
.legal-img-label{position:absolute;bottom:0;left:0;right:0;z-index:2;padding:28px 32px;background:linear-gradient(to top,rgba(60,0,0,.97),rgba(60,0,0,.6) 60%,transparent)}
.legal-img-label h3{font-family:var(--wlsa-font-heading);font-size:22px;font-weight:700;color:#ffffff;margin-bottom:6px}
.legal-img-label p{font-size:13.5px;color:rgba(255,255,255,.9)}
/* Legal text side — darker bg so white pops */
.legal-text{background:#7a0000;padding:60px 56px;display:flex;flex-direction:column;justify-content:center}
.legal-text .eyebrow-w{color:#ffffff;opacity:1}
.legal-text .eyebrow-w::before{background:var(--gold)}
.legal-text h2{font-family:var(--wlsa-font-heading);font-size:clamp(24px,2.8vw,36px);font-weight:800;color:#ffffff;margin:12px 0 16px;line-height:1.2}
.legal-text>p{font-size:17px;color:rgba(255,255,255,.92);line-height:1.75;margin-bottom:36px}
.legal-svcs{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:36px}
.l-svc{background:rgba(255,255,255,.12);border:1.5px solid rgba(255,255,255,.3);padding:18px 16px;display:flex;align-items:center;gap:14px;text-decoration:none;transition:background .2s,border-color .2s}
.l-svc:hover{background:rgba(255,255,255,.22);border-color:var(--gold)}
/* Icon: solid white bg so always visible */
.l-svc-icon{width:40px;height:40px;background:rgba(255,255,255,.18);border:2px solid rgba(255,255,255,.5);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.l-svc-icon svg,.l-svc-icon [data-lucide]{width:22px;height:22px;stroke:#ffffff;fill:none;stroke-width:1.5}
.l-svc span{font-family:var(--wlsa-font-condensed);font-size:13px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:#ffffff;transition:color .2s}
.l-svc:hover span{color:var(--gold)}

/* DONATE */
.donate{padding:64px 0;background:var(--gold-bg);position:relative;overflow:hidden}
.donate-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.donate-left h2{font-family:var(--wlsa-font-heading);font-size:clamp(26px,3.2vw,40px);font-weight:800;line-height:1.2;color:var(--text-dark);margin:12px 0 18px}
.donate-left h2 span{color:var(--maroon)}
.donate-left>p{font-size:17px;line-height:1.75;color:var(--text-body);margin-bottom:32px;max-width:440px}
.d-tiers{display:flex;flex-direction:column}
.d-tier{display:flex;align-items:flex-start;gap:16px;padding:18px 20px;background:var(--white);border-left:4px solid var(--maroon);margin-bottom:2px;transition:border-left-width .2s}
.d-tier:hover{border-left-width:6px}
.d-amt-label{font-family:var(--wlsa-font-numbers);font-size:22px;font-weight:700;color:var(--maroon);white-space:nowrap;min-width:54px;letter-spacing:-0.02em}
.d-desc{font-size:15.5px;color:var(--text-body);line-height:1.55}
/* Donate right — darker so text is legible */
.donate-right{background:#7a0000;padding:48px 44px;position:relative;overflow:hidden}
.donate-right::before{content:'';position:absolute;inset:0;background-image:url('/images/wlsa/mabvuku-empowerment-hub.jpg');background-size:cover;background-position:center;opacity:.08}
.donate-right>*{position:relative;z-index:1}
.donate-right h3{font-family:var(--wlsa-font-heading);font-size:27px;font-weight:700;color:#ffffff;margin-bottom:8px}
.donate-right>p{font-size:14.5px;color:rgba(255,255,255,.88);line-height:1.6;margin-bottom:28px}
.d-amts{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:16px}
.d-btn-amt{background:rgba(255,255,255,.15);border:1.5px solid rgba(255,255,255,.4);color:#ffffff;font-family:var(--wlsa-font-condensed);font-size:18px;font-weight:700;padding:13px 8px;text-align:center;cursor:pointer;transition:background .2s,border-color .2s,color .2s}
.d-btn-amt:hover,.d-btn-amt.on{background:var(--gold);border-color:var(--gold);color:var(--text-dark)}
.d-input{width:100%;padding:13px 16px;margin-bottom:16px;background:rgba(255,255,255,.12);border:1.5px solid rgba(255,255,255,.4);color:#ffffff;font-size:15px;font-family:var(--wlsa-font-body);outline:none}
.d-input::placeholder{color:rgba(255,255,255,.65)}
.d-input:focus{border-color:var(--gold)}
.d-submit{display:block;width:100%;background:var(--gold);color:var(--text-dark);font-family:var(--wlsa-font-condensed);font-size:16px;font-weight:700;letter-spacing:2px;text-transform:uppercase;padding:17px;border:none;cursor:pointer;text-decoration:none;text-align:center;transition:background .2s}
.d-submit:hover{background:var(--gold-light)}
.d-note{font-size:13px;color:rgba(255,255,255,.75);margin-top:12px;text-align:center}
.d-secure{display:flex;align-items:center;justify-content:center;gap:6px;margin-top:8px;font-size:12px;color:rgba(255,255,255,.7);font-family:var(--wlsa-font-condensed);letter-spacing:1px;text-transform:uppercase}
.d-secure [data-lucide]{width:13px;height:13px;stroke:rgba(255,255,255,.8);fill:none;stroke-width:2}

/* PARTNERS */
.partners{padding:44px 0;background:var(--white);border-top:1px solid var(--border)}
.partners-head{display:flex;align-items:center;gap:16px;margin-bottom:32px;justify-content:center}
.partners-head::before,.partners-head::after{content:'';flex:1;height:1px;background:var(--border)}
.partners-head span{font-family:var(--wlsa-font-condensed);font-size:11px;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:var(--text-sec);white-space:nowrap}
.p-scroll{overflow:hidden}
.p-track{display:flex;width:max-content;animation:scrollx 28s linear infinite}
.p-track-static{width:100%;animation:none;justify-content:center}
.p-logo{padding:0 40px;display:flex;align-items:center;justify-content:center;height:68px;border-right:1px solid #eee}
.p-logo img{height:40px;width:auto;max-width:120px;object-fit:contain;opacity:1;transition:.3s}
.p-logo:hover img{filter:none;opacity:1}

/* FOOTER — only dark section */
footer{background:#111;color:rgba(255,255,255,.6)}
.f-main{display:grid;grid-template-columns:1.9fr 1fr 1fr 1.1fr;gap:48px;padding:56px 0 40px}
.f-brand img{height:42px;margin-bottom:18px;display:block}
.f-brand-name{font-family:var(--wlsa-font-heading);font-size:15px;font-weight:700;color:var(--white);margin-bottom:12px}
.f-brand>p{font-size:15px;line-height:1.75;margin-bottom:22px;max-width:280px}
.f-social{display:flex;gap:8px}
.f-social a{width:34px;height:34px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);display:flex;align-items:center;justify-content:center;text-decoration:none;transition:background .2s,border-color .2s}
.f-social a:hover{background:var(--maroon);border-color:var(--maroon)}
.f-social svg{width:14px;height:14px;color:rgba(255,255,255,.7)}
.f-social a:hover svg{color:white}
.f-col h4{font-family:var(--wlsa-font-condensed);font-size:11px;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:var(--gold);margin-bottom:18px}
.f-links{list-style:none}
.f-links li{margin-bottom:9px}
.f-links a{color:rgba(255,255,255,.5);text-decoration:none;font-size:15px;display:flex;align-items:center;gap:7px;transition:color .2s}
.f-links a svg{width:12px;height:12px;stroke:var(--maroon);fill:none;flex-shrink:0}
.f-links a:hover{color:var(--white)}
.f-contact-item{display:flex;gap:10px;margin-bottom:14px;font-size:15.5px;align-items:flex-start}
.f-contact-item svg,.f-contact-item [data-lucide]{width:18px;height:18px;stroke:var(--gold);fill:none;stroke-width:1.5;flex-shrink:0;margin-top:2px}
.f-bottom{border-top:1px solid rgba(255,255,255,.08);padding:20px 0;display:flex;justify-content:space-between;align-items:center;font-size:12px;flex-wrap:wrap;gap:10px}
.f-btm-links{display:flex;gap:20px}
.f-btm-links a{color:rgba(255,255,255,.6);text-decoration:none;transition:color .2s}
.f-btm-links a:hover{color:var(--gold)}

/* MOBILE MENU */
.mob-menu{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:var(--white);z-index:1000;flex-direction:column;padding:24px;overflow-y:auto}
.mob-menu.open{display:flex}
.mob-close{align-self:flex-end;background:none;border:none;cursor:pointer;padding:8px}
.mob-close svg{width:24px;height:24px;stroke:var(--maroon);fill:none}
.mob-links{list-style:none;margin-top:24px}
.mob-links li{border-bottom:1px solid var(--border)}
.mob-links a{display:block;font-family:var(--wlsa-font-condensed);font-size:20px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--text-dark);text-decoration:none;padding:16px 0}
.mob-links .sub{padding-left:20px;font-size:15px;color:var(--text-sec)}
.mob-links a:hover{color:var(--maroon)}

/* ANIMATIONS */
@keyframes fadeUp{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:translateY(0)}}
@keyframes pulse{0%,100%{opacity:.4}50%{opacity:1}}
@keyframes scrollx{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.reveal{opacity:0;transform:translateY(20px);transition:opacity .6s ease,transform .6s ease}
.reveal.in{opacity:1;transform:translateY(0)}

/* RESPONSIVE */
@media(max-width:1024px){
  .t-cards{grid-template-columns:1fr 1fr}
  .stats-grid{grid-template-columns:1fr 1fr}
  .news-cards{grid-template-columns:1fr 1fr}
  .news-slider .nc{flex-basis:calc(50% - 10px);min-width:calc(50% - 10px)}
  .f-main{grid-template-columns:1fr 1fr;gap:36px}
}
@media(max-width:900px){
  .nav-links,.nav-donate{display:none}
  .hamburger{display:block}
  .about-grid,.legal-grid,.donate-grid{grid-template-columns:1fr}
  .about-img{min-height:320px}
  .legal-img{min-height:280px}
  .topbar{display:none}
  .quote-bg{display:none}
  .q-inner{max-width:100%}
  .t-cards{grid-template-columns:1fr}
  .stats-grid{grid-template-columns:1fr 1fr}
  .s-card{border-right:none;border-bottom:1px solid rgba(255,255,255,.12)}
  .impact-head{flex-direction:column;align-items:flex-start}
  .impact-head p{text-align:left}
  .news-cards{grid-template-columns:1fr}
  .responsive-two-col{grid-template-columns:1fr!important;gap:32px!important}
}
@media(max-width:600px){
  .stats-grid{grid-template-columns:1fr}
  .f-main{grid-template-columns:1fr}
  .legal-svcs{grid-template-columns:1fr}
  .about-text{padding:36px 24px}
  .legal-text{padding:40px 28px}
  .impact-footer{flex-direction:column;align-items:flex-start}
  .impact-mini-stats{flex-direction:column;gap:16px}
  .impact-footer-stat{border-right:none;padding:0}
  .news-slider .nc{flex-basis:100%;min-width:100%}
  .responsive-inline-form{flex-direction:column!important}
  .responsive-inline-form input{border-right:1.5px solid var(--gold-border)!important;margin-bottom:10px}
  .responsive-inline-form button{width:100%!important}
}
@media(max-width:768px){
  .q-big{left:0}
  .see-all,
  .nc-read,
  .ev-link,
  .breadcrumb a,
  .f-links a,
  .f-btm-links a{
    min-height:44px;
    display:inline-flex;
    align-items:center;
  }
  .f-social a{width:44px;height:44px}
  .pagination .page-item .page-link{min-width:44px;height:44px}
}
@media(prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  .reveal,.hero-slide,.nc,.nc-img,.t-card,.about-img img{transition:none!important;animation:none!important}
}
@media(max-width:900px){
  .upcoming-events-grid,.publications-grid{grid-template-columns:1fr!important}
}
@media(max-width:600px){
  .upcoming-events-grid,.publications-grid{grid-template-columns:1fr!important}
}

.tb-social .brand-social-icon,
.f-social .brand-social-icon,
a .brand-social-icon{fill:currentColor;stroke:none;color:currentColor}
.tb-social .brand-social-icon *,
.f-social .brand-social-icon *,
a .brand-social-icon *{fill:currentColor;stroke:none}

/* ============================================================
   Deep public resource pages: programmes, reports, legal pages
   ============================================================ */
.responsive-table{
  width:100%;
  overflow-x:auto;
  -webkit-overflow-scrolling:touch;
}
.responsive-table table{min-width:640px}

@media(max-width:1024px){
  .programme-grid,
  .reports-grid,
  .annual-reports-grid,
  .legal-education-grid,
  .resources-grid,
  .content-grid,
  .two-column-layout,
  .sidebar-layout,
  .ar-grid,
  .proj-grid{
    grid-template-columns:repeat(2,minmax(0,1fr))!important;
  }

  .le-split,
  .gj-split,
  .la-split,
  .pub-show{
    gap:36px!important;
  }

  .programme-card,
  .report-card,
  .annual-report-card,
  .legal-card,
  .resource-card,
  .programme-reports-card,
  .financial-report-card{
    width:100%;
    max-width:100%;
    min-width:0;
  }

  .page-title,
  .page-hero-title,
  .section-title,
  .programme-title,
  .report-title,
  .pub-show h1,
  .pub-show h2,
  .pub-show h3{
    overflow-wrap:anywhere;
    word-break:normal;
  }

  .report-actions,
  .download-actions,
  .card-actions{
    display:flex;
    flex-wrap:wrap;
    gap:10px;
  }

  .report-actions a,
  .download-actions a,
  .card-actions a,
  .report-actions button,
  .download-actions button,
  .card-actions button,
  a[href$=".pdf"],
  a[href*=".pdf"],
  a[href*="/storage/"][class*="btn"]{
    min-height:44px;
    align-items:center;
    justify-content:center;
  }
}

@media(max-width:1024px){
  .f-social a{width:44px;height:44px}
  .f-social svg{width:16px;height:16px}
  .f-links a,
  .f-btm-links a,
  .f-contact-item a{min-height:44px;display:inline-flex;align-items:center}
}

@media(max-width:768px){
  .programme-grid,
  .reports-grid,
  .annual-reports-grid,
  .legal-education-grid,
  .resources-grid,
  .content-grid,
  .two-column-layout,
  .sidebar-layout,
  .ar-grid,
  .proj-grid,
  .le-activity,
  .activity-grid,
  .la-activity,
  .le-split,
  .gj-split,
  .la-split,
  .pub-show,
  [style*="grid-template-columns:200px 1fr"],
  [style*="grid-template-columns: 200px 1fr"],
  [style*="grid-template-columns:280px 1fr"],
  [style*="grid-template-columns: 280px 1fr"]{
    grid-template-columns:1fr!important;
  }

  .programme-card,
  .report-card,
  .annual-report-card,
  .legal-card,
  .resource-card,
  .programme-reports-card,
  .financial-report-card,
  .pub-show > *{
    width:100%;
    max-width:100%;
    min-width:0;
  }

  .programme-card img,
  .report-card img,
  .annual-report-card img,
  .legal-card img,
  .resource-card img,
  .pub-show img{
    max-width:100%;
    height:auto;
  }

  .programme-card [style*="height:240px"],
  .report-card [style*="height:220px"],
  .annual-report-card [style*="max-height:220px"]{
    min-height:180px!important;
  }

  .le-gallery,
  .gj-photo-grid,
  .gj-gallery,
  [style*="height:400px"],
  [style*="height:460px"],
  [style*="min-height:520px"]{
    height:auto!important;
    min-height:220px!important;
  }

  [style*="padding:64px 56px"],
  [style*="padding:28px 32px"],
  [style*="padding:28px"],
  [style*="padding:26px"]{
    padding:24px!important;
  }

  [style*="display:flex"][style*="gap:24px"],
  [style*="display:flex"][style*="align-items:flex-start"]{
    flex-direction:column!important;
  }

  [style*="width:80px"][style*="height:80px"],
  [style*="width:60px"][style*="height:60px"]{
    width:64px!important;
    height:64px!important;
  }

  .report-actions,
  .download-actions,
  .card-actions{
    flex-direction:column;
    align-items:stretch;
  }

  .report-actions a,
  .download-actions a,
  .card-actions a,
  .report-actions button,
  .download-actions button,
  .card-actions button,
  a[href$=".pdf"],
  a[href*=".pdf"],
  a[href*="/storage/"][class*="btn"]{
    width:100%;
    min-height:44px;
    text-align:center;
    justify-content:center;
  }

  .page-hero .breadcrumb,
  .breadcrumb{
    max-width:100%;
    overflow-wrap:anywhere;
  }

  .page-hero-title{
    max-width:100%;
    overflow-wrap:anywhere;
  }

  .le-gallery{
    display:block!important;
    height:220px!important;
    min-height:220px!important;
    overflow:hidden;
  }

  .le-gallery > div:first-child,
  .le-gallery > div:first-child img{
    width:100%!important;
    height:100%!important;
  }

  .le-gallery-sub{
    display:none!important;
  }
}

