/* ==========================================================================
   Yujverse — Internal page styles
   ========================================================================== */

/* ---- Branded page hero ---- */
.page-hero {
  position: relative;
  padding-top: calc(var(--nav-h) + clamp(2.5rem, 1.5rem + 4vw, 5rem));
  padding-bottom: clamp(2rem, 1.2rem + 3vw, 3.5rem);
  text-align: center;
  overflow: hidden;
  background:
    radial-gradient(60% 80% at 50% 0%, var(--gold-soft) 0%, transparent 60%),
    linear-gradient(180deg, #fdf7ec, var(--cream-bg));
}
.page-hero__title { font-size: var(--fs-h1); color: var(--brick); }
.page-hero__sub { max-width: 60ch; margin: 1rem auto 0; color: var(--ink-soft); font-size: var(--fs-lead); }

/* ---- Contact / Volunteer ---- */
.contact__grid, .volunteer__grid {
  display: grid; grid-template-columns: .9fr 1.4fr; gap: clamp(1.5rem, 1rem + 3vw, 4rem); align-items: start;
}
@media (max-width: 860px) { .contact__grid, .volunteer__grid { grid-template-columns: 1fr; } }
.contact__info h2, .volunteer__intro h2 { font-family: var(--font-serif); color: var(--brick); font-size: 1.5rem; margin-bottom: 1.3rem; }
.contact__list { list-style: none; display: flex; flex-direction: column; gap: 1.1rem; }
.contact__list li, .volunteer__ways li { display: flex; gap: .8rem; align-items: flex-start; color: var(--ink-soft); }
.contact__ic {
  flex: none; width: 40px; height: 40px; border-radius: var(--radius-md); display: grid; place-items: center;
  background: color-mix(in srgb, var(--mint) 18%, transparent); color: var(--teal-ink);
}
.contact__list strong { color: var(--ink); }
.contact__note { margin-top: 1.6rem; color: var(--ink-mute); }
.contact__note a { color: var(--brick); font-weight: 600; }
.volunteer__ways { list-style: none; display: flex; flex-direction: column; gap: .9rem; }
.contact__form-wrap {
  background: var(--surface); border: 1px solid var(--line); border-radius: var(--radius-lg);
  padding: clamp(1.5rem, 1rem + 2vw, 2.6rem); box-shadow: var(--shadow-sm);
}

/* ---- Team ---- */
.team__grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--gutter); }
@media (max-width: 1000px) { .team__grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 520px)  { .team__grid { grid-template-columns: 1fr; } }
.team-card { text-align: center; }
.team-card__photo {
  width: 110px; height: 110px; border-radius: 50%; object-fit: cover; object-position: top center;
  margin: 0 auto 1rem; background: var(--cream-warm); border: 3px solid var(--gold-soft);
}
.team-card__photo--ph { display: grid; place-items: center; color: var(--clay); }
.team-card__role { color: var(--accent); font-weight: 600; font-size: .9rem; margin-bottom: .6rem; }

/* ---- Programs (full list) ---- */
.programs__grid--list { grid-template-columns: repeat(3, 1fr); }
@media (max-width: 920px) { .programs__grid--list { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .programs__grid--list { grid-template-columns: 1fr; } }
.program-card--full { display: flex; flex-direction: column; }
.program-card__link { margin-top: auto; padding-top: 1rem; color: var(--brick); font-weight: 700; font-size: .9rem; display: inline-flex; gap: .4rem; }
.program-card__link .btn-arrow { transition: transform var(--dur) var(--ease-out); }
.program-card--full:hover .program-card__link .btn-arrow { transform: translateX(4px); }

/* ---- Gallery masonry ---- */
.masonry { columns: 4 220px; column-gap: 1rem; }
.masonry__item { margin: 0 0 1rem; break-inside: avoid; border-radius: var(--radius-md); overflow: hidden; box-shadow: var(--shadow-sm); }
.masonry__item img { width: 100%; display: block; transition: transform var(--dur-slow) var(--ease-out); }
.masonry__item:hover img { transform: scale(1.04); }

/* ---- News ---- */
.news__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--gutter); }
@media (max-width: 920px) { .news__grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .news__grid { grid-template-columns: 1fr; } }
.news-card { padding: 0; overflow: hidden; }
.news-card__cover { width: 100%; aspect-ratio: 16/10; object-fit: cover; }
.news-card__body { padding: 1.4rem; }
.news-card__date { font-size: .78rem; text-transform: uppercase; letter-spacing: .08em; color: var(--accent); }
.news-empty { text-align: center; max-width: 460px; margin-inline: auto; padding: 2rem 0; }
.news-empty h3 { font-family: var(--font-serif); color: var(--brick); margin: .8rem 0 .4rem; }
.news-empty p { margin-bottom: 1.4rem; }

/* ==========================================================================
   About page
   ========================================================================== */
