/* ===== Transparent header only (nav stays global) ===== */
.header-transparent .site-header{
  background: transparent !important;
  box-shadow: none !important;
  backdrop-filter: blur(10px);
}
/* Mobile menu styles are now in index.css */

/* ===== HERO: move the dark radial below the header ===== */
.mission-hero{
  padding: 6rem 0 2.25rem;
  text-align: center;
}
.mission-hero h1{
  font-size: clamp(2.25rem, 7vw, 3.25rem);
  letter-spacing: .06em;
  display: inline-block;
  border-bottom: none !important;
}
.mission-hero .lead{
  max-width: 1000px;
  margin: 1.25rem auto 0;
  padding: 1.15rem 1.35rem;
  background: var(--glass-bg);
  backdrop-filter: blur(10px);
  border: 1px solid var(--border-color);
  border-radius: 14px;
  box-shadow: 0 12px 28px rgba(0,0,0,.28);
  color: var(--text);
  font-size: 1.3rem;
  line-height: 1.85;
  text-align: center;
  text-wrap: balance;
}

/* ===== STATS ===== */
.stat-row{ display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:1rem; margin-top:1.1rem; }
.stat{
  background: var(--glass-bg);
  backdrop-filter: blur(10px);
  border: 1px solid var(--border-color);
  border-radius: 14px;
  padding: 1rem 1.1rem;
  transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}
