/* ═══════════════════════════════════════════════
   EVENTS PAGE — events-page.css
   Lionnes Unies en Christ
   Depends on global :root tokens, .btn-*, .section-label,
   .section-title, .reveal already defined in style.css
═══════════════════════════════════════════════ */

/* ── PAGE HERO ── */
.page-hero { height: 68vh; min-height: 480px; display: flex; flex-direction: column; justify-content: flex-end; padding: 0 4rem 5rem; position: relative; overflow: hidden; }
.hero-img { position: absolute; inset: 0; background-image: url('images/evangelisation.jpg'); background-size: cover; background-position: center 25%; z-index: 0; }
.hero-overlay { position: absolute; inset: 0; z-index: 1; background: linear-gradient(105deg, rgba(14,8,35,.93) 0%, rgba(14,8,35,.62) 55%, rgba(14,8,35,.25) 100%); }
.hero-btm { position: absolute; bottom: 0; left: 0; right: 0; height: 200px; z-index: 2; background: linear-gradient(to top, rgba(14,8,35,.82) 0%, transparent 100%); }
.hero-content { position: relative; z-index: 3; }
.hero-eyebrow { font-size: .62rem; font-weight: 500; letter-spacing: .26em; text-transform: uppercase; color: var(--gold); margin-bottom: 1.2rem; display: flex; align-items: center; gap: 1rem; opacity: 0; animation: fadeUp .8s .3s forwards; }
.hero-eyebrow::before { content: ''; display: block; width: 40px; height: 1px; background: var(--gold); }
.hero-title { font-family: 'Playfair Display', serif; font-size: clamp(2.5rem, 5.5vw, 6rem); font-weight: 400; color: var(--white); line-height: 1.06; max-width: 700px; margin-bottom: 1rem; opacity: 0; animation: fadeUp .9s .5s forwards; }
.hero-title em { font-style: italic; color: var(--gold); }
.hero-sub { font-size: .95rem; font-weight: 300; color: rgba(255,255,255,.6); max-width: 460px; line-height: 1.85; opacity: 0; animation: fadeUp .9s .7s forwards; }

/* ── BREADCRUMB ── */
.breadcrumb { background: var(--violet-deep); padding: .85rem 4rem; display: flex; align-items: center; gap: .6rem; border-bottom: 1px solid rgba(232,160,32,.12); }
.breadcrumb a { font-size: .65rem; font-weight: 500; letter-spacing: .12em; text-transform: uppercase; color: rgba(255,255,255,.45); text-decoration: none; transition: color .2s; }
.breadcrumb a:hover { color: var(--gold); }
.breadcrumb-sep { color: rgba(255,255,255,.2); font-size: .6rem; }
.breadcrumb-current { font-size: .65rem; font-weight: 500; letter-spacing: .12em; text-transform: uppercase; color: var(--gold); }

/* ── TICKER ── */
.ticker-wrap { background: var(--gold); overflow: hidden; padding: .82rem 0; }
.ticker-track { display: flex; white-space: nowrap; animation: ticker 30s linear infinite; width: max-content; }
.ticker-track:hover { animation-play-state: paused; }
@keyframes ticker { from { transform: translateX(0) } to { transform: translateX(-50%) } }
.ticker-item { display: inline-flex; align-items: center; gap: 1rem; padding: 0 2.5rem; font-family: 'Playfair Display', serif; font-style: italic; font-size: .9rem; color: var(--violet-deep); }
.ticker-dot { width: 4px; height: 4px; border-radius: 50%; background: rgba(42,29,78,.4); flex-shrink: 0; }

/* ── INTRO ── */
.ev-intro { background: var(--white); padding: 4.5rem 4rem; text-align: center; }
.ev-intro-inner { max-width: 740px; margin: 0 auto; }
.ev-intro-notice { display: inline-flex; align-items: center; gap: .6rem; background: var(--violet-pale); border: 1px solid rgba(61,43,107,.15); border-radius: 2px; padding: .6rem 1.4rem; margin-bottom: 2rem; }
.ev-notice-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--gold); flex-shrink: 0; }
.ev-notice-text { font-size: .72rem; font-weight: 500; color: var(--violet); }
.ev-intro-body { font-size: .95rem; font-weight: 300; color: #666; line-height: 1.95; }

/* ═══════════════════════════════════════
   UPCOMING EVENTS SECTION
═══════════════════════════════════════ */
.ev-upcoming { background: var(--cream); padding: 5rem 4rem 0; }

.ev-upcoming-header { display: flex; flex-direction: column; margin-bottom: 3rem; }
.ev-upcoming-badge { display: inline-flex; align-items: center; gap: .45rem; background: rgba(232,160,32,.12); border: 1px solid rgba(232,160,32,.28); border-radius: 20px; padding: .35rem .9rem; margin-top: 1rem; align-self: flex-start; }
.ev-badge-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--gold); animation: pulse 1.5s infinite; }
.ev-badge-text { font-size: .56rem; font-weight: 600; letter-spacing: .14em; text-transform: uppercase; color: var(--gold); }
@keyframes pulse { 0%,100% { opacity: .5; transform: scale(1) } 50% { opacity: 1; transform: scale(1.3) } }