.about-split { display: grid; grid-template-columns: 1.1fr .9fr; gap: clamp(1.5rem, 1rem + 3vw, 4rem); align-items: center; }
.about-split--reverse { grid-template-columns: .9fr 1.1fr; }
.about-split--reverse .about-split__text { order: 2; }
.about-split--reverse .about-split__media { order: 1; }
@media (max-width: 820px) {
  .about-split, .about-split--reverse { grid-template-columns: 1fr; }
  .about-split--reverse .about-split__text { order: 2; }
  .about-split--reverse .about-split__media { order: 1; }
}
.about-split__text p { color: var(--ink-soft); margin-bottom: 1rem; max-width: 60ch; }
.about-split__text em { font-family: var(--font-serif); font-style: italic; color: var(--brick); }
.about-split__media { position: relative; }
.about-split__media img { width: 100%; aspect-ratio: 4/3; object-fit: cover; border-radius: var(--radius-lg); box-shadow: var(--shadow-md); }
.about-split__chip {
  position: absolute; bottom: -16px; right: -16px; width: 60px; height: 60px; border-radius: 50%;
  background: var(--gold); color: var(--brick); display: grid; place-items: center; box-shadow: var(--shadow-md); border: 4px solid var(--bg);
}

/* Accordion */
.accordion { margin-top: 1.4rem; border: 1px solid var(--line); border-radius: var(--radius-md); background: var(--surface); overflow: hidden; }
.accordion__trigger {
  width: 100%; text-align: left; background: none; border: none; cursor: pointer;
  padding: 1rem 1.2rem; font-family: var(--font-serif); font-size: 1.05rem; color: var(--brick); font-weight: 700;
  display: flex; align-items: center; justify-content: space-between; gap: 1rem;
}
.accordion__trigger--sm { font-size: .92rem; padding: .7rem 1rem; }
.accordion__chev { transition: transform var(--dur) var(--ease-out); color: var(--clay); }
.accordion.is-open .accordion__chev { transform: rotate(180deg); }
.accordion__panel { max-height: 0; overflow: hidden; transition: max-height var(--dur-slow) var(--ease-out); }
.accordion__inner { padding: 0 1.2rem 1.2rem; color: var(--ink-soft); }
.accordion__inner p { margin-bottom: .8rem; }

/* Founder block */
.founder-head { text-align: center; margin-bottom: clamp(1.5rem, 1rem + 2vw, 2.5rem); }
.founder-head h2 { color: var(--brick); }
.dotted-rule { width: 180px; height: 0; margin: 1rem auto 0; border-bottom: 3px dotted var(--clay); }
.founder-block__quote { font-family: var(--font-serif); font-size: 1.2rem; line-height: 1.55; color: var(--ink); margin: 1.4rem 0 1rem; }
.founder-block__quote .founder__qmark { color: var(--clay); display: block; margin-bottom: .3rem; }
.founder-block__photo { aspect-ratio: 3/4 !important; object-position: top center; }

