.lfr-layout-structure-item-container {padding: 0;} .lfr-layout-structure-item-row {overflow: hidden;} .portlet-borderless .portlet-content {padding: 0;}/* ============================================================
   GAITS Platform Overview — CSS
   Paste into the Custom CSS panel in Liferay's Advanced tab.
   Shares the same design token palette as 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;
  --light-warm:  #faf0e8;
  --light-green: #e8f5ee;
  --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, .gp-container, nav, .hero, 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;
  justify-content: space-between; 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-links { display: flex; align-items: center; flex: 1; }
.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; }

/* ── Hero ── */
.hero {
  background: linear-gradient(135deg, #1a2744, #2d3d6b, #1a4a5a);
  color: #fff; padding: 5rem 2rem 4rem; text-align: center;
}
.hero-label {
  font-size: 12px; font-weight: 700; letter-spacing: .15em; text-transform: uppercase;
  color: var(--gold); margin-bottom: 1.2rem;
}
.hero h1 {
  font-size: clamp(2rem, 5vw, 3.2rem); font-weight: 700; line-height: 1.2;
  margin-bottom: 1rem; max-width: 800px; margin-left: auto; margin-right: auto;
}
.hero-sub {
  font-size: 1.15rem; color: rgba(255,255,255,.75); max-width: 660px;
  margin: 0 auto 2rem; font-weight: 300; line-height: 1.7;
}
.hero-badges { display: flex; gap: 1rem; justify-content: center; flex-wrap: wrap; }
.hero-badge {
  background: rgba(255,255,255,.1); border: 1px solid rgba(255,255,255,.2);
  color: rgba(255,255,255,.85); padding: .4rem 1rem; border-radius: 2rem;
  font-size: 13px; font-weight: 600; letter-spacing: .04em;
}
.hero-attribution { margin-top: 1.5rem; font-size: .9rem; color: rgba(255,255,255,.6); }
.hero-attribution a { color: rgba(255,255,255,.6); text-decoration: underline; }
.hero-attribution a:hover { color: rgba(255,255,255,.9); opacity: 1; }

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

section { padding: 3rem 2rem; }
section + section { border-top: 1px solid var(--gray-200); }

/* ── Section labels & headings ── */
.section-label {
  font-size: 11px; font-weight: 700; letter-spacing: .15em; text-transform: uppercase;
  color: var(--teal); margin-bottom: .6rem;
}
h2.section-heading {
  font-size: clamp(1.5rem, 3vw, 2rem); font-weight: 700; color: var(--navy);
  line-height: 1.25; margin-bottom: 1.2rem;
}
h3 { font-size: 1.25rem; font-weight: 600; color: var(--navy); margin-bottom: .75rem; margin-top: 2rem; }
h3:first-child { margin-top: 0; }
p { line-height: 1.75; margin-bottom: 1rem; color: var(--gray-800); }
p:last-child { margin-bottom: 0; }

/* ── Journey section — 4 framework cards ── */
.journey-grid {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 0; margin-top: 2rem; border: 1px solid var(--gray-200); border-radius: 10px;
  overflow: hidden;
}
.journey-card {
  padding: 1.6rem 1.4rem; border-right: 1px solid var(--gray-200);
  position: relative; background: var(--white);
}
.journey-card:last-child { border-right: none; }
.journey-card-num {
  font-size: 11px; font-weight: 800; letter-spacing: .12em; text-transform: uppercase;
  margin-bottom: .5rem;
}
.journey-card-title {
  font-size: 1rem; font-weight: 700; color: var(--navy); margin-bottom: .6rem; line-height: 1.3;
}
.journey-card-desc { font-size: .875rem; color: var(--text-light); line-height: 1.6; margin: 0; }
.journey-card-link {
  display: inline-block; margin-top: 1rem; font-size: 12px; font-weight: 700;
  letter-spacing: .04em; text-decoration: none; text-transform: uppercase;
}
.journey-card-link:hover { opacity: .7; }

/* Colour-coded top borders per framework */
.journey-hic   { border-top: 3px solid var(--teal); }
.journey-hic   .journey-card-num { color: var(--teal); }
.journey-hic   .journey-card-link { color: var(--teal); }
.journey-veritas { border-top: 3px solid var(--warm); }
.journey-veritas .journey-card-num { color: var(--warm); }
.journey-veritas .journey-card-link { color: var(--warm); }
.journey-hbmc  { border-top: 3px solid var(--blue); }
.journey-hbmc  .journey-card-num { color: var(--blue); }
.journey-hbmc  .journey-card-link { color: var(--blue); }
.journey-fr    { border-top: 3px solid var(--gold); }
.journey-fr    .journey-card-num { color: var(--warm); }
.journey-fr    .journey-card-link { color: var(--warm); }

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

/* ── Solution types ── */
.solution-grid {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: 1rem; margin-top: 1.5rem;
}
.solution-card {
  background: var(--white); border: 1px solid var(--gray-200);
  border-radius: 8px; padding: 1.2rem 1rem; text-align: center;
  transition: border-color .2s ease, box-shadow .2s ease;
}
.solution-card:hover { border-color: var(--teal); box-shadow: 0 2px 8px rgba(30,122,140,.12); }
.solution-card-title { font-size: .9rem; font-weight: 700; color: var(--navy); margin-bottom: .4rem; }
.solution-card-links { font-size: 12px; }
.solution-card-links a { color: var(--blue); text-decoration: none; font-weight: 600; }
.solution-card-links a:hover { opacity: .7; }
.solution-card-links .sep { color: var(--gray-400); margin: 0 .3rem; }

/* ── Roles section ── */
.roles-grid {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 1.2rem; margin-top: 1.5rem;
}
.role-card {
  border: 1px solid var(--gray-200); border-radius: 10px; padding: 1.6rem;
  background: var(--white);
}
.role-card-icon {
  width: 2.4rem; height: 2.4rem; border-radius: 50%; display: flex;
  align-items: center; justify-content: center; font-size: 1.1rem;
  margin-bottom: 1rem;
}
.role-user    .role-card-icon { background: var(--light-blue); }
.role-mentor  .role-card-icon { background: var(--light-teal); }
.role-pm      .role-card-icon { background: var(--light-warm); }
.role-card-title { font-size: 1.05rem; font-weight: 700; color: var(--navy); margin-bottom: .5rem; }
.role-card-desc { font-size: .875rem; color: var(--text-light); line-height: 1.6; margin: 0 0 1rem; }
.role-card ul { margin: 0; padding-left: 1.2rem; }
.role-card ul li { font-size: .85rem; color: var(--text-light); line-height: 1.6; margin-bottom: .2rem; }
.role-card-link {
  display: inline-block; margin-top: 1rem; font-size: 12px; font-weight: 700;
  letter-spacing: .04em; text-transform: uppercase; text-decoration: none; color: var(--blue);
}
.role-card-link:hover { opacity: .7; }

/* ── Sign-in CTA block ── */
.signin-block {
  background: var(--navy); border-radius: 12px; padding: 2.5rem 2.2rem;
  text-align: center; margin: 2rem 0;
}
.signin-block h3 { color: #fff; font-size: 1.4rem; margin-bottom: .75rem; margin-top: 0; }
.signin-block p { color: rgba(255,255,255,.7); font-size: 1rem; margin-bottom: 1.5rem; }
.signin-btn {
  display: inline-block; background: var(--gold); color: var(--navy) !important;
  font-weight: 700; font-size: 14px; letter-spacing: .06em; text-transform: uppercase;
  padding: .8rem 2rem; border-radius: 6px; text-decoration: none;
  transition: opacity .2s ease;
}
.signin-btn:hover { opacity: .85; }

/* ── Auth hub cards ── */
.hub-intro {
  background: var(--gray-100); border-bottom: 1px solid var(--gray-200);
  padding: 2rem; text-align: center;
}
.hub-intro p { max-width: 640px; margin: 0 auto; font-size: 1.05rem; color: var(--gray-600); }
.hub-grid {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 1.2rem; padding: 2.5rem 2rem;
}
.hub-card {
  border: 1px solid var(--gray-200); border-radius: 10px; padding: 1.6rem;
  background: var(--white); text-decoration: none; color: var(--text);
  transition: border-color .2s ease, box-shadow .2s ease, transform .15s ease;
  display: flex; flex-direction: column;
}
.hub-card:hover {
  border-color: var(--blue); box-shadow: 0 4px 16px rgba(45,95,163,.12);
  transform: translateY(-2px); opacity: 1;
}
.hub-card-tag {
  font-size: 10px; font-weight: 800; letter-spacing: .14em; text-transform: uppercase;
  margin-bottom: .6rem;
}
.hub-card-title { font-size: 1.05rem; font-weight: 700; color: var(--navy); margin-bottom: .5rem; }
.hub-card-desc { font-size: .85rem; color: var(--text-light); line-height: 1.6; margin: 0; flex: 1; }
.hub-card-arrow { font-size: 1.2rem; color: var(--gray-400); margin-top: 1rem; text-align: right; }

.hub-hic      .hub-card-tag { color: var(--teal); }
.hub-hic:hover { border-color: var(--teal); box-shadow: 0 4px 16px rgba(30,122,140,.12); }
.hub-veritas  .hub-card-tag { color: var(--warm); }
.hub-veritas:hover { border-color: var(--warm); box-shadow: 0 4px 16px rgba(200,112,58,.12); }
.hub-hbmc     .hub-card-tag { color: var(--blue); }
.hub-fr       .hub-card-tag { color: var(--warm); }
.hub-guide    .hub-card-tag { color: var(--navy); }
.hub-tracker  .hub-card-tag { color: var(--green); }
.hub-tracker:hover { border-color: var(--green); box-shadow: 0 4px 16px rgba(46,125,82,.12); }

/* ── Guest sign-in prompt ── */
.guest-signin-prompt {
  background: var(--light-teal); border-bottom: 1px solid #c0dfe4; padding: .7rem 2rem; text-align: center;
}
.guest-signin-prompt p { font-size: .925rem; color: #1a5a6a; margin: 0; }
.guest-signin-prompt a { color: var(--teal); font-weight: 700; text-decoration: none; }
.guest-signin-prompt a:hover { opacity: .7; }

/* ── Programmes hub card ── */
.hub-prog .hub-card-tag { color: var(--gold); }
.hub-prog:hover { border-color: var(--gold); box-shadow: 0 4px 16px rgba(212,168,75,.15); }

/* ── Gray banner sections ── */
.section-gray { background: var(--gray-100); }
.section-teal-strip {
  background: linear-gradient(135deg, #1a4a5a, #1e7a8c);
  padding: 2.5rem 2rem; text-align: center;
}
.section-teal-strip .section-label { color: rgba(255,255,255,.6); }
.section-teal-strip h2 { color: #fff; }
.section-teal-strip p { color: rgba(255,255,255,.8); max-width: 680px; margin: 0 auto 1.5rem; }

/* ── Footer ── */
footer {
  background: var(--navy);
  padding: 1.2rem 2rem;
  text-align: center;
}
footer p { color: rgba(255,255,255,.45); font-size: .8rem; margin: 0; line-height: 1.7; }
footer a { color: rgba(255,255,255,.55); text-decoration: none; font-weight: 600; letter-spacing: .03em; }
footer a:hover { color: rgba(255,255,255,.85); }

/* ── Responsive ── */
@media (max-width: 640px) {
  .journey-grid { grid-template-columns: 1fr; }
  .journey-card { border-right: none; border-bottom: 1px solid var(--gray-200); }
  .journey-card:last-child { border-bottom: none; }
  section { padding: 2rem 1rem; }
  .hub-grid { padding: 1.5rem 1rem; }
  .signin-block { padding: 1.8rem 1.2rem; }
}