/* ── CARDS GRID ── */
.ev-cards { display: grid; grid-template-columns: 1fr 1fr; gap: 1.5px; background: rgba(61,43,107,.08); }

/* ── BASE CARD ── */
.ev-card { background: var(--white); display: flex; flex-direction: column; position: relative; overflow: hidden; transition: background .2s; }
.ev-card:hover { background: var(--violet-pale); }

/* Accent bar top */
.ev-card-accent { height: 3px; background: var(--gold); flex-shrink: 0; }
.ev-card-accent--coral  { background: var(--coral); }
.ev-card-accent--violet { background: var(--violet); }

/* ── FLYER IMAGE — sits directly below accent bar ── */
.ev-card-flyer { margin: 0; flex-shrink: 0; overflow: hidden; line-height: 0; }
.ev-card-flyer img {
  width: 100%;
  display: block;
  object-fit: cover;
  object-position: top center;
  transition: transform .5s ease;
}
.ev-card:hover .ev-card-flyer img { transform: scale(1.02); }

/* ── CARD BODY (below flyer) ── */
.ev-card-body { padding: 2rem; flex: 1; display: flex; flex-direction: column; }

/* Tags */
.ev-card-tag { display: inline-block; font-size: .52rem; font-weight: 600; letter-spacing: .16em; text-transform: uppercase; padding: .22rem .65rem; border-radius: 2px; margin-bottom: .75rem; background: rgba(232,160,32,.12); color: #8a6010; }
.ev-card-tag--coral  { background: rgba(212,84,74,.1);  color: #8a2d26; }
.ev-card-tag--violet { background: rgba(61,43,107,.1);  color: var(--violet); }

/* Date */
.ev-card-date { font-family: 'Playfair Display', serif; font-size: 2.2rem; font-weight: 700; color: var(--violet); line-height: 1; }
.ev-card-month { font-size: .58rem; font-weight: 600; letter-spacing: .16em; text-transform: uppercase; color: var(--gold); margin-top: .2rem; margin-bottom: .85rem; }
.ev-card-month--coral  { color: var(--coral); }
.ev-card-month--violet { color: var(--violet-light); }

/* Title / subtitle */
.ev-card-title { font-family: 'Playfair Display', serif; font-size: 1.1rem; font-weight: 500; color: var(--violet); line-height: 1.3; margin-bottom: .5rem; }
.ev-card-subtitle { font-family: 'Playfair Display', serif; font-style: italic; font-size: .84rem; color: var(--coral); margin-bottom: .9rem; }
.ev-card-subtitle--violet { color: var(--violet-light); }

/* Meta */
.ev-card-meta { font-size: .78rem; font-weight: 300; color: #777; line-height: 1.7; margin-bottom: 1rem; flex: 1; display: flex; flex-direction: column; gap: .35rem; }
.ev-meta-row { display: flex; align-items: flex-start; gap: .4rem; }
.ev-icon { flex-shrink: 0; font-style: normal; }

/* Description (wide card only) */
.ev-card-desc { font-size: .85rem; font-weight: 300; color: #666; line-height: 1.85; margin-bottom: 1.5rem; }

/* Footer */
.ev-card-footer { border-top: 1px solid rgba(61,43,107,.08); padding-top: 1.2rem; display: flex; gap: .6rem; flex-wrap: wrap; margin-top: auto; }

/* ── BUTTONS ── */
.ev-btn { font-family: 'Poppins', sans-serif; font-size: .6rem; font-weight: 600; letter-spacing: .1em; text-transform: uppercase; padding: .55rem 1.1rem; border-radius: 2px; cursor: pointer; text-decoration: none; display: inline-flex; align-items: center; gap: .3rem; transition: background .2s, color .2s, border-color .2s; white-space: nowrap; border: none; }
.ev-btn--primary { background: var(--gold);   color: var(--violet-deep); }
.ev-btn--primary:hover { background: var(--gold-light); }
.ev-btn--coral   { background: var(--coral);  color: var(--white); }
.ev-btn--coral:hover   { background: #c04840; }
.ev-btn--violet  { background: var(--violet); color: var(--white); }
.ev-btn--violet:hover  { background: var(--violet-light); }
.ev-btn--outline { background: transparent; color: var(--violet); border: 1.5px solid rgba(61,43,107,.22); }
.ev-btn--outline:hover { background: var(--violet); color: var(--white); border-color: var(--violet); }

/* ── WIDE CARD — Yaoundé 2025 (spans full grid, no flyer yet) ── */
.ev-card--wide { grid-column: 1 / -1; }
.ev-card-body--wide { display: grid; grid-template-columns: 1fr 1fr; gap: 3rem; align-items: start; }
.ev-card-wide-left  { display: flex; flex-direction: column; }
.ev-card-wide-right { display: flex; flex-direction: column; padding-top: 4.5rem; }

/* ── SHARED VENUE STRIP ── */
.ev-venue-strip { background: var(--violet-deep); padding: 2rem 4rem; display: flex; align-items: center; justify-content: space-between; gap: 2rem; border-top: 1px solid rgba(232,160,32,.12); margin-top: 2rem; }
.ev-venue-label    { font-size: .52rem; font-weight: 600; letter-spacing: .2em; text-transform: uppercase; color: rgba(232,160,32,.7); margin-bottom: .3rem; }
.ev-venue-name     { font-family: 'Playfair Display', serif; font-size: 1.1rem; font-weight: 500; color: var(--white); }
.ev-venue-addr     { font-size: .72rem; font-weight: 300; color: rgba(255,255,255,.45); margin-top: .15rem; }
.ev-venue-dates    { text-align: right; flex-shrink: 0; }
.ev-venue-date-num { font-family: 'Playfair Display', serif; font-size: 2rem; font-weight: 700; color: var(--gold); line-height: 1; }
.ev-venue-date-lbl { font-size: .52rem; font-weight: 500; letter-spacing: .14em; text-transform: uppercase; color: rgba(255,255,255,.3); margin-top: .15rem; }

/* ═══════════════════════════════════════
   TIMEZONES
═══════════════════════════════════════ */
.timezones { background: var(--violet-deep); padding: 3rem 4rem; display: grid; grid-template-columns: auto 1fr; gap: 3rem; align-items: center; border-top: 1px solid rgba(232,160,32,.12); border-bottom: 1px solid rgba(232,160,32,.12); }
.tz-label { font-size: .6rem; font-weight: 600; letter-spacing: .22em; text-transform: uppercase; color: var(--gold); margin-bottom: .5rem; }
.tz-note  { font-size: .82rem; font-weight: 300; color: rgba(255,255,255,.5); line-height: 1.6; max-width: 280px; }
.tz-grid  { display: flex; gap: 1rem; flex-wrap: wrap; }
.tz-item  { background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.08); border-radius: 3px; padding: .75rem 1.25rem; min-width: 110px; }
.tz-city  { font-size: .6rem; font-weight: 600; letter-spacing: .14em; text-transform: uppercase; color: rgba(255,255,255,.4); margin-bottom: .25rem; }
.tz-time  { font-family: 'Playfair Display', serif; font-size: 1.1rem; color: var(--white); }

/* ═══════════════════════════════════════
   ONLINE EVENTS INFO
═══════════════════════════════════════ */
.ev-online { background: var(--white); padding: 5rem 4rem; display: grid; grid-template-columns: 1fr 1.5fr; gap: 5rem; align-items: start; border-top: 1px solid rgba(61,43,107,.07); }
.ev-online-card { background: var(--violet); border-radius: 4px; padding: 2.5rem; border: 1px solid rgba(232,160,32,.15); }
.ev-online-card-title { font-family: 'Playfair Display', serif; font-size: 1rem; color: var(--gold); font-weight: 500; margin-bottom: 1.5rem; }
.ev-zoom-row { display: flex; align-items: flex-start; gap: .85rem; padding-bottom: .85rem; margin-bottom: .85rem; border-bottom: 1px solid rgba(255,255,255,.06); }
.ev-zoom-row:last-child { border-bottom: none; padding-bottom: 0; margin-bottom: 0; }
.ev-zoom-label { font-size: .58rem; font-weight: 600; letter-spacing: .15em; text-transform: uppercase; color: var(--gold); flex-shrink: 0; min-width: 72px; margin-top: .1rem; }
.ev-zoom-val { font-size: .82rem; font-weight: 300; color: rgba(255,255,255,.65); line-height: 1.6; }
.ev-zoom-val a { color: var(--gold-light); text-decoration: none; }
.ev-zoom-val a:hover { text-decoration: underline; }

/* ═══════════════════════════════════════
   NEWSLETTER
═══════════════════════════════════════ */
.newsletter { background: var(--white); padding: 5rem 4rem; display: grid; grid-template-columns: 1fr 1fr; gap: 5rem; align-items: center; border-top: 1px solid rgba(61,43,107,.07); }
.newsletter-form { display: flex; flex-direction: column; gap: 1rem; }
.newsletter-input { width: 100%; padding: 1rem 1.25rem; border: 1.5px solid rgba(61,43,107,.14); border-radius: 2px; font-family: 'Poppins', sans-serif; font-size: .85rem; color: #1a1228; background: var(--cream); outline: none; transition: border-color .2s; }
.newsletter-input:focus { border-color: var(--violet); }
.newsletter-input::placeholder { color: #bbb; }
.newsletter-btn { background: var(--violet); color: var(--white); font-family: 'Poppins', sans-serif; font-size: .72rem; font-weight: 600; letter-spacing: .12em; text-transform: uppercase; padding: 1rem 2rem; border: none; border-radius: 2px; cursor: pointer; transition: background .2s; }
.newsletter-btn:hover { background: var(--violet-light); }

/* ═══════════════════════════════════════
   VISION BANNER
═══════════════════════════════════════ */
.vision { background: var(--black); padding: 5rem 4rem; text-align: center; position: relative; overflow: hidden; }
.vision-watermark { position: absolute; left: 50%; top: 50%; transform: translate(-50%,-50%); font-family: 'Playfair Display', serif; font-size: clamp(5rem,14vw,18rem); font-weight: 700; color: rgba(255,255,255,.025); white-space: nowrap; pointer-events: none; user-select: none; }
.vision-lbl   { font-size: .62rem; font-weight: 600; letter-spacing: .24em; text-transform: uppercase; color: var(--gold); margin-bottom: 1.5rem; }
.vision-quote { font-family: 'Playfair Display', serif; font-size: clamp(1.5rem,3vw,3rem); font-weight: 400; color: var(--white); line-height: 1.28; max-width: 780px; margin: 0 auto 1.5rem; }
.vision-quote em { font-style: italic; color: var(--gold); }
.vision-ref { font-size: .68rem; font-weight: 500; letter-spacing: .14em; text-transform: uppercase; color: rgba(255,255,255,.25); margin-bottom: 2.5rem; }

/* ═══════════════════════════════════════
   ANIMATIONS
═══════════════════════════════════════ */
@keyframes fadeUp { from { opacity: 0; transform: translateY(22px) } to { opacity: 1; transform: translateY(0) } }

/* ═══════════════════════════════════════
   RESPONSIVE — Tablet ≤ 1024px
═══════════════════════════════════════ */
@media (max-width: 1024px) {
  .page-hero    { padding: 0 2.5rem 4rem; }
  .breadcrumb   { padding: .85rem 2.5rem; }
  .ev-upcoming  { padding: 4rem 2.5rem 0; }
  .ev-card-body--wide { grid-template-columns: 1fr; gap: 1.5rem; }
  .ev-card-wide-right { padding-top: 0; }
  .ev-venue-strip { padding: 2rem 2.5rem; }
  .timezones    { padding: 2.5rem; grid-template-columns: 1fr; gap: 1.5rem; }
  .ev-online    { padding: 4rem 2.5rem; grid-template-columns: 1fr; gap: 3rem; }
  .newsletter   { padding: 4rem 2.5rem; gap: 3rem; }
  .vision       { padding: 4rem 2.5rem; }
}

/* ── Mobile ≤ 768px ── */
@media (max-width: 768px) {
  .page-hero    { padding: 0 1.5rem 3.5rem; min-height: 55vh; }
  .hero-title   { font-size: clamp(2.4rem, 10vw, 3.8rem); }
  .breadcrumb   { padding: .75rem 1.5rem; }
  .ev-intro     { padding: 3.5rem 1.5rem; }
  .ev-upcoming  { padding: 3rem 1.5rem 0; }
  .ev-cards     { grid-template-columns: 1fr; }
  .ev-card--wide { grid-column: 1; }
  .ev-venue-strip { padding: 1.5rem; flex-direction: column; align-items: flex-start; gap: 1rem; }
  .ev-venue-dates { text-align: left; }
  .timezones    { padding: 2.5rem 1.5rem; }
  .tz-grid      { gap: .6rem; }
  .tz-item      { min-width: 90px; padding: .6rem .9rem; }
  .ev-online    { padding: 3rem 1.5rem; }
  .newsletter   { padding: 3.5rem 1.5rem; grid-template-columns: 1fr; gap: 3rem; }
  .vision       { padding: 3.5rem 1.5rem; }
}

/* ── Small mobile ≤ 480px ── */
@media (max-width: 480px) {
  .hero-title         { font-size: clamp(2rem, 11vw, 3rem); }
  .ev-card-body--wide { gap: 1rem; }
  .ev-card-footer     { flex-direction: column; }
  .ev-btn             { justify-content: center; }
  .vision-quote       { font-size: clamp(1.3rem, 7vw, 2rem); }
}