.lfr-layout-structure-item-container {padding: 0;} .lfr-layout-structure-item-row {overflow: hidden;} .portlet-borderless .portlet-content {padding: 0;}/* ============================================================
   GAITS For Programmes — CSS
   Paste into the Custom CSS panel in Liferay's Advanced tab.
   Shares the same design token palette as HIC, H-BMC, VERITAS,
   and Funding Readiness fragments.
   ============================================================ */

:root {
  --navy:       #1a2744;
  --blue:       #2d5fa3;
  --teal:       #1e7a8c;
  --warm:       #c8703a;
  --gold:       #d4a84b;
  --green:      #2e7d52;
  --light-blue: #e8f0f8;
  --light-teal: #e6f4f6;
  --gray-100:   #f7f8fa;
  --gray-200:   #edeef2;
  --gray-400:   #9aa0b0;
  --gray-600:   #5a6070;
  --gray-800:   #2e3340;
  --white:      #ffffff;
  --text:       #2e3340;
  --text-light: #5a6070;
}

* { box-sizing: border-box; margin: 0; padding: 0; font-family: "Segoe UI", Arial, sans-serif; }
html { scroll-behavior: smooth; }

#fragment-root, .container, .container-wide, nav, .part-header, section, div { color: var(--text); }

/* ── Navigation ── */
nav {
  position: sticky; top: 0; background: var(--navy); z-index: 100;
  padding: 0 2rem; display: flex; align-items: center; overflow-x: auto;
}
nav a {
  color: rgba(255,255,255,.7); text-decoration: none; font-size: 13px;
  font-weight: 600; letter-spacing: .06em; text-transform: uppercase;
  padding: 1rem 1.1rem; white-space: nowrap; transition: opacity .2s ease;
}
nav a:hover { opacity: .7; }
.nav-brand { color: #fff; font-size: 15px; font-weight: 700; padding-right: 2rem; margin-right: .5rem; }
.nav-signin {
  margin-left: auto;
  background: rgba(255,255,255,.15); border: 1px solid rgba(255,255,255,.35);
  color: #fff !important; padding: .45rem 1.2rem !important; border-radius: 4px;
  font-size: 13px !important; font-weight: 700 !important; letter-spacing: .06em;
  text-transform: uppercase; transition: background .2s ease; white-space: nowrap;
}
.nav-signin:hover { background: rgba(255,255,255,.28) !important; opacity: 1 !important; }

/* ── Layout ── */
.container      { max-width: 780px; margin: 0 auto; padding: 0 2rem; }
.container-wide { max-width: 1060px; margin: 0 auto; padding: 0 2rem; }

/* ── Page header banner ── */
.part-header {
  background: var(--gray-100); border-top: 4px solid var(--teal);
  padding: 2.2rem 2rem 2rem; margin-bottom: .5rem;
}
.part-label {
  font-size: 11px; font-weight: 700; letter-spacing: .15em;
  text-transform: uppercase; color: var(--teal); margin-bottom: .6rem;
}
.part-header h2 {
  font-size: clamp(1.6rem, 3vw, 2.2rem); color: var(--navy);
  font-weight: 700; line-height: 1.2; margin-bottom: 1rem;
}
.part-intro { font-size: 1.1rem; color: #3e4450; font-weight: 400; font-style: italic; max-width: 680px; }

/* ── Sections ── */
.cta-section { padding: 1.5rem 0 2.5rem; }

/* ── Section labels ── */
.section-label {
  font-size: 11px; font-weight: 700; letter-spacing: .15em;
  text-transform: uppercase; color: var(--teal); margin-bottom: .4rem;
}

/* ── Accordion expand / collapse controls ── */
.accordion-controls { display: flex; gap: .5rem; justify-content: flex-end; margin: .75rem 0 .25rem; }
.accordion-pill {
  background: transparent; border: 1.5px solid var(--teal); color: var(--teal);
  border-radius: 20px; padding: .25rem .9rem; font-size: .78rem; font-weight: 600;
  letter-spacing: .04em; cursor: pointer; font-family: inherit;
  transition: background .2s ease, color .2s ease;
}
.accordion-pill:hover { background: var(--teal); color: #fff; }

/* ── Accordion (details/summary) ── */
.accordion { border-top: 1px solid var(--gray-200); }
details { border-bottom: 1px solid var(--gray-200); }

summary {
  padding: .7rem 0; cursor: pointer;
  display: flex; align-items: flex-start; gap: 1rem;
  list-style: none; user-select: none;
}
summary::-webkit-details-marker { display: none; }
summary::marker { content: ''; }
summary:hover .summary-title { color: var(--teal); }

.summary-chevron {
  flex-shrink: 0; width: 22px; height: 22px;
  border: 1.5px solid var(--teal); border-radius: 50%;
  color: var(--teal); font-size: 11px; line-height: 1;
  display: flex; align-items: center; justify-content: center;
  margin-top: .3rem; transition: transform .25s ease;
}
details[open] .summary-chevron { transform: rotate(180deg); }

.summary-text { flex: 1; }
.summary-title {
  font-size: 1.05rem; font-weight: 700; color: var(--navy);
  margin-bottom: .25rem; line-height: 1.3; transition: color .15s ease;
}
.summary-overview { font-size: .875rem; color: var(--gray-600); line-height: 1.5; }

.details-body { padding-bottom: 1.1rem; }

/* ── Typography ── */
h3 { font-size: 1.2rem; font-weight: 700; color: var(--navy); line-height: 1.35; margin: .4rem 0 .9rem; }
h4 { font-size: 1rem; font-weight: 700; color: var(--navy); margin-bottom: .35rem; }
p { margin-bottom: 1rem; line-height: 1.75; }
p:last-child { margin-bottom: 0; }
a { transition: opacity .2s ease; }

/* ── Callout box ── */
.quick-read {
  background: #e6f3f5; border-left: 4px solid var(--teal);
  padding: 1.4rem 1.6rem; border-radius: 8px; margin: 1.2rem 0 0;
}
.quick-read-label {
  font-size: 12px; font-weight: 800; letter-spacing: .12em;
  text-transform: uppercase; color: var(--teal); margin-bottom: .6rem;
}
.quick-read p { font-size: .95rem; line-height: 1.65; color: #2d3748; margin-bottom: 0; }

/* ── Capabilities grid ── */
.capabilities-grid {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 1.2rem; margin-top: 1.4rem;
}
.capability-card {
  background: var(--gray-100); border: 1px solid var(--gray-200);
  border-radius: 8px; padding: 1.3rem;
}
.capability-label {
  font-size: 11px; font-weight: 700; letter-spacing: .12em;
  text-transform: uppercase; color: var(--blue); margin-bottom: .4rem;
}
.capability-title { font-size: .95rem; font-weight: 700; color: var(--navy); margin-bottom: .45rem; }
.capability-desc { font-size: .925rem; color: var(--gray-600); line-height: 1.6; margin: 0; }

/* ── Roles step list ── */
.steps { margin: 1.4rem 0 0; }
.step { display: flex; gap: 1.2rem; margin-bottom: 1.1rem; align-items: flex-start; }
.step:last-child { margin-bottom: 0; }
.step-num {
  color: #fff; font-weight: 700; font-size: .78rem; letter-spacing: .04em;
  min-width: 36px; height: 36px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0; margin-top: .1rem;
}
.step-pm     { background: var(--navy); }
.step-mentor { background: var(--teal); }
.step-team   { background: var(--blue); }
.step-content h4 { margin-top: 0; }
.step-content p  { font-size: .95rem; color: var(--gray-600); margin-bottom: 0; line-height: 1.65; }

/* ── Programme names grid ── */
.programme-grid {
  display: flex; flex-wrap: wrap; gap: .75rem; margin-top: 1.4rem;
}
.programme-card {
  background: var(--white); border: 1.5px solid var(--gray-200);
  border-radius: 8px; padding: .6rem 1.1rem;
  font-size: .9rem; font-weight: 600; color: var(--navy);
}

/* ── Contact block (lightweight CTA) ── */
.contact-block {
  background: var(--gray-100); border: 1px solid var(--gray-200);
  border-left: 4px solid var(--teal);
  border-radius: 8px; padding: 1.2rem 1.6rem;
}
.contact-block p { font-size: 1rem; color: var(--gray-800); margin: 0; line-height: 1.7; }
.contact-block a { color: var(--teal); font-weight: 600; text-decoration: none; }
.contact-block a:hover { opacity: .75; }

/* ── Responsive ── */
@media (max-width: 640px) {
  .capabilities-grid { grid-template-columns: 1fr; }
  .programme-grid { gap: .5rem; }
}
