/* Writers portal additions on top of the shared style.css. */
.portal-writers {
  --division-accent: var(--div-writers);
}

/* Division accent touches */
.portal-writers .site-header::before {
  background: linear-gradient(to right, var(--div-writers) 0 14%, var(--brand) 14% 100%);
}
.portal-writers .kicker { color: var(--div-writers); }
.portal-writers .kicker::before { background: var(--div-writers); }

.portal-head { position: relative; overflow: hidden; }

/* Category chip on cards and article heads */
.cat-chip {
  display: inline-block;
  border: 1px solid var(--div-writers);
  color: var(--div-writers);
  border-radius: 99px;
  padding: .05rem .6rem;
  font-size: .68rem;
  letter-spacing: .08em;
  text-transform: uppercase;
  margin-inline-end: .5rem;
}

/* Type filter row */
.type-filter {
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
  border-block-end: 1px solid var(--n-100);
  padding-block-end: var(--space-3);
}
.type-filter a {
  text-decoration: none;
  font-weight: 500;
  font-size: .9rem;
  color: var(--n-700);
  border: 1px solid var(--n-300);
  border-radius: 99px;
  padding: .35rem 1rem;
  min-block-size: 24px;
}
.type-filter a:hover { border-color: var(--div-writers); color: var(--div-writers); }
.type-filter a.current { background: var(--brand); border-color: var(--brand); color: #fff; }

/* Author chip (cards) */
.author-chip {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  text-decoration: none;
  color: var(--n-700);
  font-size: .88rem;
  font-weight: 500;
  margin-block-start: auto;
}
.author-chip:hover { color: var(--brand); }
.author-chip img {
  inline-size: 28px;
  block-size: 28px;
  border-radius: 50%;
  object-fit: cover;
  border: 1px solid var(--blue-100);
}
.chip-initials {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  inline-size: 28px;
  block-size: 28px;
  border-radius: 50%;
  background: var(--blue-050);
  color: var(--brand);
  font-family: var(--font-display);
  font-weight: 600;
  font-size: .72rem;
  border: 1px solid var(--blue-100);
}
.author-chip-lg { gap: .7rem; margin-block-start: var(--space-3); }
.author-chip-lg img, .author-chip-lg .chip-initials { inline-size: 44px; block-size: 44px; font-size: 1rem; }
.author-chip-lg span { display: flex; flex-direction: column; line-height: 1.3; }
.author-chip-lg small { color: var(--color-muted); }

/* Citation box (APA / MLA / Chicago / Harvard) */
.cite-box {
  max-inline-size: 56rem;
  margin-inline: auto;
  margin-block-start: var(--space-5);
  background: var(--blue-050);
  border: 1px solid var(--blue-100);
  border-inline-start: 3px solid var(--brand);
  border-radius: var(--radius);
  padding: var(--space-4);
}
.cite-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  margin-block-end: .8rem;
}
.cite-copy { padding: .4rem .9rem; font-size: .85rem; background: var(--surface); }
.cite-tabs { display: flex; flex-wrap: wrap; gap: .35rem; margin-block-end: .8rem; }
.cite-tabs button {
  font: inherit;
  font-size: .78rem;
  font-weight: 600;
  letter-spacing: .03em;
  padding: .3rem .8rem;
  border: 1px solid var(--n-300);
  border-radius: 99px;
  background: var(--surface);
  color: var(--n-700);
  cursor: pointer;
  min-block-size: 28px;
}
.cite-tabs button:hover { border-color: var(--brand); color: var(--brand); }
.cite-tabs button[aria-selected="true"] { background: var(--brand); border-color: var(--brand); color: #fff; }
.cite-text {
  margin: 0;
  font-family: var(--font-mono);
  font-size: .82rem;
  line-height: 1.7;
  background: var(--surface);
  border: 1px solid var(--n-100);
  border-radius: var(--radius);
  padding: .85rem 1rem;
  word-break: break-word;
}

/* Author box under articles */
.author-box {
  max-inline-size: 56rem;
  display: flex;
  gap: var(--space-4);
  align-items: flex-start;
  background: var(--surface);
  border: 1px solid var(--n-100);
  border-inline-start: 3px solid var(--div-writers);
  border-radius: var(--radius);
  padding: var(--space-4);
  margin-block-start: var(--space-6);
  box-shadow: var(--shadow-1);
}
.author-box img {
  inline-size: 72px;
  block-size: 72px;
  border-radius: 50%;
  object-fit: cover;
  border: 2px solid var(--blue-100);
  flex-shrink: 0;
}
.chip-initials-lg { inline-size: 72px; block-size: 72px; font-size: 1.4rem; flex-shrink: 0; }
.chip-initials-xl { inline-size: 110px; block-size: 110px; font-size: 2rem; flex-shrink: 0; }

/* Author hero (profile page) */
.author-hero {
  display: flex;
  gap: var(--space-5);
  align-items: center;
  flex-wrap: wrap;
}
.author-hero img {
  inline-size: 110px;
  block-size: 110px;
  border-radius: 50%;
  object-fit: cover;
  border: 3px solid var(--blue-100);
}

/* Author cards: centered content so they read as an organized grid. */
.writer-card {
  text-decoration: none;
  color: var(--ink);
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  transition: transform .2s ease, box-shadow .2s ease;
}
.writer-card:hover { transform: translateY(-2px); box-shadow: var(--shadow-2); color: var(--ink); }
.writer-card .board-photo,
.writer-card .board-initials { margin-inline: auto; }
.writer-card .board-role { display: block; }

.card-note {
  background: var(--blue-050);
  border: 1px solid var(--blue-100);
  border-radius: var(--radius);
  padding: var(--space-4);
}

@media (max-width: 54rem) {
  #form { grid-template-columns: 1fr !important; }
}

/* Writers portal footer: responsive (the hub footer media queries do not
   reach this 3-column variant, so define its breakpoints explicitly). */
.footer-writers { grid-template-columns: minmax(0, 5fr) minmax(0, 3fr) minmax(0, 4fr); }
@media (max-width: 60rem) {
  .footer-writers { grid-template-columns: 1fr 1fr; gap: var(--space-5); }
}
@media (max-width: 36rem) {
  .footer-writers { grid-template-columns: 1fr; gap: var(--space-5); }
}
