/* Editorial content pages matching the homepage rhythm: dark hero, cream
   content blocks, Bebas display, accent rules. Scoped under .ips. Drives the
   About page plus the Advisory Council and Readiness pages (advisor-* / prose
   primitives below). Reuses .eyebrow / .ips-btn / em helpers from
   ips-design-system.css. The About script hooks (.video-card[data-video-id],
   #videoModal, .timeline .step, .marker, .tabs .tab[data-tab], [data-panel],
   #scrollTimeline, #timelineSection) are preserved. */

.ips.about { background: var(--ips-cream); }

/* keyword: editorial accent-underline, replaces the old blue chip */
.ips.about .keyword { font-weight: 600; color: inherit; border-bottom: 1px solid var(--ips-accent); white-space: nowrap; }

/* ---- hero (dark) ---- */
.about-hero { background: var(--ips-hero); color: var(--ips-cream); padding: 60px 56px 56px; }
.about-hero h1 { font-family: 'Bebas Neue', sans-serif; font-size: clamp(40px, 6.4vw, 84px); line-height: .95; letter-spacing: .005em; margin: 20px 0 0; max-width: 16ch; }
.about-hero h1 em { font-style: normal; color: var(--ips-accent-bright); }
.about-hero .lead { margin-top: 24px; max-width: 680px; font-size: 15px; line-height: 1.75; color: #cfd4da; }
.about-hero .lead .keyword { color: var(--ips-cream); border-bottom-color: var(--ips-accent-bright); }
.about-hero .cta-row { display: flex; gap: 14px; margin-top: 30px; flex-wrap: wrap; align-items: center; }

.about-hero-grid { display: grid; grid-template-columns: 320px minmax(0, 540px); gap: 44px; margin-top: 48px; align-items: start; justify-content: start; }

/* quick facts (left) */
.about-facts { border-top: 1px solid rgba(245,234,208,.2); padding-top: 22px; }
.about-facts h4 { font-family: 'Bebas Neue', sans-serif; font-size: 22px; letter-spacing: .02em; margin: 0 0 14px; color: var(--ips-cream); }
.about-facts p { font-size: 13px; line-height: 1.65; color: #cfd4da; margin: 10px 0; }
.about-facts details { margin-top: 12px; }
.about-facts summary { cursor: pointer; color: var(--ips-accent-bright); font-size: 10.5px; letter-spacing: .18em; text-transform: uppercase; font-weight: 600; padding: 8px 0; list-style: none; }
.about-facts summary::-webkit-details-marker { display: none; }
.about-facts details ul { margin: 8px 0 0 0; padding: 0; list-style: none; }
.about-facts details li { position: relative; padding: 7px 0 7px 20px; font-size: 12.5px; line-height: 1.5; color: #cfd4da; border-top: 1px solid var(--ips-line); }
.about-facts details li::before { content: ""; position: absolute; left: 0; top: 15px; width: 9px; height: 1px; background: var(--ips-accent-bright); }

/* video (right) */
.about-video { background: var(--ips-hero-2); border: 1px solid var(--ips-line); max-width: 540px; width: 100%; }
.about-video .vhead { font-family: var(--font-mono); font-size: 10px; letter-spacing: .18em; text-transform: uppercase; color: #a8b0bb; padding: 12px 14px; border-bottom: 1px solid var(--ips-line); }
.about-video .video-card { display: block; cursor: pointer; line-height: 0; text-decoration: none; }
/* padding-box wrapper keeps a fixed 16:9 frame even if the remote thumbnail fails to load */
.about-video .thumb-wrap { position: relative; width: 100%; padding-top: 56.25%; background: #0c1219; overflow: hidden; }
.about-video .thumb { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; display: block; }
.about-video .poster-overlay { position: absolute; inset: 0; background: linear-gradient(180deg, rgba(11,15,19,0) 38%, rgba(11,15,19,.72) 100%); pointer-events: none; transition: background .3s ease; z-index: 1; }
.about-video .video-card:hover .poster-overlay { background: linear-gradient(180deg, rgba(11,15,19,0) 28%, rgba(11,15,19,.82) 100%); }
.about-video .play-cta { position: absolute; left: 14px; bottom: 14px; z-index: 2; display: inline-flex; align-items: center; gap: 10px; padding: 11px 16px; background: var(--ips-accent); color: #fff; font-family: var(--font-sans); font-size: 10px; letter-spacing: .2em; text-transform: uppercase; font-weight: 600; text-decoration: none; line-height: 1; }
.about-video .video-card:hover .play-cta { background: var(--ips-accent-bright); }
.about-video .play-cta svg { width: 13px; height: 13px; fill: #fff; flex-shrink: 0; }

/* ---- content blocks (cream) ---- */
.about-block { padding: 60px 56px; border-top: 1px solid rgba(20,20,20,.1); }
.about-block .eyebrow { margin-bottom: 16px; }
.about-block h2 { font-family: 'Bebas Neue', sans-serif; font-size: clamp(30px, 4vw, 44px); letter-spacing: .005em; line-height: 1; color: var(--ips-ink); margin: 0; }
.about-block > p { font-size: 14px; line-height: 1.75; color: var(--ips-ink-soft); max-width: 760px; margin: 16px 0 0; }
.about-block .about-note { margin-top: 18px; font-style: italic; font-size: 13px; color: var(--ips-muted); max-width: 760px; }

.about-list { list-style: none; margin: 20px 0 0; padding: 0; max-width: 760px; }
.about-list li { position: relative; padding: 13px 0 13px 28px; border-top: 1px solid rgba(20,20,20,.08); font-size: 14px; line-height: 1.6; color: var(--ips-ink-soft); }
.about-list li::before { content: ""; position: absolute; left: 0; top: 21px; width: 12px; height: 1px; background: var(--ips-accent); }

/* leaders */
.leader-intro { font-size: 14px; line-height: 1.7; color: var(--ips-ink-soft); max-width: 760px; margin: 16px 0 0; }
.leader-card { display: flex; gap: 18px; align-items: center; background: #fff; border: 1px solid rgba(20,20,20,.1); padding: 18px 20px; margin-top: 18px; max-width: 760px; }
.leader-thumb { width: 88px; height: 58px; flex-shrink: 0; display: grid; place-items: center; background: var(--ips-hero); }
.leader-meta .lt { font-family: 'Bebas Neue', sans-serif; font-size: 20px; letter-spacing: .02em; color: var(--ips-ink); }
.leader-meta .ls { color: var(--ips-ink-soft); font-size: 13px; margin: 4px 0 10px; line-height: 1.55; }
.link-btn { display: inline-flex; align-items: center; gap: 8px; font-size: 10.5px; letter-spacing: .2em; text-transform: uppercase; font-weight: 600; color: var(--ips-accent); text-decoration: none; }
.link-btn:hover { color: var(--ips-accent-bright); }

/* corridor timeline */
.timeline { display: flex; flex-direction: column; margin-top: 22px; max-width: 880px; }
.cstep { display: grid; grid-template-columns: 56px 1fr; gap: 20px; padding: 22px 0; border-top: 1px solid rgba(20,20,20,.1); align-items: start; }
.cstep:first-child { border-top: none; }
.marker { width: 50px; height: 50px; display: grid; place-items: center; background: var(--ips-accent); color: #fff; font-family: 'Bebas Neue', sans-serif; font-size: 26px; line-height: 1; }
.step h4 { font-family: 'Bebas Neue', sans-serif; font-size: 23px; letter-spacing: .02em; color: var(--ips-ink); margin: 4px 0 8px; cursor: pointer; }
.step p { font-size: 13.5px; line-height: 1.65; color: var(--ips-ink-soft); margin: 0; max-width: 640px; }
.step .meta { margin-top: 10px; font-family: var(--font-mono); font-size: 10px; letter-spacing: .14em; text-transform: uppercase; color: var(--ips-muted); }
.step .keyword { color: var(--ips-ink); }

/* who-we-work-with tabs */
.about-tabs { display: flex; gap: 4px; border-bottom: 1px solid rgba(20,20,20,.12); margin: 20px 0 22px; flex-wrap: wrap; }
.tab { padding: 12px 18px; background: transparent; border: 0; border-bottom: 2px solid transparent; color: var(--ips-ink-soft); font-family: var(--font-sans); font-size: 11px; letter-spacing: .18em; text-transform: uppercase; font-weight: 600; cursor: pointer; }
.tab:hover { color: var(--ips-accent); }
.tab.active { color: var(--ips-accent); border-bottom-color: var(--ips-accent); }

/* cards (panels + is/is-not) */
.about-cards { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; max-width: 920px; }
.about-card { background: #fff; border: 1px solid rgba(20,20,20,.1); padding: 24px; }
.about-card h5 { font-family: 'Bebas Neue', sans-serif; font-size: 22px; letter-spacing: .02em; color: var(--ips-ink); margin: 0 0 14px; }
.about-card .about-list { margin-top: 0; }
.about-card .about-list li:first-child { border-top: none; padding-top: 4px; }

/* video modal (functional, restyled) */
.video-modal { display: none; position: fixed; inset: 0; z-index: 12000; align-items: center; justify-content: center; }
.video-modal[aria-hidden="false"] { display: flex; }
.video-modal__backdrop { position: absolute; inset: 0; background: rgba(7,7,8,.88); backdrop-filter: blur(6px); }
.video-modal__panel { position: relative; width: calc(100% - 32px); max-width: 900px; overflow: hidden; z-index: 12001; background: #000; border: 1px solid var(--ips-line-strong); }
.video-modal__frame { position: relative; width: 100%; height: 0; padding-bottom: 56.25%; }
.video-modal__frame iframe { position: absolute; inset: 0; width: 100%; height: 100%; border: 0; display: block; }
.video-modal__close { position: absolute; right: 12px; top: 12px; z-index: 5; padding: 9px 13px; border: 1px solid var(--ips-line-strong); background: rgba(11,15,19,.85); color: var(--ips-cream); font-size: 16px; cursor: pointer; line-height: 1; }
.video-modal__close:hover { background: var(--ips-accent); border-color: var(--ips-accent); color: #fff; }

img, iframe, video { max-width: 100%; }

/* ---- responsive ---- */
@media (max-width: 991px) {
    .about-hero, .about-block { padding-left: 24px; padding-right: 24px; }
    .about-hero-grid { grid-template-columns: 1fr; gap: 28px; }
    .about-cards { grid-template-columns: 1fr; }
}
@media (max-width: 600px) {
    .about-hero { padding-top: 44px; }
    .cstep { grid-template-columns: 40px 1fr; gap: 14px; }
    .marker { width: 38px; height: 38px; font-size: 20px; }
    .step .step-body { display: none; }
    .step.expanded .step-body { display: block; margin-top: 8px; }
    .step h4::after { content: " \203A"; color: var(--ips-accent); }
    .step.expanded h4::after { content: " \2039"; }
    .about-tabs { overflow-x: auto; -webkit-overflow-scrolling: touch; flex-wrap: nowrap; }
    .tab { white-space: nowrap; flex-shrink: 0; }
    .leader-card { flex-direction: column; align-items: flex-start; }
    .leader-thumb { width: 100%; height: 64px; }
}

/* ===========================================================================
   advisory council + readiness (shared editorial content-page primitives)
   =========================================================================== */
.about-hero .back-link { display: inline-flex; align-items: center; gap: 8px; margin-bottom: 18px; font-size: 10.5px; letter-spacing: .2em; text-transform: uppercase; font-weight: 600; color: #a8b0bb; text-decoration: none; }
.about-hero .back-link:hover { color: var(--ips-accent-bright); }
.about-hero .hero-role { margin-top: 16px; font-family: var(--font-mono); font-size: 12px; letter-spacing: .16em; text-transform: uppercase; color: var(--ips-accent-bright); }

/* council category groups */
.council-group { margin-top: 32px; }
.council-group:first-of-type { margin-top: 4px; }
.council-group h3 { font-family: 'Bebas Neue', sans-serif; font-size: 22px; letter-spacing: .02em; color: var(--ips-ink); margin: 0 0 14px; padding-bottom: 10px; border-bottom: 1px solid rgba(20,20,20,.12); }

/* advisor grid + card: compact card variant. desktop shows a denser grid with
   smaller photos + no body excerpt so each card is ~60% of the previous height,
   trading the long bio preview for breadth (more advisors above the fold).
   mobile gets a dedicated horizontal-row layout below the breakpoint so each
   advisor row is ~80px tall instead of ~350px. */
.advisor-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(210px, 1fr)); gap: 14px; }
.advisor-card { display: flex; flex-direction: column; background: #fff; border: 1px solid rgba(20,20,20,.1); text-decoration: none; color: var(--ips-ink); overflow: hidden; transition: transform .16s ease, border-color .16s ease, box-shadow .16s ease; }
.advisor-card:hover { transform: translateY(-4px); border-color: var(--ips-accent); box-shadow: 0 12px 24px rgba(20,20,20,.12); }
.advisor-photo { aspect-ratio: 4/3; overflow: hidden; background: linear-gradient(155deg, #18222e, #0c1219); display: grid; place-items: center; }
.advisor-photo img { width: 100%; height: 100%; object-fit: cover; }
.advisor-photo .ph-initials { font-family: 'Bebas Neue', sans-serif; font-size: 48px; color: rgba(245,234,208,.22); letter-spacing: .04em; }
.advisor-card .ac-body { padding: 14px 16px 16px; display: flex; flex-direction: column; flex: 1 1 auto; }
.advisor-card .ac-name { font-family: 'Bebas Neue', sans-serif; font-size: 20px; letter-spacing: .02em; line-height: 1.05; color: var(--ips-ink); }
.advisor-card .ac-role { margin-top: 5px; font-family: var(--font-mono); font-size: 9.5px; letter-spacing: .14em; text-transform: uppercase; color: var(--ips-accent); line-height: 1.4; }
/* bio excerpt hidden in the compact variant - the detail page carries the prose */
.advisor-card .ac-bio { display: none; }
.advisor-card .ac-more { margin-top: auto; padding-top: 12px; font-size: 9.5px; letter-spacing: .2em; text-transform: uppercase; font-weight: 600; color: var(--ips-accent); display: inline-flex; align-items: center; gap: 8px; }

/* mobile (<=640px): horizontal-row layout. each advisor becomes a single 80px
   tall row with a small square thumbnail on the left + name/role/icons stacked
   on the right. council page collapses from a tall card stack to a tight
   directory-style list. */
@media (max-width: 640px) {
    .advisor-grid { grid-template-columns: 1fr; gap: 10px; }
    .advisor-card { flex-direction: row; align-items: stretch; }
    .advisor-card:hover { transform: none; box-shadow: 0 6px 14px rgba(20,20,20,.1); }
    .advisor-photo { aspect-ratio: auto; width: 96px; height: 96px; flex: 0 0 96px; }
    .advisor-photo .ph-initials { font-size: 32px; }
    .advisor-card .ac-body { padding: 12px 14px; min-width: 0; }
    .advisor-card .ac-name { font-size: 18px; }
    .advisor-card .ac-role { font-size: 9px; }
    .advisor-card .ac-more { padding-top: 8px; font-size: 9px; }
    .council-group { margin-top: 22px; }
    .council-group h3 { font-size: 18px; margin-bottom: 10px; padding-bottom: 8px; }
}

/* advisor detail hero */
.advisor-detail-grid { display: grid; grid-template-columns: 300px 1fr; gap: 44px; align-items: center; margin-top: 6px; }
.advisor-portrait { width: 100%; max-width: 300px; aspect-ratio: 1/1; overflow: hidden; background: linear-gradient(150deg, var(--ips-accent-bright), var(--ips-accent)); display: grid; place-items: center; }
.advisor-portrait img { width: 100%; height: 100%; object-fit: cover; }
.advisor-portrait .ph-initials { font-family: 'Bebas Neue', sans-serif; font-size: 96px; color: rgba(255,255,255,.85); }

/* long-form prose (readiness body + advisor bio) */
.prose { max-width: 760px; }
.prose h2 { font-family: 'Bebas Neue', sans-serif; font-size: clamp(26px, 3.4vw, 34px); letter-spacing: .005em; color: var(--ips-ink); margin: 40px 0 0; }
.prose > h2:first-child, .prose > *:first-child { margin-top: 0; }
.prose p { font-size: 15px; line-height: 1.8; color: var(--ips-ink-soft); margin: 14px 0 0; }
.prose ul { list-style: none; margin: 18px 0 0; padding: 0; }
.prose li { position: relative; padding: 12px 0 12px 28px; border-top: 1px solid rgba(20,20,20,.08); font-size: 14px; line-height: 1.6; color: var(--ips-ink-soft); }
.prose li::before { content: ""; position: absolute; left: 0; top: 20px; width: 12px; height: 1px; background: var(--ips-accent); }
.prose a { color: var(--ips-accent); text-decoration: underline; text-underline-offset: 2px; }
.prose .cta-center { margin-top: 40px; }

@media (max-width: 991px) {
    .advisor-detail-grid { grid-template-columns: 1fr; gap: 24px; }
    .advisor-portrait { max-width: 240px; }
}

/* ----- advisor detail editorial pass -------------------------------------
   lifts the advisor detail page from a plain bio dump to the same editorial
   rhythm the legacy center pages use. no new fields - selectors below pull
   the lede, the pillar list and the pull-quote out of the existing bio HTML
   that the html sanitiser already renders. */

/* tightened topbar above the hero so the page opens with the same signature
   line the legacy center uses */
.advisor-topbar { background: var(--ips-hero); color: var(--ips-cream); display: flex; align-items: center; justify-content: space-between; gap: 24px; padding: 10px 56px; border-bottom: 1px solid rgba(245,234,208,.08); font-family: var(--font-mono); font-size: 10px; letter-spacing: .18em; text-transform: uppercase; flex-wrap: wrap; }
.advisor-topbar .left, .advisor-topbar .right { display: flex; gap: 24px; color: #8b929c; flex-wrap: wrap; align-items: center; }
.advisor-topbar b { color: var(--ips-cream); font-weight: 600; }

/* section head above the bio mirrors lc-sechead so the body has a clear
   editorial opener instead of starting cold on a paragraph */
.advisor-sechead { display: flex; align-items: baseline; justify-content: space-between; padding: 64px 56px 0; gap: 24px; flex-wrap: wrap; background: var(--ips-cream); }
.advisor-sechead .kicker { display: flex; align-items: center; gap: 14px; font-family: var(--font-mono); font-size: 10px; letter-spacing: .22em; text-transform: uppercase; color: var(--ips-muted); }
.advisor-sechead .kicker .num { font-family: 'Bebas Neue', sans-serif; font-size: 18px; color: var(--ips-accent); }
.advisor-sechead h2 { font-family: 'Bebas Neue', sans-serif; font-size: clamp(48px, 7vw, 84px); letter-spacing: .01em; color: var(--ips-ink); line-height: .9; margin: 0; }
.advisor-sechead .span { font-family: 'Bebas Neue', sans-serif; font-size: 20px; color: var(--ips-ink-soft); letter-spacing: .06em; }

/* body container - wider than .prose, more breathing, cream background */
.advisor-body { background: var(--ips-cream); padding: 32px 56px 96px; }
.advisor-body-grid { display: grid; grid-template-columns: minmax(0, 1fr) 280px; gap: 56px; align-items: start; max-width: 1280px; margin: 0 auto; }
.advisor-body .advisor-bio { max-width: none; margin: 0; min-width: 0; }

/* first paragraph reads as a lede: ink colour, larger size, drop cap on the
   opening letter so the eye lands on the bio with the same editorial weight
   the legacy center chapter columns carry */
.advisor-bio > p:first-of-type { font-family: var(--font-sans); font-size: 20px; line-height: 1.55; color: var(--ips-ink); margin-top: 28px; font-weight: 500; }
.advisor-bio > p:first-of-type::first-letter { float: left; font-family: 'Bebas Neue', sans-serif; font-size: 78px; line-height: .82; padding: 4px 14px 0 0; color: var(--ips-accent); }
.advisor-bio > p { font-size: 16px; line-height: 1.85; color: var(--ips-ink-soft); margin: 28px 0 0; padding-top: 28px; border-top: 1px solid rgba(20,20,20,.08); }
.advisor-bio > p:first-of-type { padding-top: 0; border-top: none; }
.advisor-bio > p + p { /* dividers come from border-top above */ }
.advisor-bio a { color: var(--ips-accent); text-decoration: underline; text-underline-offset: 2px; }

/* at-a-glance facts panel pinned to the right of the bio - same role the
   side ticker plays on the legacy center chapter blocks */
.advisor-facts { position: sticky; top: 24px; }
.facts-card { background: var(--ips-cream-2); border: 1px solid rgba(20,20,20,.18); padding: 28px 26px 24px; }
.facts-card h6 { font-family: var(--font-mono); font-size: 10px; letter-spacing: .22em; text-transform: uppercase; color: var(--ips-muted); margin: 0 0 18px; }
.facts-card dl { margin: 0; padding: 0; display: flex; flex-direction: column; gap: 16px; }
.facts-card dl > div { display: flex; flex-direction: column; gap: 4px; padding-bottom: 14px; border-bottom: 1px solid rgba(20,20,20,.12); }
.facts-card dl > div:last-of-type { border-bottom: none; padding-bottom: 0; }
.facts-card dt { font-family: var(--font-mono); font-size: 9.5px; letter-spacing: .2em; text-transform: uppercase; color: var(--ips-muted); margin: 0; }
.facts-card dd { margin: 0; font-family: 'Bebas Neue', sans-serif; font-size: 22px; letter-spacing: .03em; color: var(--ips-ink); line-height: 1.1; }
.facts-cta { display: inline-flex; align-items: center; justify-content: space-between; gap: 12px; margin-top: 24px; padding: 12px 16px; background: var(--ips-accent); color: var(--ips-ink); font-family: var(--font-mono); font-size: 10.5px; letter-spacing: .2em; text-transform: uppercase; text-decoration: none; width: 100%; transition: background .15s ease; }
.facts-cta:hover { background: var(--ips-accent-bright); color: var(--ips-ink); }
.facts-cta .arr { font-size: 16px; line-height: 1; }

/* numbered list becomes a vertical stack of pillar cells - each one carries
   a giant accent number so the readiness pillars register as the structural
   spine of the page, not a throwaway bullet list */
.advisor-bio > ol { counter-reset: pillar; list-style: none; margin: 44px 0 0; padding: 0; border-top: 1px solid rgba(20,20,20,.18); }
.advisor-bio > ol li { counter-increment: pillar; position: relative; padding: 28px 0 28px 96px; border-bottom: 1px solid rgba(20,20,20,.18); font-family: 'Bebas Neue', sans-serif; font-size: 28px; letter-spacing: .03em; color: var(--ips-ink); line-height: 1.05; }
.advisor-bio > ol li::before { content: counter(pillar, decimal-leading-zero); position: absolute; left: 0; top: 22px; font-family: 'Bebas Neue', sans-serif; font-size: 54px; color: var(--ips-accent); line-height: .85; letter-spacing: .02em; }

/* unordered list becomes a roster grid - used for non-ranked enumerations
   like country posts. each item is a small accent-dashed line on a cream-2
   background so the list reads as a structural roster rather than default
   disc bullets running down the page */
.advisor-bio > ul { list-style: none; margin: 36px 0 0; padding: 0; display: grid; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)); gap: 8px; }
.advisor-bio > ul li { position: relative; padding: 14px 16px 14px 32px; background: var(--ips-cream-2); border: 1px solid rgba(20,20,20,.12); font-family: var(--font-sans); font-size: 14px; line-height: 1.3; color: var(--ips-ink); letter-spacing: .02em; }
.advisor-bio > ul li::before { content: ""; position: absolute; left: 14px; top: 50%; width: 10px; height: 2px; background: var(--ips-accent); transform: translateY(-50%); }

/* blockquote becomes an inline pull-quote with the same display face the
   legacy center pages use for their pull-quote bands */
.advisor-bio > blockquote { position: relative; margin: 56px 0; padding: 44px 32px 44px 84px; background: var(--ips-cream-2); border-left: 4px solid var(--ips-accent); font-family: 'Bebas Neue', sans-serif; font-size: clamp(28px, 4vw, 44px); line-height: 1.1; letter-spacing: .01em; color: var(--ips-ink); quotes: none; }
.advisor-bio > blockquote::before { content: "\201C"; position: absolute; left: 28px; top: 18px; font-family: 'Bebas Neue', sans-serif; font-size: 108px; line-height: 1; color: var(--ips-accent); opacity: .35; }

/* external-link badges: visible, easy to identify. shown beneath the role on
   the hero whenever an advisor has LinkedInUrl and/or WebsiteUrl populated;
   either field degrades to nothing when null. linkedin uses brand blue with
   the official linkedin glyph; website uses ips-accent with an inline globe
   so the two are distinct at a glance and never read as the same link. */
.advisor-links { display: flex; gap: 10px; margin-top: 18px; flex-wrap: wrap; }
.advisor-linkedin,
.advisor-website,
.advisor-instagram { display: inline-flex; align-items: center; gap: 10px; padding: 9px 16px; color: #fff; font-family: var(--font-mono); font-size: 11px; letter-spacing: .18em; text-transform: uppercase; text-decoration: none; border-radius: 4px; transition: background .15s ease, transform .15s ease, filter .15s ease; }
.advisor-linkedin { background: #0A66C2; }
.advisor-linkedin:hover { background: #084d94; color: #fff; transform: translateY(-1px); }
.advisor-website { background: var(--ips-accent); color: var(--ips-ink); }
.advisor-website:hover { background: var(--ips-accent-bright); color: var(--ips-ink); transform: translateY(-1px); }
.advisor-instagram { background: linear-gradient(45deg, #833AB4 0%, #C13584 25%, #E1306C 50%, #FD1D1D 75%, #F77737 100%); }
.advisor-instagram:hover { color: #fff; transform: translateY(-1px); filter: brightness(1.08); }
.advisor-linkedin .li-mark,
.advisor-website .li-mark,
.advisor-instagram .li-mark { width: 18px; height: 18px; flex: 0 0 auto; }

/* compact links inside the at-a-glance facts card */
.facts-linkedin,
.facts-website,
.facts-instagram { display: inline-flex; align-items: center; gap: 8px; text-decoration: none; font-family: 'Bebas Neue', sans-serif; font-size: 18px; letter-spacing: .03em; line-height: 1.1; }
.facts-linkedin { color: #0A66C2; }
.facts-linkedin:hover { color: #084d94; text-decoration: underline; text-underline-offset: 3px; }
.facts-website { color: var(--ips-accent); }
.facts-website:hover { color: var(--ips-accent-bright); text-decoration: underline; text-underline-offset: 3px; }
.facts-instagram { color: #E1306C; }
.facts-instagram:hover { color: #C13584; text-decoration: underline; text-underline-offset: 3px; }
.facts-linkedin .li-mark,
.facts-website .li-mark,
.facts-instagram .li-mark { width: 16px; height: 16px; flex: 0 0 auto; }

/* small marks next to "Read more" on the council card so visitors can tell
   at a glance which advisors have an external profile or site to follow */
.advisor-card .ac-linkedin,
.advisor-card .ac-website,
.advisor-card .ac-instagram { display: inline-flex; align-items: center; margin-left: 10px; }
.advisor-card .ac-linkedin { color: #0A66C2; }
.advisor-card:hover .ac-linkedin { color: #084d94; }
.advisor-card .ac-website { color: var(--ips-accent); }
.advisor-card:hover .ac-website { color: var(--ips-accent-bright); }
.advisor-card .ac-instagram { color: #E1306C; }
.advisor-card:hover .ac-instagram { color: #C13584; }
.advisor-card .ac-linkedin .li-mark,
.advisor-card .ac-website .li-mark,
.advisor-card .ac-instagram .li-mark { width: 14px; height: 14px; }

/* footer CTA mirrors lc-cta so the page closes on a clear next step */
.advisor-cta { background: var(--ips-hero); color: var(--ips-cream); padding: 72px 56px; display: grid; grid-template-columns: 1fr 1fr; gap: 56px; align-items: center; }
.advisor-cta h2 { font-family: 'Bebas Neue', sans-serif; font-size: clamp(36px, 5vw, 64px); line-height: .98; letter-spacing: .01em; margin: 0; }
.advisor-cta h2 em { font-style: normal; color: var(--ips-accent); }
.advisor-cta p { font-size: 14px; line-height: 1.8; color: #cfd4da; margin: 18px 0 0; max-width: 460px; }
.advisor-cta .cta-actions { display: flex; gap: 14px; flex-wrap: wrap; justify-content: flex-end; }
.advisor-cta .cta-btn { display: inline-flex; align-items: center; gap: 10px; padding: 14px 24px; font-family: var(--font-mono); font-size: 11px; letter-spacing: .2em; text-transform: uppercase; text-decoration: none; border: 1px solid var(--ips-accent); color: var(--ips-cream); background: transparent; transition: background .15s ease, color .15s ease; }
.advisor-cta .cta-btn.primary { background: var(--ips-accent); color: var(--ips-ink); border-color: var(--ips-accent); }
.advisor-cta .cta-btn:hover { background: var(--ips-accent-bright); color: var(--ips-ink); border-color: var(--ips-accent-bright); }

/* at the tablet breakpoint the facts panel drops below the bio so neither
   column gets squeezed; sticky position is released since it stops being a
   companion column and becomes a footer block */
@media (max-width: 991px) {
    .advisor-body-grid { grid-template-columns: 1fr; gap: 36px; }
    .advisor-facts { position: static; }
    .facts-card { max-width: 520px; }
}

@media (max-width: 760px) {
    .advisor-topbar { padding: 10px 20px; gap: 12px; font-size: 9.5px; }
    .advisor-topbar .right { display: none; }
    .advisor-sechead { padding: 48px 20px 0; }
    .advisor-sechead h2 { font-size: clamp(40px, 12vw, 72px); }
    .advisor-body { padding: 24px 20px 64px; }
    .advisor-bio > p:first-of-type { font-size: 18px; }
    .advisor-bio > p:first-of-type::first-letter { font-size: 64px; }
    .advisor-bio > ol li { padding-left: 72px; font-size: 22px; }
    .advisor-bio > ol li::before { font-size: 42px; top: 18px; }
    .advisor-bio > blockquote { margin: 40px 0; padding: 32px 20px 32px 56px; }
    .advisor-bio > blockquote::before { left: 16px; font-size: 72px; }
    .advisor-cta { padding: 56px 20px; grid-template-columns: 1fr; gap: 28px; }
    .advisor-cta .cta-actions { justify-content: flex-start; }
}