.stat:hover{ transform: translateY(-4px); border-color: rgba(255,255,255,.12); box-shadow: 0 12px 28px rgba(0,0,0,.28); }
.stat-value{ font-size:1.3rem; color:#fff; font-weight:700; }
.stat-label{ color:var(--text-muted); font-size:.92rem; }

/* ===== GENERIC SECTIONS (centered + underline like Team) ===== */
.section{ padding: 2rem 0; }
.section-title{
  font-size: 1.5rem;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: #fff;
  margin: 0 auto 1.6rem;
  text-align: center;
  font-weight: 600;
  display: block;
  width: 100%;
  padding-bottom: .5rem;
  border-bottom: 2px solid rgba(255,255,255,0.1);
}
.section-kicker{
  color: var(--text-muted);
  margin: .5rem auto 1.5rem;
  text-align: center;
  font-size: 1.05rem;
  max-width: 900px;
}

/* ===== PILLARS ===== */
.pillars{ display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:1rem; }
.pillar{
  background: var(--glass-bg);
  backdrop-filter: blur(10px);
  border: 1px solid var(--border-color);
  border-radius: 14px;
  padding: 1.15rem 1.2rem;
  transition: transform .25s ease, border-color .25s ease, box-shadow .25s ease;
  overflow-wrap: break-word;
}
.pillar:hover{ transform: translateY(-4px); border-color: rgba(255,255,255,.12); box-shadow: 0 14px 32px rgba(0,0,0,.28); }
.pillar h3{ color:#fff; margin-bottom:.4rem; }
.pillar p{ word-break: break-word; }

/* ===== MASONRY GALLERY ===== */
.masonry{ display:grid; grid-template-columns:repeat(6,1fr); gap:.6rem; }
.tile{ grid-column: span 2; }
.tile.wide{ grid-column: span 3; }
.tile.tall{ grid-row: span 2; }
.tile img{
  width:100%; height:100%; object-fit:cover; display:block;
  border-radius:14px; border:1px solid var(--border-color);
  background: rgba(255,255,255,0.02);
  filter: grayscale(.35) saturate(.9) contrast(1);
  transition: transform .35s ease, filter .35s ease, border-color .35s ease, box-shadow .35s ease;
}
.tile img:hover{
  filter: grayscale(0) saturate(1.05) contrast(1.05);
  transform: perspective(800px) rotateX(2deg) rotateY(-2.5deg) translateY(-4px);
  border-color: rgba(255,255,255,.14);
  box-shadow: 0 16px 40px rgba(0,0,0,.34);
}
.gallery-note{ color:var(--text-muted); margin-top:.8rem; text-align:center; }

/* ===== ROADMAP ===== */
.roadmap {
  position: relative;
  list-style: none;
  display: grid;
  gap: 1.05rem;
  max-width: 1100px;
  margin: 0 auto;
  padding-inline: 0;
}

.roadmap::before {
  content: "";
  position: absolute;
  left: -12px;
  top: .25rem;
  bottom: .25rem;
  width: 2px;
  background: linear-gradient(to bottom, rgba(255, 255, 255, .25), rgba(255, 255, 255, .08));
  border-radius: 2px;
  opacity: .9;
}

.roadmap li {
  background: var(--glass-bg);
  border: 1px solid var(--border-color);
  border-radius: 12px;
  backdrop-filter: blur(10px);
  padding: 1rem 1.15rem;
  display: grid;
  grid-template-columns: minmax(180px, max-content) 1fr;
  gap: 1.15rem;
  align-items: center;
  overflow: hidden;
  transition: transform .25s ease, border-color .25s ease, box-shadow .25s ease;
}

.roadmap li:hover {
  transform: translateY(-3px);
  border-color: rgba(255, 255, 255, .16);
  box-shadow: 0 16px 34px rgba(0, 0, 0, .30);
}

.roadmap .when {
  font-size: 1.02rem;
  font-weight: 700;
  color: #fff;
  background: rgba(255, 255, 255, .06);
  border: 1px solid rgba(255, 255, 255, .12);
  border-radius: 10px;
  padding: .5rem .7rem;
  line-height: 1.25;
  white-space: normal;
  max-width: 420px;
  display: inline-block;
}

.roadmap .what {
  font-size: 1.05rem;
  line-height: 1.6;
  color: rgba(234, 234, 234, .95);
  overflow-wrap: anywhere;
}

/* ===== CTA BAND ===== */
.cta-row{ display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:1rem; }
.cta-block{
  background: var(--glass-bg); border:1px solid var(--border-color); border-radius:14px;
  backdrop-filter: blur(10px);
  padding:1.25rem 1.35rem; overflow:hidden;
  transition: transform .25s ease, border-color .25s ease, box-shadow .25s ease;
}
.cta-block:hover{ transform:translateY(-4px); border-color:rgba(255,255,255,.12); box-shadow:0 16px 36px rgba(0,0,0,.28); }
.cta-block h3{ color:#fff; margin-bottom:.4rem; }


/* ===== Gallery note card (better contrast) ===== */
.gallery-note{
  max-width: 700px;
  margin: .9rem auto 0;
  padding: .9rem 1.1rem;
  background: var(--glass-bg);
  backdrop-filter: blur(10px);
  border: 1px solid var(--border-color);
  border-radius: 12px;
  box-shadow: 0 10px 24px rgba(0,0,0,.28);
  color: var(--text);
  text-align: center;
  line-height: 1.6;
  font-size: 1.02rem;
}

/* Link legibility inside the note */
.gallery-note a{
  color: #fff;
  font-weight: 600;
  text-decoration: underline;
  text-underline-offset: 2px;
  text-decoration-thickness: 1px;
  transition:
    color .25s ease,
    text-underline-offset .25s ease,
    text-decoration-color .25s ease,
    text-decoration-thickness .25s ease,
    filter .25s ease;
  text-decoration-color: rgba(255,255,255,.7);
}

.gallery-note a:hover{
  text-decoration: none;
  filter: brightness(1.05);
  color: var(--accent);
  text-underline-offset: 4px;
  text-decoration-thickness: 2px;
  text-decoration-color: currentColor;
}

.lab-card {
  background: rgba(255,255,255,0.05); /* very light overlay */
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 10px;
  padding: 1rem;
  transition: transform 0.25s ease, box-shadow 0.25s ease;
}

.lab-card:hover {
  transform: translateY(-4px) scale(1.02);
  box-shadow: 0 8px 16px rgba(0,0,0,0.3);
}

/* keyboard focus = same nice effect */
.gallery-note a:focus-visible{
  outline: none;
  color: var(--accent);
  text-underline-offset: 4px;
  text-decoration-thickness: 2px;
  text-decoration-color: currentColor;
}

/* Respect reduced motion */
@media (prefers-reduced-motion: reduce){
  .gallery-note a{ transition: none; }
}


/* ===== Responsive ===== */
@media (max-width:1024px){
  .pillars{ grid-template-columns:repeat(2,1fr); }
  .masonry{ grid-template-columns:repeat(4,1fr); }
}

@media (max-width: 900px){
  .pillars{ grid-template-columns: 1fr; }
}

@media (max-width:720px){
  .stat-row{ grid-template-columns:1fr; }
  .pillars{ grid-template-columns:1fr; }
  .masonry{ grid-template-columns:repeat(2,1fr); }
  .cta-row{ grid-template-columns:1fr; }
}


/* ===== Horizontal scroller (3-up) ===== */
.lab-scroller{
  position: relative;
  margin-top: .75rem;
}

.lab-track{
  display: grid;
  grid-auto-flow: column;
  gap: 1rem;
  /* 3 items per view: (100% - 2 gaps) / 3 */
  grid-auto-columns: calc((100% - 2rem) / 3);
  overflow-x: auto;
  overscroll-behavior-inline: contain;
  scroll-snap-type: inline mandatory;
  padding: .25rem;                 /* breathing room for focus ring */
  scroll-behavior: smooth;         /* smooth arrows */
}

.lab-item{
  scroll-snap-align: start;
  border-radius: 14px;
  background: var(--glass-bg);
  backdrop-filter: blur(10px);
  border: 1px solid var(--border-color);
  box-shadow: 0 8px 18px rgba(0,0,0,.18);
  overflow: hidden;
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.lab-item:hover{
  transform: translateY(-4px);
  border-color: rgba(255,255,255,.12);
  box-shadow: 0 14px 28px rgba(0,0,0,.26);
}

.lab-item img{
  display: block;
  width: 100%;
  height: 260px;            /* consistent cards */
  object-fit: cover;
  filter: grayscale(.25) saturate(.95);
  transition: filter .25s ease;
}
.lab-item:hover img{ filter: grayscale(0) saturate(1.05) contrast(1.03); }

/* Nav buttons */
.lab-nav{
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  inline-size: 40px;
  block-size: 40px;
  border-radius: 999px;
  border: 1px solid var(--border-color);
  background: rgba(13,17,23,.55);
  color: #fff;
  font-size: 24px;
  line-height: 1;
  display: grid;
  place-items: center;
  cursor: pointer;
  backdrop-filter: blur(6px);
  transition: transform .15s ease, background .2s ease, border-color .2s ease;
  z-index: 1;
}
.lab-nav:hover{
  transform: translateY(-50%) scale(1.05);
  background: rgba(13,17,23,.7);
  border-color: rgba(255,255,255,.2);
}
.lab-prev{ left: -.5rem; }
.lab-next{ right: -.5rem; }

/* Scrollbar (optional, subtle) */
.lab-track::-webkit-scrollbar{ height: 8px; }
.lab-track::-webkit-scrollbar-thumb{
  background: rgba(255,255,255,.15);
  border-radius: 999px;
}
.lab-track{ scrollbar-color: rgba(255,255,255,.15) transparent; scrollbar-width: thin; }

/* Responsive: 2-up on tablets, 1-up on phones */
@media (max-width: 1024px){
  .lab-track{ grid-auto-columns: calc((100% - 1rem) / 2); }
  .lab-item img{ height: 240px; }
}
@media (max-width: 680px){
  .lab-track{ grid-auto-columns: 100%; }
  .lab-item img{ height: 220px; }
  .lab-prev{ left: .25rem; }
  .lab-next{ right: .25rem; }
}

/* ===== Typography bumps for section headings ===== */
.section-title{
  font-size: clamp(1.75rem, 2.6vw, 2.05rem);   /* was 1.5rem */
  letter-spacing: .12em;
}
.section-kicker{
  font-size: clamp(1.05rem, 1.6vw, 1.18rem);   /* was 1.05rem */
  color: rgba(255,255,255,.85);
}

/* Tweak caps on smaller breakpoints */
@media (max-width: 1200px){
  .roadmap .when{ max-width: 360px; }
}
@media (max-width: 1024px){
  .roadmap li{ grid-template-columns: minmax(160px, max-content) 1fr; }
  .roadmap .when{ max-width: 320px; font-size: 1rem; }
  .roadmap .what{ font-size: 1.03rem; }
}

/* ==== Roadmap: mobile-first fixes (stacked cards, centered, no clashes) ==== */

/* Tablet-down: loosen spacing a bit */
@media (max-width: 900px){
  .roadmap{ max-width: 720px; gap: 1rem; padding-left: 0; }
  .roadmap::before{ left: 0.25rem; }
  .roadmap li{
    grid-template-columns: minmax(160px, max-content) 1fr;
    align-items: center;
    padding: .95rem 1rem;
  }
  .roadmap .when{ max-width: 320px; }
}

/* Phone: stack to 1 column, center, hide the spine */
@media (max-width: 720px){
  .roadmap{
    max-width: 640px;
    padding-left: 0;
    padding-inline: 0;      /* prevent side “nudge” */
    gap: .9rem;
  }
  .roadmap::before{ display: none; }  /* remove the vertical line */

  .roadmap li{
    grid-template-columns: 1fr;       /* single column */
    padding: 1rem 1.1rem;             /* comfy touch target */
    gap: .55rem;
  }

  .roadmap .when{
    display: block;
    white-space: normal;               /* allow wrap */
    max-width: none;
    margin: 0 auto .25rem;
    text-align: center;
    padding: .55rem .8rem;
    font-size: clamp(1rem, 3.8vw, 1.1rem);
    line-height: 1.25;
  }

  .roadmap .what{
    text-align: center;
    font-size: clamp(.98rem, 3.6vw, 1.06rem);
    line-height: 1.6;
    overflow-wrap: anywhere;          /* never overflow */
  }
}

/* Very small phones: tighten just a touch */
@media (max-width: 380px){
  .roadmap li{ padding: .9rem .9rem; }
  .roadmap .when{ padding: .45rem .65rem; }
  .roadmap .what{ font-size: .98rem; }
}

/* ===== CTA BAND (Join / Support) ===== */
.cta-band{
  padding: 3rem 0;
  margin-top: 2.5rem;
}

.cta-row{
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1.5rem;
  align-items: stretch;
  max-width: 1000px;
  margin: 0 auto;
}

.cta-block{
  background: rgba(255,255,255,0.08);
  backdrop-filter: blur(10px);
  border: 1px solid rgba(255,255,255,0.15);
  border-radius: 16px;
  padding: 2rem 1.75rem;
  text-align: center;
  box-shadow: 0 14px 28px rgba(0,0,0,.25);
  transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}

.cta-block:hover{
  transform: translateY(-6px);
  border-color: rgba(255,255,255,.25);
  box-shadow: 0 18px 36px rgba(0,0,0,.35);
}

.cta-block h3{
  font-size: 1.4rem;
  font-weight: 700;
  color: #fff;
  margin-bottom: .75rem;
}

.cta-block p{
  color: rgba(235,235,235,.9);
  font-size: 1.05rem;
  margin-bottom: 1.25rem;
}

.cta-block .btn{
  display: inline-block;
  padding: .75rem 1.5rem;
  border-radius: 8px;
  font-weight: 600;
  font-size: 1rem;
  transition: transform .2s ease, background .2s ease;
}

.btn-primary{
  background: #16a34a; /* green */
  color: #fff;
}
.btn-primary:hover{
  background: #22c55e;
  transform: scale(1.05);
}

.btn-secondary{
  background: transparent;
  border: 2px solid #16a34a;
  color: #fff;
}
.btn-secondary:hover{
  background: #16a34a;
  color: #fff;
  transform: scale(1.05);
}

/* Responsive */
@media (max-width: 820px){
  .cta-row{ grid-template-columns: 1fr; }
}

@media (max-width: 480px) {
  .cta-block {
    padding: 1.5rem 1.25rem;
  }

  .cta-block .btn {
    display: block;
    width: 100%;
  }
}