/**
 * Page Activités — CFA Prince George (scoped .page-activites)
 */

.page-activites{
  --a-bg: #f5f7fb;
  --a-card: #ffffff;
  --a-text: #1a1d24;
  --a-muted: #5c6170;
  --a-border: #e4e6eb;
  --a-radius: 18px;
  --a-radius-sm: 12px;
  --a-shadow: 0 6px 22px rgba(0,0,0,.06);
  --a-shadow-hover: 0 14px 34px rgba(0,0,0,.10);

  --a-blue: #2d4a8a;
  --a-blue-dark: #1e3268;
  --a-accent: #1a9b75;
}

/* Container */
.page-activites .c-container{
  max-width: 1180px;
  margin: 0 auto;
  padding: 0 1.25rem;
}
@media (min-width: 768px){
  .page-activites .c-container{ padding: 0 2rem; }
}

/* HERO */
.page-activites .act-hero{
  position: relative;
  padding: 3.25rem 0 2.2rem;
  color: #fff;
  overflow: hidden;
}
.page-activites .act-hero__bg{
  position:absolute; inset:0;
  background: linear-gradient(145deg, var(--a-blue-dark) 0%, #152a52 50%, #1e3268 100%);
  z-index:0;
}
.page-activites .act-hero__bg::before{
  content:"";
  position:absolute;
  top:-55%;
  right:-15%;
  width:70%;
  height:150%;
  background: radial-gradient(ellipse, rgba(26,155,117,.16) 0%, transparent 70%);
  pointer-events:none;
}
.page-activites .act-hero__inner{ position:relative; z-index:1; }
.page-activites .act-hero__top{
  display:flex;
  justify-content:center;
  margin-bottom: 1.3rem;
}
.page-activites .act-hero__sub{
  color: rgba(255,255,255,.88);
  line-height: 1.6;
  font-size: 1.05rem;
}

/* Buttons */
.page-activites .act-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:.6rem;
  padding: .85rem 1.25rem;
  border-radius: var(--a-radius-sm);
  font-weight: 800;
  text-decoration:none;
  border: 1px solid transparent;
  transition: transform .18s ease, box-shadow .18s ease, background .18s ease, border-color .18s ease;
  cursor:pointer;
}
.page-activites .act-btn--primary{
  background: var(--a-accent);
  color:#fff;
  box-shadow: 0 10px 26px rgba(26,155,117,.35);
}
.page-activites .act-btn--primary:hover{
  transform: translateY(-2px);
  background: #22b88a;
  box-shadow: 0 14px 30px rgba(26,155,117,.45);
}
.page-activites .act-btn--ghost{
  background: rgba(255,255,255,.12);
  border-color: rgba(255,255,255,.25);
  color:#fff;
}
.page-activites .act-btn--ghost:hover{
  background: rgba(255,255,255,.18);
  transform: translateY(-1px);
}

/* Filters */
.page-activites .act-filters{
  display:flex;
  flex-wrap:wrap;
  gap:.75rem;
  justify-content:center;
  align-items:flex-end;
}
.page-activites .act-filter{
  display:flex;
  align-items:center;
  gap:.6rem;
  background: rgba(255,255,255,.10);
  border: 1px solid rgba(255,255,255,.18);
  border-radius: 14px;
  padding: .65rem .75rem;
  backdrop-filter: blur(8px);
}
.page-activites .act-filter__icon{
  color: rgba(255,255,255,.82);
  display:inline-flex;
}
.page-activites .act-filter__label{
  font-size: .82rem;
  font-weight: 800;
  color: rgba(255,255,255,.88);
  margin-right: .2rem;
  white-space: nowrap;
}
.page-activites .act-select,
.page-activites .act-input{
  border: none;
  outline: none;
  background: rgba(255,255,255,.92);
  color: #1a1d24;
  border-radius: 10px;
  padding: .55rem .7rem;
  font-weight: 700;
  font-size: .9rem;
  min-width: 140px;
}
.page-activites .act-filter--search .act-input{
  min-width: 220px;
}
.page-activites .act-filter--sort .act-select{
  min-width: 160px;
}

