/* ================================================ */
/* OFFICERS PAGE SPECIFIC STYLES                    */
/* Contains styles unique to officers.html.         */
/* ================================================ */

/* -------------------------
   HERO SECTION STYLES
   ------------------------- */
.hero {
  padding: 48px 18px;
  text-align: center;
  display: flex;
  flex-direction: column;
  gap: 18px;
  align-items: center;
  animation: fadeUp 0.7s both;  /* Entry animation */
}

.hero h2 {
  font-size: clamp(1.5rem, 4vw, 2.2rem); /* Responsive font */
  line-height: 1.05;
  letter-spacing: 0.2px;
}

.tagline {
  color: rgba(255,255,255,0.9);
  max-width: 820px;
  margin: 0 auto;
  font-size: clamp(1rem, 2vw, 1.1rem);
}

/* Logo container (for hero section) */
.logo-container {
  position: relative;
  display: inline-block;
}

/* -------------------------
   OFFICERS GRID STYLES
   ------------------------- */

/* ADVISERS SECTION */
.advisers-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 24px;
  margin-top: 20px;
}

.adviser-card {
  display: grid;
  grid-template-columns: 150px 1fr;
  gap: 20px;
  align-items: center;
  padding: 20px;

  border-radius: 12px;
  background: linear-gradient(180deg, rgba(255,255,255,0.01), rgba(255,255,255,0.00));
  border: 1px solid rgba(255,255,255,0.025);
  transition: var(--transition);
}

.adviser-details h4 {
  margin: 0 0 12px 0;
  font-size: 1.2rem;
}

/* ADVISER AVATARS */
.adviser-avatar {
  width: 125px;
  height: 125px;
  border-radius: 12px;
  background: linear-gradient(135deg, var(--neon), var(--accent));
  box-shadow:
    0 0 10px var(--neon),
    0 0 25px var(--accent);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: var(--transition);
  overflow: hidden;
  position: relative;
}

.adviser-avatar .avatar-img-container {
  width: 100%;
  height: 100%;
  border-radius: inherit;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
}

.adviser-avatar .avatar-img-container img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.3s var(--ease);
}

.adviser-avatar:hover .avatar-img-container img {
  transform: scale(1.05);
}

/* General Officers Grid */
.officers-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 16px;
  margin-top: 12px;
}

.officer {
  padding: 14px;
  border-radius: 12px;
  background: linear-gradient(180deg, rgba(255,255,255,0.01), rgba(255,255,255,0.00));
  border: 1px solid rgba(255,255,255,0.025);
  transition: var(--transition);
}

.officer:hover {
  background: linear-gradient(180deg, rgba(255,255,255,0.03), rgba(255,255,255,0.01));
  border-color: rgba(0,191,255,0.15);
}

/* Center a grid item */
.grid-center {
  grid-column: 1 / -1;
  justify-self: center;
  max-width: 330px;
}

.officer h4 {
  margin: 6px 0 4px 0;
  font-size: 1rem;
}

.officer p {
  margin: 0;
  font-size: 0.9rem;
  color: rgba(255,255,255,0.9);
}

/* Representative avatar style */
.rep-avatar {
  background: linear-gradient(135deg, #39ff14, #00ff99);
  box-shadow: 0 0 10px #39ff14, 0 0 25px #00ff99;
}

/* Director avatar style */
.dir-avatar {
  background: linear-gradient(135deg, #bf00ff, #8a2be2);
  box-shadow: 0 0 10px #bf00ff, 0 0 25px #8a2be2;
}

/* -------------------------
   RESPONSIVE DESIGN (Officers Specific)
   ------------------------- */
@media (max-width: 768px) {
  .adviser-card {
    grid-template-columns: 1fr;
  }
  .adviser-avatar {
    width: 120px;
    height: 120px;
    margin: 0 auto 15px;
  }
}

@media (max-width: 480px) {
  .officers-grid {
    grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  }
}