.lfr-layout-structure-item-container {padding: 0;} .lfr-layout-structure-item-row {overflow: hidden;} .portlet-borderless .portlet-content {padding: 0;}/* ============================================================
   HIC — Healthcare Innovation Cycle — 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;
  --gray-100:   #f7f8fa;
  --gray-200:   #edeef2;
  --gray-400:   #9aa0b0;
  --gray-600:   #5a6070;
  --gray-800:   #2e3340;
  --white:      #ffffff;
  --text:       #2e3340;
  --text-light: #5a6070;

  /* Domain colours matching the HIC wheel */
  --domain-clinical:    #1e7a8c;   /* teal   — Clinical / Workflow   */
  --domain-market:      #5a7a2e;   /* olive  — Market / Business      */
  --domain-regulatory:  #1a5560;   /* d-teal — Regulatory             */
  --domain-technical:   #c8703a;   /* orange — Technical / Science    */
}

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

section { scroll-margin-top: 80px; padding: 0.75rem 0; }
section + section { border-top: 1px solid var(--gray-200); }

#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; position: relative; overflow: hidden;
}
.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; }

/* ── Typography ── */
h3 { font-size: 1.35rem; color: var(--navy); font-weight: 600; margin-bottom: .9rem; margin-top: 2rem; }
h3:first-child { margin-top: 0; }
h4 { font-size: 1rem; font-weight: 700; color: var(--navy); margin-bottom: .35rem; margin-top: 0; }
p { margin-bottom: 1rem; line-height: 1.75; }
p:last-child { margin-bottom: 0; }
ul, ol { margin: .8rem 0 1rem 1.5rem; }
li { margin-bottom: .4rem; line-height: 1.6; }
strong { font-weight: 600; color: var(--gray-800); }
a { transition: opacity .2s ease; }

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

/* ── IML step list ── */
.steps { margin: 1.2rem 0; }
.step { display: flex; gap: 1.2rem; margin-bottom: .9rem; align-items: flex-start; }
.step:last-child { margin-bottom: 0; }
.step-num {
  background: var(--teal); color: #fff; font-weight: 700; font-size: .85rem;
  min-width: 32px; height: 32px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center; flex-shrink: 0; margin-top: .15rem;
}
.step-content h4 { margin-top: 0; }
.step-content p  { font-size: .95rem; color: var(--gray-600); margin-bottom: 0; line-height: 1.6; }

/* Domain-coloured circles for the 4-domain section */
.step-num.clinical   { background: var(--domain-clinical); }
.step-num.market     { background: var(--domain-market); }
.step-num.regulatory { background: var(--domain-regulatory); }
.step-num.technical  { background: var(--domain-technical); }

/* ── Video embed ── */
.video-container {
  position: relative; padding-bottom: 56.25%; height: 0;
  overflow: hidden; border-radius: 8px; margin: 1.2rem 0; background: var(--gray-100);
}
.video-container iframe {
  position: absolute; top: 0; left: 0; width: 100%; height: 100%;
  border: none; border-radius: 8px;
}

/* ── Solution type navigation cards ── */
.part-nav-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 1rem; margin-top: 1.2rem;
}
.part-nav-card {
  display: block; background: var(--gray-100); border: 1px solid var(--gray-200);
  border-radius: 10px; padding: 1.2rem; text-decoration: none; color: var(--text);
  transition: background .2s ease, border-color .2s ease;
}
.part-nav-card:hover { background: #fff; border-color: var(--teal); opacity: 1; }
.part-nav-label {
  font-size: 10px; font-weight: 800; letter-spacing: .12em;
  text-transform: uppercase; color: var(--teal); margin-bottom: .4rem;
}
.part-nav-title { font-size: .95rem; font-weight: 700; color: var(--navy); margin-bottom: .3rem; line-height: 1.3; }
.part-nav-desc  { font-size: .82rem; color: var(--gray-600); line-height: 1.5; }

/* ── Sign-in / auth CTA block ── */
.signin-block {
  background: var(--navy); border-radius: 12px;
  padding: 2rem 2.2rem; text-align: center; margin: 2rem 0;
}
.signin-block p { color: rgba(255,255,255,.8); font-size: .975rem; line-height: 1.7; max-width: 580px; margin: 0 auto 1.4rem; }
.signin-btn {
  display: inline-block; background: #fff; color: var(--navy) !important;
  font-weight: 700; font-size: .95rem; padding: .75rem 2rem;
  border-radius: 6px; text-decoration: none; letter-spacing: .02em;
  transition: background .2s ease;
}
.signin-btn:hover { background: #e8f0f8; opacity: 1 !important; }
.signin-note { color: rgba(255,255,255,.55); font-size: .875rem; margin-top: 1rem; margin-bottom: 0; }
.signin-note a { color: rgba(255,255,255,.75); }

/* ── Accordion expand / collapse all controls ── */
.accordion-controls { display: flex; gap: .5rem; justify-content: flex-end; margin: .5rem 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); margin-top: .5rem; }
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; }

/* ── HIC diagram — full-width image in About section ── */
.hic-diagram { margin: 1rem 0 1.5rem; text-align: center; }
.hic-diagram img { width: 50%; max-width: 320px; height: auto; mix-blend-mode: multiply; }

/* ── Responsive ── */
@media (max-width: 760px) {
  section { padding: .4rem 0; }
  .part-nav-grid { grid-template-columns: 1fr 1fr; }
  .two-col-image { flex: 0 0 100%; justify-content: flex-start; }
  .two-col-image img { max-width: 220px; }
}
@media (max-width: 460px) {
  .part-nav-grid { grid-template-columns: 1fr; }
}
