:root{
  --font: "Manrope", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  --radius-xl: 1.5rem;
  --shadow-soft: 0 18px 50px rgba(16,24,40,.12);
}

html, body { font-family: var(--font); }

.fw-extrabold { font-weight: 800; }

.bg-surface{
  background: color-mix(in srgb, var(--bs-body-bg) 92%, var(--bs-primary) 8%);
}

.announcement-bar{
  background: linear-gradient(90deg, #0d6efd, #6f42c1);
  color: #fff;
}

.navbar-glass{
  backdrop-filter: blur(12px);
  background: color-mix(in srgb, var(--bs-body-bg) 80%, transparent);
  border-bottom: 1px solid color-mix(in srgb, var(--bs-border-color) 70%, transparent);
}

.brand-mark{
  width: 14px;
  height: 14px;
  border-radius: 6px;
  background: linear-gradient(135deg, var(--bs-primary), #6f42c1);
  box-shadow: 0 10px 25px rgba(13,110,253,.35);
}

.brand-sub{
  font-size: .85rem;
  opacity: .7;
  margin-left: .25rem;
}

.hero-section{
  position: relative;
  padding: 5rem 0 4rem;
  overflow: hidden;
}

.hero-glow{
  position: absolute;
  inset: -200px -200px auto auto;
  width: 500px;
  height: 500px;
  background: radial-gradient(circle at 30% 30%, rgba(13,110,253,.35), rgba(111,66,193,.18), transparent 60%);
  filter: blur(10px);
  pointer-events: none;
}

.eyebrow{
  display: inline-flex;
  align-items: center;
  gap: .6rem;
  padding: .45rem .75rem;
  border-radius: 999px;
  background: color-mix(in srgb, var(--bs-body-bg) 75%, var(--bs-primary) 25%);
  border: 1px solid color-mix(in srgb, var(--bs-border-color) 70%, transparent);
}

.eyebrow .dot{
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: var(--bs-primary);
}

.text-gradient{
  background: linear-gradient(90deg, var(--bs-primary), #6f42c1);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

.hero-lead{ max-width: 58ch; }

.trust-strip{
  background: color-mix(in srgb, var(--bs-body-bg) 70%, var(--bs-primary) 30%);
  border: 1px solid color-mix(in srgb, var(--bs-border-color) 70%, transparent);
}

.stat-value{
  font-size: 1.35rem;
  font-weight: 800;
  letter-spacing: -0.02em;
}

.stat-label{
  font-size: .78rem;
  color: color-mix(in srgb, var(--bs-body-color) 60%, transparent);
}

.hero-card{
  background: color-mix(in srgb, var(--bs-body-bg) 88%, var(--bs-primary) 12%);
}

.avatar-ring{
  width: 44px;
  height: 44px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  background: linear-gradient(135deg, var(--bs-primary), #6f42c1);
}

.avatar-initials{
  width: 38px;
  height: 38px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  background: color-mix(in srgb, var(--bs-body-bg) 80%, transparent);
  font-weight: 800;
}

.btn-soft{
  background: color-mix(in srgb, var(--bs-primary) 10%, var(--bs-body-bg));
  border: 1px solid color-mix(in srgb, var(--bs-primary) 25%, var(--bs-border-color));
  color: var(--bs-body-color);
}
.btn-soft:hover{ filter: brightness(.98); }

.btn-ghost{
  border: 1px solid color-mix(in srgb, var(--bs-border-color) 70%, transparent);
  background: transparent;
}
.btn-ghost:hover{
  background: color-mix(in srgb, var(--bs-body-bg) 70%, var(--bs-primary) 30%);
}

.social-pill{
  width: 40px;
  height: 40px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  border: 1px solid color-mix(in srgb, var(--bs-border-color) 70%, transparent);
  color: var(--bs-body-color);
  text-decoration: none;
}
.social-pill:hover{
  transform: translateY(-1px);
  box-shadow: var(--shadow-soft);
}

.section-pad{ padding: 5rem 0; }

.section-kicker{
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  font-size: .85rem;
  font-weight: 700;
  color: var(--bs-primary);
  text-transform: uppercase;
  letter-spacing: .12em;
  margin-bottom: .7rem;
}
.section-kicker::before{
  content:"";
  width: 28px;
  height: 2px;
  background: var(--bs-primary);
  border-radius: 99px;
}

.support-badge{
  padding: .55rem .9rem;
  border-radius: 999px;
  background: color-mix(in srgb, var(--bs-body-bg) 85%, var(--bs-primary) 15%);
  border: 1px solid color-mix(in srgb, var(--bs-border-color) 70%, transparent);
  font-size: .85rem;
}

.about-card{
  background: linear-gradient(135deg, var(--bs-primary), #6f42c1);
  color: #fff;
  box-shadow: 0 22px 60px rgba(111,66,193,.25);
}

.timeline{ display: grid; gap: 1rem; }
.t-item{
  display: grid;
  grid-template-columns: 14px 1fr;
  gap: .75rem;
  align-items: start;
}
.t-dot{
  width: 12px;
  height: 12px;
  border-radius: 999px;
  background: rgba(255,255,255,.9);
  margin-top: .35rem;
  box-shadow: 0 0 0 6px rgba(255,255,255,.18);
}

.feature{
  display: flex;
  gap: .8rem;
  padding: 1rem;
  border-radius: var(--radius-xl);
  border: 1px solid color-mix(in srgb, var(--bs-border-color) 70%, transparent);
  background: color-mix(in srgb, var(--bs-body-bg) 92%, var(--bs-primary) 8%);
}
.feature i{ font-size: 1.2rem; color: var(--bs-primary); }

.priority-card{
  background: color-mix(in srgb, var(--bs-body-bg) 92%, var(--bs-primary) 8%);
  box-shadow: var(--shadow-soft);
}
.icon-bubble{
  width: 46px;
  height: 46px;
  border-radius: 16px;
  display: grid;
  place-items: center;
  background: linear-gradient(135deg, var(--bs-primary), #6f42c1);
  color: #fff;
}

.plan-card{
  background: color-mix(in srgb, var(--bs-body-bg) 90%, var(--bs-primary) 10%);
  border: 1px solid color-mix(in srgb, var(--bs-border-color) 70%, transparent);
  box-shadow: var(--shadow-soft);
}

.project-card{
  background: color-mix(in srgb, var(--bs-body-bg) 96%, var(--bs-primary) 4%);
  border: 1px solid color-mix(in srgb, var(--bs-border-color) 70%, transparent);
}
.project-card:hover{
  transform: translateY(-2px);
  box-shadow: var(--shadow-soft);
}

.testimonial-card{
  background: color-mix(in srgb, var(--bs-body-bg) 92%, var(--bs-primary) 8%);
  border: 1px solid color-mix(in srgb, var(--bs-border-color) 70%, transparent);
}

.event-card{
  background: color-mix(in srgb, var(--bs-body-bg) 92%, var(--bs-primary) 8%);
  border: 1px solid color-mix(in srgb, var(--bs-border-color) 70%, transparent);
  box-shadow: var(--shadow-soft);
}
.date-pill{
  width: 60px;
  border-radius: 18px;
  padding: .7rem .6rem;
  text-align: center;
  background: color-mix(in srgb, var(--bs-body-bg) 82%, var(--bs-primary) 18%);
  border: 1px solid color-mix(in srgb, var(--bs-border-color) 70%, transparent);
}

.media-tile{
  border: 1px solid color-mix(in srgb, var(--bs-border-color) 70%, transparent);
  background: color-mix(in srgb, var(--bs-body-bg) 92%, var(--bs-primary) 8%);
}
.media-icon{
  width: 46px;
  height: 46px;
  border-radius: 16px;
  display: grid;
  place-items: center;
  background: color-mix(in srgb, var(--bs-primary) 15%, var(--bs-body-bg));
  border: 1px solid color-mix(in srgb, var(--bs-primary) 25%, var(--bs-border-color));
}

.news-card{
  background: color-mix(in srgb, var(--bs-body-bg) 96%, var(--bs-primary) 4%);
  border: 1px solid color-mix(in srgb, var(--bs-border-color) 70%, transparent);
}

.form-card{
  background: color-mix(in srgb, var(--bs-body-bg) 92%, var(--bs-primary) 8%);
  border: 1px solid color-mix(in srgb, var(--bs-border-color) 70%, transparent);
  box-shadow: var(--shadow-soft);
}

.bg-soft{
  background: color-mix(in srgb, var(--bs-body-bg) 88%, var(--bs-primary) 12%);
  border: 1px solid color-mix(in srgb, var(--bs-border-color) 70%, transparent);
}

.support-card{
  background: linear-gradient(135deg,
    color-mix(in srgb, var(--bs-primary) 15%, var(--bs-body-bg)),
    color-mix(in srgb, #6f42c1 12%, var(--bs-body-bg))
  );
  border: 1px solid color-mix(in srgb, var(--bs-border-color) 70%, transparent);
  box-shadow: var(--shadow-soft);
}

.contact-card{
  background: color-mix(in srgb, var(--bs-body-bg) 92%, var(--bs-primary) 8%);
  border: 1px solid color-mix(in srgb, var(--bs-border-color) 70%, transparent);
}
.contact-icon{
  width: 42px;
  height: 42px;
  border-radius: 16px;
  display: grid;
  place-items: center;
  background: color-mix(in srgb, var(--bs-primary) 15%, var(--bs-body-bg));
  border: 1px solid color-mix(in srgb, var(--bs-primary) 25%, var(--bs-border-color));
}

.chip{
  display: inline-flex;
  gap: .5rem;
  align-items: center;
  padding: .55rem .9rem;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--bs-border-color) 70%, transparent);
  background: color-mix(in srgb, var(--bs-body-bg) 92%, var(--bs-primary) 8%);
  font-size: .9rem;
}

.footer{
  border-top: 1px solid color-mix(in srgb, var(--bs-border-color) 70%, transparent);
}
.footer-link{
  color: color-mix(in srgb, var(--bs-body-color) 70%, transparent);
  text-decoration: none;
}
.footer-link:hover{ color: var(--bs-body-color); text-decoration: underline; }

.back-to-top{
  position: fixed;
  right: 18px;
  bottom: 18px;
  border-radius: 999px;
  width: 46px;
  height: 46px;
  display: grid;
  place-items: center;
  opacity: 0;
  pointer-events: none;
  transform: translateY(10px);
  transition: .2s ease;
}
.back-to-top.show{
  opacity: 1;
  pointer-events: auto;
  transform: translateY(0);
}

/* Motion safety */
@media (prefers-reduced-motion: reduce){
  *{ scroll-behavior: auto !important; transition: none !important; }
}


/* --- HERO PHOTO (candidate image) --- */
.hero-photo{
  position: relative;
  padding: 5.5rem 0 4.5rem;
  overflow: hidden;
}

.candidate-wrap{
  position: relative;
  padding-bottom: 3.5rem;
}

.candidate-frame{
  border-radius: 2.2rem;
  overflow: hidden;
  border: 1px solid color-mix(in srgb, var(--bs-border-color) 70%, transparent);
  background: color-mix(in srgb, var(--bs-body-bg) 90%, var(--bs-primary) 10%);
  box-shadow: 0 25px 70px rgba(16,24,40,.18);
}

.candidate-img{
  width: 100%;
  height: 560px;
  object-fit: cover;
  object-position: center;
  display: block;
  filter: contrast(1.02) saturate(1.02);
}

@media (max-width: 991.98px){
  .candidate-img{ height: 420px; }
}

.candidate-badge{
  position: absolute;
  left: 18px;
  right: 18px;
  bottom: 10px;
  padding: 1rem 1.1rem;
  border-radius: 1.4rem;
  background: color-mix(in srgb, var(--bs-body-bg) 88%, var(--bs-primary) 12%);
  border: 1px solid color-mix(in srgb, var(--bs-border-color) 70%, transparent);
  backdrop-filter: blur(10px);
}

.candidate-float{
  position: absolute;
  top: 18px;
  left: 18px;
  background: color-mix(in srgb, var(--bs-body-bg) 85%, var(--bs-primary) 15%);
}

/* --- MODERN CAROUSEL --- */
.carousel-modern{
  border: 1px solid color-mix(in srgb, var(--bs-border-color) 70%, transparent);
  background: color-mix(in srgb, var(--bs-body-bg) 96%, var(--bs-primary) 4%);
}

.carousel-img{
  height: 520px;
  object-fit: cover;
  filter: contrast(1.02) saturate(1.05);
}

@media (max-width: 991.98px){
  .carousel-img{ height: 360px; }
}

.carousel-caption{
  left: 1.2rem;
  right: 1.2rem;
  bottom: 1.2rem;
}

.caption-card{
  max-width: 520px;
  padding: 1rem 1.1rem;
  border-radius: 1.4rem;
  background: rgba(0,0,0,.55);
  backdrop-filter: blur(10px);
  border: 1px solid rgba(255,255,255,.18);
}

[data-bs-theme="light"] .caption-card{
  background: color-mix(in srgb, var(--bs-body-bg) 60%, rgba(0,0,0,.35));
}

/* --- EVENTS MODERN --- */
.event-modern{
  background: color-mix(in srgb, var(--bs-body-bg) 92%, var(--bs-primary) 8%);
  border: 1px solid color-mix(in srgb, var(--bs-border-color) 70%, transparent);
  box-shadow: 0 18px 50px rgba(16,24,40,.12);
  transition: transform .15s ease, box-shadow .15s ease;
}

.event-modern:hover{
  transform: translateY(-2px);
  box-shadow: 0 25px 70px rgba(16,24,40,.16);
}

.event-date{
  font-weight: 800;
  letter-spacing: -0.02em;
  color: var(--bs-primary);
}

.event-meta{
  display: grid;
  gap: .4rem;
}