/* Marquee categories */
.page-activites .act-marqueeWrap{
  background: #fff;
  border-bottom: 1px solid var(--a-border);
}
.page-activites .act-marquee{
  position: relative;
  overflow:hidden;
  padding: 1rem 0;
}
.page-activites .act-marquee__track{
  display:flex;
  align-items:center;
  gap: .75rem;
  width: max-content;
  white-space: nowrap;
  animation: actScroll 22s linear infinite;
}
.page-activites .act-marquee.is-paused .act-marquee__track{
  animation-play-state: paused;
}
@keyframes actScroll{
  0%   { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}
.page-activites .act-chip{
  display:inline-flex;
  align-items:center;
  gap:.55rem;
  padding: .55rem .85rem;
  border-radius: 999px;
  border: 1px solid var(--a-border);
  background: #f3f6fb;
  color: #1a1d24;
  font-weight: 900;
  font-size: .78rem;
  text-transform: uppercase;
  letter-spacing: .06em;
  cursor:pointer;
  transition: transform .15s ease, background .15s ease;
}
.page-activites .act-chip:hover{
  transform: translateY(-1px);
  background: #eaf0fb;
}
.page-activites .act-chip__dot{
  width: 10px; height: 10px;
  border-radius: 999px;
  background: var(--dot, #2d4a8a);
}

/* List */
.page-activites .act-list{
  background: var(--a-bg);
}
.page-activites .act-countRow{
  display:flex;
  justify-content:flex-start;
  margin-bottom: 1rem;
}
.page-activites .act-count{
  margin:0;
  color: var(--a-blue);
  font-weight: 900;
}

/* Cards grid */
.page-activites .act-grid{
  display:grid;
  grid-template-columns: 1fr;
  gap: 1.25rem;
}
@media (min-width: 768px){
  .page-activites .act-grid{
    grid-template-columns: repeat(2, 1fr);
    gap: 1.5rem;
  }
}
@media (min-width: 1200px){
  .page-activites .act-grid{
    grid-template-columns: repeat(3, 1fr);
    gap: 1.5rem;
  }
}

.page-activites .act-card{
  position: relative;
  background: var(--a-card);
  border: 1px solid var(--a-border);
  border-radius: var(--a-radius);
  overflow:hidden;
  box-shadow: var(--a-shadow);
  transition: transform .22s ease, box-shadow .22s ease;
}
.page-activites .act-card:hover{
  transform: translateY(-3px);
  box-shadow: var(--a-shadow-hover);
}

.page-activites .act-card__img{
  position:relative;
  aspect-ratio: 4/3;
  background:#0b1020;
  overflow:hidden;
}
.page-activites .act-card__img img{
  width:100%;
  height:100%;
  object-fit:cover;
  transition: transform .5s ease;
}
.page-activites .act-card:hover .act-card__img img{
  transform: scale(1.06);
}

/* Tag top-left */
.page-activites .act-tag{
  position:absolute;
  left: 14px;
  top: 14px;
  display:flex;
  align-items:center;
  gap:.5rem;
  background: rgba(45,74,138,.92);
  color:#fff;
  padding: .38rem .6rem;
  border-radius: 999px;
  font-size:.72rem;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .06em;
}
.page-activites .act-tag__dot{
  width: 10px; height: 10px;
  border-radius: 999px;
  background: #fff;
}

/* Status bottom-left */
.page-activites .act-status{
  position:absolute;
  left: 14px;
  bottom: 14px;
  padding: .32rem .55rem;
  border-radius: 10px;
  font-size: .75rem;
  font-weight: 900;
  color:#fff;
  text-transform: lowercase;
}
.page-activites .act-status--à-venir{ background: #1a9b75; }
.page-activites .act-status--en-cours{ background: #2d4a8a; }
.page-activites .act-status--passé{ background: #94a3b8; }

/* Badge png top-right */
.page-activites .act-badge{
  position:absolute;
  right: 14px;
  top: 14px;
  width: 34px;
  height: 34px;
  border-radius: 12px;
  background: rgba(255,255,255,.92);
  display:flex;
  align-items:center;
  justify-content:center;
  border: 1px solid rgba(255,255,255,.35);
}
.page-activites .act-badge img{
  width: 22px;
  height: 22px;
  object-fit: contain;
  opacity: .92;
}

/* Body */
.page-activites .act-card__body{
  padding: 1rem 1rem 1.05rem;
}

/* Meta: date / time / location */
.page-activites .act-meta{
  display:flex;
  flex-direction: column;
  gap: .35rem;
  margin-bottom: .75rem;
}
.page-activites .act-meta__item{
  display:flex;
  align-items:center;
  gap:.55rem;
  color: var(--a-muted);
  font-weight: 800;
  font-size: .9rem;
  line-height: 1.25;
}
.page-activites .act-meta__icon{
  color: var(--a-blue);
  display:inline-flex;
}
.page-activites .act-meta__txt{
  overflow:hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* Title */
.page-activites .act-title{
  margin: 0 0 .9rem;
  font-size: 1.08rem;
  font-weight: 950;
  color: var(--a-blue);
  line-height: 1.25;
}
.page-activites .act-title__link{
  color: inherit;
  text-decoration:none;
}
.page-activites .act-title__link:hover{
  text-decoration: underline;
}

/* Actions */
.page-activites .act-actions{
  display:flex;
  gap:.6rem;
  justify-content: space-between;
  align-items:center;
}
.page-activites .act-btnSmall{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding: .55rem .75rem;
  border-radius: 12px;
  font-weight: 900;
  font-size: .85rem;
  border: 1px solid transparent;
  cursor:pointer;
  transition: transform .15s ease, box-shadow .15s ease, background .15s ease;
}
.page-activites .act-btnSmall--outline{
  background: #fff;
  border-color: var(--a-border);
  color: var(--a-blue);
}
.page-activites .act-btnSmall--outline:hover{
  transform: translateY(-1px);
  box-shadow: 0 10px 22px rgba(0,0,0,.08);
}
.page-activites .act-btnSmall--primary{
  background: var(--a-accent);
  color:#fff;
}
.page-activites .act-btnSmall--primary:hover{
  background:#22b88a;
  transform: translateY(-1px);
}

/* Empty state */
.page-activites .act-empty{
  margin-top: 1.25rem;
  padding: 1rem 1rem;
  border-radius: var(--a-radius);
  background:#fff;
  border:1px solid var(--a-border);
  color: var(--a-muted);
  font-weight: 900;
}

/* Focus */
.page-activites a:focus-visible,
.page-activites button:focus-visible,
.page-activites input:focus-visible,
.page-activites select:focus-visible{
  outline: 3px solid rgba(26,155,117,.45);
  outline-offset: 3px;
  border-radius: 12px;
}

@media (prefers-reduced-motion: reduce){
  .page-activites *{ transition:none !important; animation:none !important; }
}