/* Vision / Mission / Core Values panels (bold) */
.vmv-panels { display: grid; grid-template-columns: 1fr 1fr; }
.vmv-panel { color: var(--on-dark); }
.vmv-panel__inner { padding: clamp(2rem, 1.4rem + 3vw, 4rem); max-width: 620px; margin-inline: auto; }
.vmv-panel__icon { display: inline-grid; place-items: center; width: 56px; height: 56px; border-radius: 50%; background: rgba(255,255,255,.16); margin-bottom: 1rem; }
.vmv-panel h3 { color: #fff; font-family: var(--font-display); font-size: clamp(1.6rem, 1.2rem + 1.5vw, 2.2rem); margin-bottom: .8rem; }
.vmv-panel p { color: rgba(255,255,255,.92); max-width: 52ch; }
.vmv-panel--vision  { background: linear-gradient(150deg, var(--teal-deep), var(--teal-ink)); }
.vmv-panel--mission { background: linear-gradient(150deg, var(--terracotta), #b06a3e); }
.vmv-panel--values  { background: linear-gradient(150deg, var(--brick), var(--brick-deep)); grid-column: 1 / -1; }
.vmv-panel--values .vmv-panel__inner { max-width: var(--container); }
.vmv-panel__values { list-style: none; display: grid; grid-template-columns: 1fr 1fr; gap: 1rem 2rem; margin-top: .5rem; }
.vmv-panel__values li { display: flex; gap: .7rem; align-items: flex-start; color: rgba(255,255,255,.92); }
.vmv-panel__values strong { color: var(--gold); }
.vmv-panel__vicon { flex: none; color: var(--gold); margin-top: 2px; }
@media (max-width: 760px) { .vmv-panels { grid-template-columns: 1fr; } .vmv-panel__values { grid-template-columns: 1fr; } }

/* People (trustees / team) — circular avatars + accordion */
.people__grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: clamp(1.5rem, 1rem + 2vw, 2.5rem); }
@media (max-width: 1000px) { .people__grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 520px)  { .people__grid { grid-template-columns: 1fr; max-width: 320px; margin-inline: auto; } }
.member { text-align: center; }
.member__avatar {
  width: 150px; height: 150px; border-radius: 50%; margin: 0 auto 1rem; overflow: hidden;
  border: 4px solid var(--gold); box-shadow: var(--shadow-sm); background: var(--cream-warm);
  display: grid; place-items: center;
}
.member__avatar img { width: 100%; height: 100%; object-fit: cover; }
.member__initial { font-family: var(--font-display); font-size: 3rem; color: var(--clay); }
.member__name { font-family: var(--font-serif); color: var(--accent); font-size: 1.2rem; }
.member__role { color: var(--ink-mute); font-size: .9rem; margin-bottom: .8rem; }
.member__acc { text-align: left; }
.member__social { margin-top: .6rem; }
.member__social a { display: inline-flex; align-items: center; gap: .3rem; color: var(--brick); font-weight: 600; font-size: .85rem; }

/* Guru */
.guru__photo { aspect-ratio: 1/1 !important; object-fit: cover; }

/* ==========================================================================
   Gallery page — filter, masonry hover, lightbox
   ========================================================================== */
.gallery-filter { display: flex; flex-wrap: wrap; gap: .5rem; justify-content: center; margin-bottom: 2rem; }
.gallery-filter__btn {
  padding: .5rem 1.1rem; border-radius: var(--radius-full); border: 1.5px solid var(--line);
  background: var(--surface); color: var(--ink-soft); font-weight: 600; font-size: .9rem; cursor: pointer;
  transition: all var(--dur) var(--ease-out);
}
.gallery-filter__btn:hover { border-color: var(--brick); color: var(--brick); }
.gallery-filter__btn.is-active { background: var(--brick); color: var(--cream); border-color: var(--brick); }

.gallery-page .masonry { columns: 4 240px; column-gap: 1.1rem; }
.gallery-page .masonry__item { position: relative; margin: 0 0 1.1rem; break-inside: avoid; border-radius: var(--radius-md); overflow: hidden; box-shadow: var(--shadow-sm); }
.gallery-page .masonry__item a { display: block; position: relative; }
.masonry__zoom {
  position: absolute; inset: 0; display: grid; place-items: center; color: var(--cream);
  background: linear-gradient(0deg, rgba(32,18,12,.45), rgba(32,18,12,.1));
  opacity: 0; transition: opacity var(--dur) var(--ease-out);
}
.gallery-page .masonry__item:hover .masonry__zoom { opacity: 1; }
.gallery-page .masonry__item:hover img { transform: scale(1.05); }
.gallery-page .masonry__item img { transition: transform var(--dur-slow) var(--ease-out); }

/* Lightbox */
.lightbox {
  position: fixed; inset: 0; z-index: var(--z-toast); display: none;
  align-items: center; justify-content: center; padding: 4vh 5vw;
  background: rgba(20,10,6,.92); backdrop-filter: blur(6px);
}
.lightbox.is-open { display: flex; }
.lightbox__img { max-width: 100%; max-height: 90vh; object-fit: contain; border-radius: var(--radius-md); box-shadow: var(--shadow-lg); }
.lightbox__close, .lightbox__nav {
  position: absolute; background: rgba(255,255,255,.1); color: var(--cream); border: none; cursor: pointer;
  width: 52px; height: 52px; border-radius: 50%; font-size: 2rem; line-height: 1; display: grid; place-items: center;
  transition: background var(--dur) var(--ease-out);
}
.lightbox__close:hover, .lightbox__nav:hover { background: var(--brick); }
.lightbox__close { top: 3vh; right: 4vw; font-size: 1.8rem; }
.lightbox__nav--prev { left: 2vw; }
.lightbox__nav--next { right: 2vw; }
.lightbox__counter { position: absolute; bottom: 3vh; left: 50%; transform: translateX(-50%); color: var(--on-dark-mute); font-size: .9rem; letter-spacing: .1em; }
@media (max-width: 640px) { .lightbox__nav { width: 42px; height: 42px; font-size: 1.5rem; } .lightbox__nav--prev { left: 1vw; } .lightbox__nav--next { right: 1vw; } }

/* ==========================================================================
   Community page
   ========================================================================== */
.join-card { position: relative; display: flex; flex-direction: column; padding-top: 2.6rem; }
.join-card .value-num { position: absolute; top: 1.1rem; left: 1.4rem; font-family: var(--font-display); font-size: 1.6rem; color: var(--clay); }
.join-card .card__text { flex: 1; }
.join-card__actions { display: flex; flex-direction: column; gap: .7rem; margin-top: 1.2rem; }
.join-news { display: flex; gap: .4rem; }
.join-news input { flex: 1; min-width: 0; padding: .55rem .8rem; border: 1.5px solid var(--line); border-radius: var(--radius-full); background: var(--surface); }
.join-news input:focus { outline: none; border-color: var(--accent); }

.belonging { list-style: none; padding: 0; margin: 2rem auto 0; max-width: 60ch; display: grid; gap: 1rem; }
.belonging li {
  position: relative; padding-left: 2rem; color: var(--ink-soft);
  font-family: var(--font-serif); font-size: clamp(1.05rem, .95rem + .5vw, 1.25rem); line-height: 1.6;
}
.belonging li::before {
  content: ""; position: absolute; left: 0; top: .55em; width: 9px; height: 9px; border-radius: 50%;
  background: var(--bindi); box-shadow: 0 0 0 4px color-mix(in srgb, var(--bindi) 14%, transparent);
}
