/* Self-hosted IBM Plex Sans — replaces the render-blocking @import to Google Fonts that was in styles.min.css. */
/* latin-ext */
@font-face {
  font-family: 'IBM Plex Sans';
  font-style: normal;
  font-weight: 300;
  font-stretch: 100%;
  font-display: swap;
  src: url(/assets/fonts/ibm-plex-sans/ibm-plex-sans-300-latin-ext.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'IBM Plex Sans';
  font-style: normal;
  font-weight: 300;
  font-stretch: 100%;
  font-display: swap;
  src: url(/assets/fonts/ibm-plex-sans/ibm-plex-sans-300-latin.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* latin-ext */
@font-face {
  font-family: 'IBM Plex Sans';
  font-style: normal;
  font-weight: 400;
  font-stretch: 100%;
  font-display: swap;
  src: url(/assets/fonts/ibm-plex-sans/ibm-plex-sans-400-latin-ext.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'IBM Plex Sans';
  font-style: normal;
  font-weight: 400;
  font-stretch: 100%;
  font-display: swap;
  src: url(/assets/fonts/ibm-plex-sans/ibm-plex-sans-400-latin.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* latin-ext */
@font-face {
  font-family: 'IBM Plex Sans';
  font-style: normal;
  font-weight: 500;
  font-stretch: 100%;
  font-display: swap;
  src: url(/assets/fonts/ibm-plex-sans/ibm-plex-sans-500-latin-ext.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'IBM Plex Sans';
  font-style: normal;
  font-weight: 500;
  font-stretch: 100%;
  font-display: swap;
  src: url(/assets/fonts/ibm-plex-sans/ibm-plex-sans-500-latin.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* latin-ext */
@font-face {
  font-family: 'IBM Plex Sans';
  font-style: normal;
  font-weight: 600;
  font-stretch: 100%;
  font-display: swap;
  src: url(/assets/fonts/ibm-plex-sans/ibm-plex-sans-600-latin-ext.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'IBM Plex Sans';
  font-style: normal;
  font-weight: 600;
  font-stretch: 100%;
  font-display: swap;
  src: url(/assets/fonts/ibm-plex-sans/ibm-plex-sans-600-latin.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

/* Theme Park Innovations — petrol primary on a B&W foundation. */
:root {
    --primary-rgb: 12, 56, 72;
    --body-bg-rgb: 255, 255, 255;
    --default-background: #ffffff;
    --default-body-bg-color: #ffffff;
    --default-text-color: #111111;
    --header-bg: #ffffff;
    --menu-bg: #ffffff;
    --menu-prime-color: #111111;
    --header-prime-color: rgb(var(--primary-rgb));
    --default-border: #e6e6e6;
    --header-border-color: #e6e6e6;
    --menu-border-color: #e6e6e6;
    --bootstrap-card-border: #e6e6e6;
    --text-muted: #5b6470;
    --shadow-color: rgba(12, 56, 72, 0.08);
}

/* Petrol frame: body is petrol, the landing wrapper is a centered white
   "page" with petrol gutters visible on the sides on wider viewports. */
html,
body {
    margin: 0;
    padding: 0;
}
/* Sash's base body sets overflow-y: scroll which turns body into a scroll
   container and breaks position:sticky for descendants (the header would
   scroll off the top of the viewport instead of pinning). Override so the
   viewport is the scroll context again. overflow-x: clip prevents any
   horizontal bleed without re-establishing a scroll container. */
.landing-body {
    overflow-y: visible !important;
    overflow-x: clip;
}
html {
    overflow-x: clip;
}

body,
.landing-body {
    background: #0c3848;
}

.landing-body .landing-page-wrapper {
    background: #ffffff;
    /* Cap at 1280px (matches Bootstrap container norms); always leave at least
       24px of petrol on each side so the frame is visible on laptops too. */
    width: min(1280px, 100% - 48px);
    margin-inline: auto;
    box-shadow: 0 0 60px rgba(0, 0, 0, 0.2);
    position: relative;       /* contains absolutely-positioned descendants */
}

/* Belt-and-braces: keep every section's own background bounded to the wrapper. */
.landing-body .landing-page-wrapper > * {
    max-width: 100%;
}

/* On mobile, drop the frame so content goes edge-to-edge. */
@media (max-width: 767.98px) {
    .landing-body .landing-page-wrapper {
        width: 100%;
        box-shadow: none;
    }
}

/* Sash's section-bg renders a subtle off-white instead of tinted primary. */
.landing-body .section-bg {
    background: #f6f7f8;
}

/* Strip Sash's decorative hero artwork — both the grey backdrop image and the
   absolutely-positioned ::before rectangle that bleeds past the wrapper. */
.landing-body .landing-banner {
    background-image: none !important;
    background-color: #ffffff;
}

.landing-body .landing-banner::before {
    content: none !important;
    display: none !important;
}

/* Same treatment for the Features section's gradient overlay. */
.landing-body .landing-Features {
    background-image: none !important;
}
.landing-body .landing-Features::before {
    content: none !important;
    display: none !important;
}

/* Inner CTA banner — keep petrol, but kill Sash's intentional +92px overlap
   that pushes the banner DOWN into the dark footer. We want a clean break
   between the petrol CTA and the black footer beneath it. */
.landing-body .buynow-landing {
    inset-block-start: 0 !important;
    margin-block-end: 0;
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.15);
}
.landing-body .buynow-landing::before {
    content: none !important;
}
.landing-body .buynow-landing .card-body {
    background: #0c3848;
    border-radius: 12px;
}

/* Inner Features section — replace the SaaS gradient with a deep neutral so
   the section reads as distinct from the petrol outer frame. */
.landing-body .landing-Features {
    background: #111111 !important;
}

/* Persona cards — large clickable surfaces for the home page. */
.persona-card {
    display: block;
    padding: 2rem 1.5rem;
    border: 1px solid #e6e6e6;
    border-radius: 12px;
    background: #ffffff;
    color: #111111;
    text-decoration: none;
    height: 100%;
    transition: border-color .15s ease, transform .15s ease, box-shadow .15s ease;
}

.persona-card:hover,
.persona-card:focus {
    border-color: #0c3848;
    transform: translateY(-2px);
    box-shadow: 0 12px 28px rgba(12, 56, 72, 0.10);
    color: #0c3848;
}

.persona-card .persona-icon {
    width: 56px;
    height: 56px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    background: rgba(12, 56, 72, 0.08);
    color: #0c3848;
    font-size: 1.6rem;
    margin-bottom: 1rem;
}

.persona-card .persona-title {
    font-weight: 600;
    font-size: 1.15rem;
    margin-bottom: .35rem;
}

.persona-card .persona-sub {
    color: #5b6470;
    margin-bottom: 0;
    font-size: .95rem;
}

/* Capability cards — compact grid of platform capability tiles. */
.capability-card {
    position: relative;
    display: flex;
    flex-direction: column;
    padding: 1.75rem;
    border: 1px solid #e6e6e6;
    border-radius: 12px;
    background: #ffffff;
    color: #111111;
    text-decoration: none;
    height: 100%;
    overflow: hidden;
    transition: border-color .18s ease, box-shadow .18s ease, transform .18s ease;
}

.capability-card:hover,
.capability-card:focus {
    border-color: #0c3848;
    box-shadow: 0 10px 28px rgba(12, 56, 72, 0.10);
    color: #111111;
    transform: translateY(-2px);
}

.capability-card .capability-icon {
    width: 46px;
    height: 46px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 9px;
    background: rgba(12, 56, 72, 0.08);
    color: #0c3848;
    font-size: 1.4rem;
    margin-bottom: .9rem;
}

.capability-card h6,
.capability-card h5,
.capability-card h3 {
    font-weight: 700;
    margin-bottom: .4rem;
    color: #0c3848;
    letter-spacing: -0.005em;
}

.capability-card h6,
.capability-card h3 {
    font-size: 1.05rem;
}

.capability-card h5 {
    font-size: 1.5rem;
}

/* PoV line: italic petrol opinion under the title.
   This is what makes each card sound like a stance, not a feature list. */
.capability-card__pov {
    font-style: italic;
    color: #0c3848;
    font-size: 0.95rem;
    font-weight: 500;
    margin-bottom: 1rem;
    line-height: 1.45;
}

.capability-card__lede {
    color: #5b6470;
    font-size: 0.94rem;
    line-height: 1.55;
    margin-bottom: 0;
}

.capability-card__list {
    list-style: none;
    padding: 0;
    margin: 0 0 1.1rem 0;
    flex: 1 1 auto;
}

.capability-card__list li {
    position: relative;
    padding-left: 1.1rem;
    margin-bottom: 0.5rem;
    font-size: 0.88rem;
    color: #5b6470;
    line-height: 1.5;
}

.capability-card__list li:last-child {
    margin-bottom: 0;
}

.capability-card__list li::before {
    content: "";
    position: absolute;
    left: 0;
    top: 0.55em;
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: #0c3848;
    opacity: 0.5;
}

.capability-card__link {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    font-size: 0.85rem;
    font-weight: 700;
    color: #0c3848;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    margin-top: auto;
    padding-top: 0.5rem;
    transition: gap .15s ease;
}

.capability-card__link i {
    transition: transform .15s ease;
}

.capability-card:hover .capability-card__link {
    gap: 0.6rem;
}

.capability-card:hover .capability-card__link i {
    transform: translateX(2px);
}

/* Feature/anchor card — petrol gradient hero treatment for the lead
   capability in each section. Adds visual rhythm so 24 cards don't
   read as a wall of sameness. */
.capability-card--feature {
    background: linear-gradient(135deg, #0c3848 0%, #144a5e 100%);
    color: #ffffff;
    border-color: #0c3848;
    padding: 2.25rem 2.25rem 2rem;
}

.capability-card--feature:hover,
.capability-card--feature:focus {
    color: #ffffff;
    border-color: #0c3848;
    box-shadow: 0 14px 36px rgba(12, 56, 72, 0.28);
}

.capability-card--feature .capability-icon {
    background: rgba(255, 255, 255, 0.15);
    color: #ffffff;
    width: 54px;
    height: 54px;
    font-size: 1.65rem;
}

.capability-card--feature h5 {
    color: #ffffff;
}

.capability-card--feature .capability-card__pov {
    color: #ffffff;
    font-size: 1.1rem;
    opacity: 0.95;
    font-style: italic;
    margin-bottom: 0.85rem;
}

.capability-card--feature .capability-card__lede {
    color: rgba(255, 255, 255, 0.78);
    font-size: 0.95rem;
}

.capability-card--feature .capability-card__list li {
    color: rgba(255, 255, 255, 0.88);
    font-size: 0.92rem;
}

.capability-card--feature .capability-card__list li::before {
    background: rgba(255, 255, 255, 0.6);
    opacity: 1;
}

.capability-card--feature .capability-card__link {
    color: #ffffff;
    opacity: 0.92;
}

.capability-card__badge {
    position: absolute;
    top: 1.15rem;
    right: 1.15rem;
    background: rgba(255, 255, 255, 0.15);
    color: #ffffff;
    font-size: 0.65rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    padding: 0.3rem 0.6rem;
    border-radius: 4px;
}

.capability-card__feature-grid {
    display: grid;
    grid-template-columns: 1.2fr 1fr;
    gap: 2rem;
    align-items: start;
    margin-bottom: 1.5rem;
}

@media (max-width: 767.98px) {
    .capability-card__feature-grid {
        grid-template-columns: 1fr;
        gap: 1.25rem;
    }
    .capability-card--feature {
        padding: 1.75rem;
    }
    .capability-card__badge {
        position: static;
        display: inline-block;
        margin-bottom: 1rem;
    }
}

/* Pillar hero carousel — full-width banner that sits directly under the
   header on /capabilities.html. Mirrors the homepage hero look (cinematic
   .tpi-hero-bg with dark scrim and left-aligned text overlay), but cycles
   between three anchor pillars instead of a single static image. */
.tpi-hero-carousel .carousel-inner,
.tpi-hero-carousel .carousel-item {
    height: 100%;
}

/* Override .tpi-hero-bg's homepage-specific background image so each slide
   shows its own placeholder until Mike drops in pillar imagery. */
.tpi-hero-carousel__slide {
    background-image: none !important;
}

/* Per-slide hero images. Petrol background-color is the fallback shown
   if the image is missing/loading — keeps text legible either way.
   Target spec matches the homepage hero: ~1280x600, ~2.13:1, focal subject
   right of center (text overlay sits on the left under the dark scrim). */
.tpi-hero-carousel__slide--ops {
    background-color: #0c3848 !important;
    background-image: url('/assets/images/operations-safety.jpg') !important;
}
.tpi-hero-carousel__slide--plant {
    background-color: #08242e !important;
    background-image: url('/assets/images/maintenance-physical-plant.jpg') !important;
}
.tpi-hero-carousel__slide--bi {
    background-color: #134656 !important;
    background-image: url('/assets/images/finance-business-intelligence.jpg') !important;
}

/* Eyebrow on the dark slide — petrol dot is invisible on dark, so use a
   plain white-tinted label instead of .landing-section-heading. */
.tpi-hero-carousel__eyebrow {
    color: rgba(255, 255, 255, 0.78);
    font-size: 0.85rem;
    font-weight: 600;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    margin-bottom: 0.75rem;
}

/* Default Bootstrap controls/indicators are white-on-dark — fine here.
   Just give the indicators a wider pill when active to match site rhythm. */
.tpi-hero-carousel .carousel-indicators {
    margin-bottom: 1.5rem;
    gap: 0.5rem;
}

.tpi-hero-carousel .carousel-indicators button {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background-color: rgba(255, 255, 255, 0.45);
    border: 0;
    opacity: 1;
    transition: background-color .15s ease, width .15s ease;
}

.tpi-hero-carousel .carousel-indicators button.active {
    background-color: #ffffff;
    width: 28px;
    border-radius: 4px;
}

/* Pull controls slightly inset so they don't crowd the wrapper edge. */
.tpi-hero-carousel .carousel-control-prev,
.tpi-hero-carousel .carousel-control-next {
    width: 4rem;
    opacity: 0.85;
}

.tpi-hero-carousel .carousel-control-prev:hover,
.tpi-hero-carousel .carousel-control-next:hover {
    opacity: 1;
}

/* Compact capability index — typographic list of all 24 areas
   grouped under their section, used in place of card-grid sections
   when we want breadth without information overload. */
.tpi-cap-index__head {
    color: #0c3848;
    font-weight: 700;
    font-size: 0.95rem;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    margin-bottom: 0.9rem;
    padding-bottom: 0.6rem;
    border-bottom: 1px solid #d9dde2;
    display: flex;
    align-items: baseline;
    justify-content: space-between;
}

.tpi-cap-index__count {
    font-size: 0.75rem;
    color: #5b6470;
    font-weight: 500;
    letter-spacing: 0;
}

.tpi-cap-index__list li {
    margin-bottom: 0.4rem;
}

.tpi-cap-index__list a {
    color: #1a1a1a;
    text-decoration: none;
    font-size: 0.94rem;
    line-height: 1.45;
    display: inline-block;
    transition: color .15s ease;
}

.tpi-cap-index__list a:hover,
.tpi-cap-index__list a:focus {
    color: #0c3848;
    text-decoration: underline;
}

/* Hero subhead spacing tweak. */
.landing-banner .hero-eyebrow {
    display: inline-block;
    padding: .35rem .75rem;
    border-radius: 999px;
    background: rgba(12, 56, 72, 0.08);
    color: #0c3848;
    font-size: .85rem;
    font-weight: 500;
    margin-bottom: 1rem;
    letter-spacing: .02em;
}

/* Section eyebrow tag. */
.section-eyebrow {
    display: inline-block;
    color: #0c3848;
    font-weight: 600;
    letter-spacing: .12em;
    text-transform: uppercase;
    font-size: .8rem;
    margin-bottom: .5rem;
}

/* Footer cleanup — keep it white with petrol headings. */
.landing-footer h6 {
    color: #0c3848;
    letter-spacing: .08em;
}

.landing-main-footer {
    border-top: 1px solid #e6e6e6;
}

/* ---------- Brand lockup (mark + wordmark) ---------- */

.tpi-brand-lockup {
    display: inline-flex;
    flex-direction: column;
    align-items: center;
    gap: 0.3rem;
    text-decoration: none;
    color: #111111;
    line-height: 1;
}

.tpi-brand-lockup:hover,
.tpi-brand-lockup:focus {
    color: #0c3848;
    text-decoration: none;
}

/* Wheel mark: pre-cropped 381x400 PNG, displayed at the wordmark's scale. */
.tpi-brand-mark {
    display: block;
    width: 3.75em;
    height: 3.75em;
    background-image: url('/assets/images/brand-logos/tpi-mark.png');
    background-repeat: no-repeat;
    background-position: center center;
    background-size: contain;
}

.tpi-brand-wordmark {
    font-size: 1rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    color: #111111;
    line-height: 1;
    white-space: nowrap;
}

.tpi-brand-lockup:hover .tpi-brand-wordmark,
.tpi-brand-lockup:focus .tpi-brand-wordmark {
    color: #0c3848;
}

/* The lockup uses em units, so changing font-size scales mark + text together. */
.tpi-brand-lockup {
    font-size: 1rem;
}

/* Larger variant for the footer. */
.tpi-brand-lockup--lg {
    font-size: 1.25rem;
    gap: 0.45rem;
}

/* ---------- Header / nav ---------- */

/* Desktop: the sticky sidebar IS the header on the landing layout.
   Sash's base .app-sidebar is position:fixed + width:17rem for the admin-app
   vertical sidebar; the landing override forgets to reset those, so we do it
   here — otherwise the header spans the full viewport, ignoring the petrol
   gutters that frame the rest of the page. */
@media (min-width: 992px) {
    .landing-body .app-sidebar {
        position: sticky !important;
        inset-block-start: 0;
        inset-inline-start: auto !important;
        width: auto !important;
        z-index: 50;
        background-color: #111111 !important;
        border-bottom: none;
        border-top: 3px solid #0c3848;
        /* Compact ~80-85px header band — comparable to a standard nav. */
        padding: 0.35rem 1.75rem !important;
        /* Persistent soft shadow so the header lifts off the petrol gutters. */
        box-shadow: 0 2px 8px rgba(0, 0, 0, 0.18);
        transition: box-shadow .2s ease, padding .2s ease;
    }
    .landing-body .app-sidebar.sticky.sticky-pin {
        /* Stronger shadow when pinned — confirms the user has scrolled. */
        box-shadow: 0 6px 20px rgba(0, 0, 0, 0.35);
        padding: 0.25rem 1.75rem !important;
    }
    /* Tighter lockup so the header isn't dominated by the brand. */
    .landing-body .app-sidebar .tpi-brand-lockup {
        font-size: 0.85rem;
    }
    /* Sash adds 0.85rem vertical padding to .horizontal-logo on horizontal
       nav layouts, adding ~27px to the header. We don't need it because we
       already control padding on .app-sidebar. */
    .landing-body .app-sidebar .horizontal-logo {
        padding: 0 !important;
    }
    .landing-body .main-menu-container {
        gap: 0;
    }
    .landing-body .landing-logo-container {
        padding-inline-end: 2rem;
    }

    /* ---- Nav items: rollover buttons with thin vertical dividers ---- */
    .landing-body .app-sidebar .main-menu {
        gap: 0;
    }
    .landing-body .app-sidebar .side-menu__item {
        position: relative;
        font-size: 0.9rem;
        font-weight: 500;
        padding: 0.65rem 1.2rem !important;
        color: rgba(255, 255, 255, 0.82);
        border-radius: 0 !important;
        transition: color .15s ease, background-color .15s ease;
    }
    /* Vertical divider on the LEFT of every nav item except the first
       (so dividers appear between items, not at the outer edges). */
    .landing-body .app-sidebar .main-menu > li + li > .side-menu__item::before {
        content: "";
        position: absolute;
        left: 0;
        top: 22%;
        bottom: 22%;
        width: 1px;
        background: rgba(255, 255, 255, 0.14);
    }
    /* Rollover state: the item fills with petrol (the page background color
       showing in the gutters) with a soft drop shadow — reads as a button
       sitting on top of the dark header, with white text holding strong
       contrast on the petrol fill. */
    .landing-body .app-sidebar .side-menu__item:hover,
    .landing-body .app-sidebar .side-menu__item.active {
        color: #ffffff !important;
        background-color: #0c3848 !important;
        box-shadow: 0 4px 12px rgba(0, 0, 0, 0.4);
    }
    /* Nav labels live in a <span class="side-menu__label"> inside each item.
       Sash sets the label color directly — both default (var(--menu-prime-color)
       which can be black) and in the pinned state (var(--custom-black) = #000).
       Both render black-on-black on our dark header. Force inherit so my
       item-level white color cascades down. */
    .landing-body .app-sidebar .side-menu__item .side-menu__label,
    .landing-body .app-sidebar.sticky.sticky-pin .side-menu__label,
    .landing-body .app-sidebar.sticky.sticky-pin .side-menu__item .side-menu__label {
        color: inherit !important;
    }

    .landing-body .main-menu-container .btn-list .btn-primary {
        padding: 0.5rem 1.1rem;
    }

    /* Shrink the lockup slightly when pinned. */
    .landing-body .app-sidebar.sticky.sticky-pin .tpi-brand-lockup {
        font-size: 0.72rem;
        transition: font-size .2s ease;
    }
}

/* Mobile: top app-header is now the same near-black shell. */
@media (max-width: 991.98px) {
    .landing-body .app-header {
        background: #111111;
        border-bottom: none;
        border-top: 3px solid #0c3848;
        box-shadow: none;
    }
    /* Sidebar at mobile: fixed slide-out drawer, hidden by default. The vendor
       gates its translateX on [data-toggled=close/open] but that attribute is
       only set after defaultmenu.min.js runs. Without this rule, the sidebar
       defaults to its in-flow horizontal-nav layout from .landing-body and
       overlays the page content. */
    .landing-body .app-sidebar {
        position: fixed !important;
        top: 0;
        left: 0;
        width: 17rem !important;
        max-width: 80vw;
        height: 100vh !important;
        background: #111111 !important;
        z-index: 1050;
        transform: translateX(-100%);
        transition: transform .3s ease;
        padding: 1rem 0 !important;
        box-shadow: 0 0 30px rgba(0, 0, 0, 0.4);
        overflow-y: auto;
    }
    /* When the hamburger is tapped, the vendor JS sets [data-toggled=open]
       on <html>. Slide the drawer into view. */
    [data-toggled="open"] .landing-body .app-sidebar {
        transform: translateX(0);
    }
    /* Stack nav items vertically inside the drawer (vendor stacks them
       horizontally for the landing-body desktop nav). */
    .landing-body .app-sidebar .main-menu {
        flex-direction: column;
        gap: 0;
    }
    .landing-body .app-sidebar .side-menu__item {
        color: rgba(255, 255, 255, 0.88) !important;
        padding: 0.85rem 1.5rem !important;
        border-bottom: 1px solid rgba(255, 255, 255, 0.08);
        border-radius: 0 !important;
    }
    .landing-body .app-sidebar .side-menu__item.active {
        background-color: #0c3848 !important;
        color: #ffffff !important;
    }
    /* Horizontal-nav scroll arrows are for the desktop top-bar; hide them
       inside the slide-out drawer. */
    .landing-body .app-sidebar .slide-left,
    .landing-body .app-sidebar .slide-right {
        display: none !important;
    }
    /* The CTA button block in the sidebar — give it some breathing room. */
    .landing-body .app-sidebar .btn-list {
        padding: 1rem 1.5rem;
    }
    /* Sash's mobile app-header is position:fixed and overlays the page.
       Fallback offset in case the JS sync hasn't run yet — the actual
       value is set dynamically by tpi-site.js. */
    .landing-body .main-content {
        padding-block-start: 100px;
    }
    .landing-body .main-header-container {
        padding-block: 0.5rem;
        padding-inline: 1rem;
    }
    .landing-body .app-header .sidemenu-toggle {
        color: rgba(255, 255, 255, 0.9);
        background: transparent;
        border: 0;
        cursor: pointer;
    }
    .landing-body .app-header .btn-primary {
        padding: 0.45rem 0.9rem;
    }
    /* Slightly smaller lockup on mobile so it fits with hamburger + CTA. */
    .landing-body .app-header .tpi-brand-lockup {
        font-size: 0.78rem;
        gap: 0.2rem;
    }
    /* Mobile slide-out menu (when hamburger is tapped) — keep readable. */
    .landing-body .app-sidebar:not(.sticky-pin) .side-menu__item {
        color: rgba(255, 255, 255, 0.85);
    }
}

/* ---------- Inverted brand lockup (used in dark contexts) ---------- */

/* Anywhere the lockup sits on a dark surface, flip the mark to white via
   filter (preserves the PNG's alpha so the ferris wheel becomes white on
   the dark background) and flip the wordmark to white. */
.landing-body .app-sidebar .tpi-brand-mark,
.landing-body .app-header .tpi-brand-mark,
.landing-body .landing-footer .tpi-brand-mark {
    filter: brightness(0) invert(1);
}
.landing-body .app-sidebar .tpi-brand-wordmark,
.landing-body .app-header .tpi-brand-wordmark,
.landing-body .landing-footer .tpi-brand-wordmark {
    color: #ffffff;
}
.landing-body .app-sidebar .tpi-brand-lockup:hover .tpi-brand-wordmark,
.landing-body .app-header .tpi-brand-lockup:hover .tpi-brand-wordmark,
.landing-body .landing-footer .tpi-brand-lockup:hover .tpi-brand-wordmark {
    color: #ffffff;
    opacity: 0.85;
}

/* ---------- Dark footer ---------- */

.landing-body .landing-footer {
    background-color: #111111 !important;
    padding-block-start: 4rem;
    border-bottom: none;
}
.landing-body .landing-footer p,
.landing-body .landing-footer .text-muted {
    color: rgba(255, 255, 255, 0.65) !important;
}
.landing-body .landing-footer .footer-col-title {
    color: #6a9cb0;        /* lifted petrol, >=4.5:1 on the black footer */
    letter-spacing: 0.12em;
    font-size: 0.875rem;
    margin-block-start: 0;
}
/* Hide Sash's decorative diamond marker on footer h6 (it sits 15px to the
   left of each heading and clashes with our cleaner footer treatment). */
.landing-body .landing-footer h6::before {
    content: none !important;
}
.landing-body .landing-footer .landing-footer-list a {
    color: rgba(255, 255, 255, 0.7);
    text-decoration: none;
    transition: color .15s ease;
}
.landing-body .landing-footer .landing-footer-list a:hover,
.landing-body .landing-footer .landing-footer-list a:focus {
    color: #ffffff;
}
.landing-body .landing-footer a[href^="mailto"] {
    color: #ffffff !important;
    font-weight: 500;
}

.landing-body .landing-main-footer {
    background-color: #111111;
    /* Drop the white hairline that visually split the main footer from the
       copyright strip — they should read as one continuous dark surface. */
    border-top: none;
}
.landing-body .landing-main-footer .text-muted {
    color: rgba(255, 255, 255, 0.55) !important;
}
.landing-body .landing-main-footer a {
    color: rgba(255, 255, 255, 0.7) !important;
    text-decoration: none;
}
.landing-body .landing-main-footer a:hover {
    color: #ffffff !important;
}

/* ---------- Footer newsletter signup ---------- */
.landing-body .landing-footer .tpi-news .input-group .form-control {
    background-color: rgba(255, 255, 255, 0.06);
    border-color: rgba(255, 255, 255, 0.18);
    color: #ffffff;
}
.landing-body .landing-footer .tpi-news .input-group .form-control::placeholder {
    color: rgba(255, 255, 255, 0.4);
}
.landing-body .landing-footer .tpi-news .input-group .form-control:focus {
    background-color: rgba(255, 255, 255, 0.1);
    border-color: #4a7d92;
    box-shadow: none;
    color: #ffffff;
}
.landing-body .landing-footer .tpi-news-consent,
.landing-body .landing-footer .tpi-news-consent a {
    color: rgba(255, 255, 255, 0.5) !important;
}
.landing-body .landing-footer .tpi-news-consent a {
    text-decoration: underline;
}
.landing-body .landing-footer .tpi-news-success {
    color: #6fcf97;
}
.landing-body .landing-footer .tpi-news-error,
.landing-body .landing-footer .tpi-news-error a {
    color: #f2b8b5 !important;
}
/* Sash's .btn-outline-light renders dark text (intended for light backgrounds);
   on the dark footer that's invisible. Make the "Send a message" CTA legible. */
.landing-body .landing-footer .btn-outline-light {
    color: #ffffff !important;
    border-color: rgba(255, 255, 255, 0.35) !important;
    background: transparent !important;
}
.landing-body .landing-footer .btn-outline-light:hover,
.landing-body .landing-footer .btn-outline-light:focus {
    color: #111111 !important;
    background: #ffffff !important;
    border-color: #ffffff !important;
}

/* On very narrow viewports, drop to the mark only so the hamburger + CTA fit. */
@media (max-width: 380px) {
    .landing-body .app-header .tpi-brand-wordmark { display: none; }
}

/* Buttons — keep Bootstrap primary, but enforce petrol on outline hover. */
.btn-outline-primary:hover {
    background: #0c3848;
    border-color: #0c3848;
    color: #ffffff;
}

/* ---------- Section eyebrow + petrol hairline (Sash pattern) ---------- */

.landing-body .landing-section-heading {
    color: #0c3848;
    font-weight: 600;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    font-size: 0.78rem;
}

/* Sash defines .landing-title as a petrol-gradient hairline; we use it
   centered under section eyebrows. Override for left-aligned sections too. */
.landing-body .landing-title {
    display: block;
    width: 56px;
    height: 3px;
    background: #0c3848;
    border-radius: 2px;
    opacity: 0.85;
    margin: 0.55rem auto 1.1rem;
}
.text-start .landing-title {
    margin-inline-start: 0;
}

/* ---------- Section rhythm: alternating backgrounds + breathing room ---------- */

.landing-body .section {
    padding-block: 5.5rem;
    position: relative;
}

@media (max-width: 767.98px) {
    .landing-body .section {
        padding-block: 3.5rem;
    }
}

/* Hairline at the boundary where the section-bg meets a white section,
   so the transition reads as a deliberate divider, not a paint accident. */
.landing-body .section-bg {
    background: #f6f7f8;
    border-block: 1px solid #ececec;
}

/* Stronger eyebrow visual: a tiny petrol dot before the label gives every
   section a clear "new chapter" marker. */
.landing-body .landing-section-heading::before {
    content: "";
    display: inline-block;
    width: 6px;
    height: 6px;
    background: #0c3848;
    border-radius: 50%;
    margin-right: 0.55rem;
    transform: translateY(-2px);
}

/* ---------- Scroll-reveal (softer than Sash's 3D flip) ---------- */

.landing-body .reveal {
    transform: translateY(24px);
    opacity: 0;
    transition: transform 0.7s ease, opacity 0.7s ease;
}
.landing-body .reveal.active {
    transform: translateY(0);
    opacity: 1;
}

/* ---------- Image placeholders (for Mike to swap from his collection) ---------- */

.tpi-image-placeholder {
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    background: #f4f6f8;
    border: 2px dashed rgba(12, 56, 72, 0.35);
    border-radius: 12px;
    color: #5b6470;
    text-align: center;
    padding: 2rem 1.5rem;
    overflow: hidden;
    aspect-ratio: 16 / 10;
}
.tpi-image-placeholder::before {
    content: "";
    position: absolute;
    inset: 0;
    background-image:
        linear-gradient(135deg, rgba(12, 56, 72, 0.04) 25%, transparent 25%, transparent 50%, rgba(12, 56, 72, 0.04) 50%, rgba(12, 56, 72, 0.04) 75%, transparent 75%, transparent);
    background-size: 24px 24px;
    pointer-events: none;
}
.tpi-image-placeholder > * { position: relative; }
.tpi-image-placeholder .ph-icon {
    font-size: 2.5rem;
    color: #0c3848;
    margin-bottom: 0.75rem;
    opacity: 0.55;
}
.tpi-image-placeholder .ph-label {
    font-weight: 600;
    color: #0c3848;
    margin-bottom: 0.25rem;
    max-width: 80%;
}
.tpi-image-placeholder .ph-dimensions {
    font-size: 0.85rem;
    color: #5b6470;
    font-family: ui-monospace, "SF Mono", Menlo, Consolas, monospace;
    opacity: 0.7;
}

/* Variants */
.tpi-image-placeholder--portrait { aspect-ratio: 3 / 4; }
.tpi-image-placeholder--square { aspect-ratio: 1 / 1; }
.tpi-image-placeholder--hero { aspect-ratio: 4 / 3; }
.tpi-image-placeholder--wide { aspect-ratio: 16 / 9; }

/* Hero photo: capped width so on wide desktops it doesn't dominate the
   hero or push to the wrapper's right edge. Right-aligns in its column. */
.tpi-hero-image {
    display: block;
    width: 100%;
    max-width: 520px;
    height: auto;
    aspect-ratio: 4 / 3;
    object-fit: cover;
    object-position: 30% center;   /* keep the wheel center, crop right edge */
    border-radius: 12px;
    box-shadow: 0 12px 32px rgba(0, 0, 0, 0.15);
    margin-inline-start: auto;     /* push to the right of its column */
}

/* ---------- Hero with background image (cinematic option) ---------- */

.tpi-hero-bg {
    position: relative;
    background-image: url('/assets/images/hero-1.jpg');
    background-size: cover;
    background-position: center;
    /* Full-bleed inside the wrapper — no border-radius, no shadow, no inset.
       Aspect target 1280x600 (~2.13:1). */
    min-height: 600px;
    display: flex;
    align-items: center;
    overflow: hidden;
}
/* Dark scrim, heavier on the left so text reads cleanly, fading toward the
   right so the wheel cars stay visible as the focal point. */
.tpi-hero-bg::before {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(
        to right,
        rgba(8, 36, 46, 0.92) 0%,
        rgba(8, 36, 46, 0.78) 35%,
        rgba(8, 36, 46, 0.15) 80%,
        rgba(8, 36, 46, 0) 100%
    );
}
.tpi-hero-bg-content {
    position: relative;
    z-index: 1;
    color: #ffffff;
    max-width: 640px;
    padding: 3.5rem 3rem;
}
.tpi-hero-bg-content h1 {
    color: #ffffff;
}
.tpi-hero-bg-content p {
    color: rgba(255, 255, 255, 0.92);
}
.tpi-hero-bg-content .tpi-hero-bg-footnote {
    color: rgba(255, 255, 255, 0.7);
}
/* Outline button inside the hero needs to be white, not petrol, for contrast.
   Bootstrap's btn-outline-light defaults to dark text — force white. Subtle
   semi-transparent dark backdrop so it stays visible even where the scrim
   has faded over the bright wheel cars. */
.tpi-hero-bg-content .btn-outline-light {
    border-color: rgba(255, 255, 255, 0.75) !important;
    color: #ffffff !important;
    background: rgba(0, 0, 0, 0.18);
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
}
.tpi-hero-bg-content .btn-outline-light:hover,
.tpi-hero-bg-content .btn-outline-light:focus {
    background: #ffffff !important;
    color: #0c3848 !important;
    border-color: #ffffff !important;
}

/* Mobile/tablet: heavier full-area scrim since the text overlays the whole
   image, and reduce min-height so the hero doesn't dwarf the content. */
@media (max-width: 767.98px) {
    .tpi-hero-bg {
        min-height: 480px;
        background-position: 65% center;
    }
    .tpi-hero-bg::before {
        background: linear-gradient(
            to bottom,
            rgba(8, 36, 46, 0.9) 0%,
            rgba(8, 36, 46, 0.7) 60%,
            rgba(8, 36, 46, 0.85) 100%
        );
    }
    .tpi-hero-bg-content {
        padding: 2.5rem 1.75rem;
        max-width: 100%;
    }
}

/* ---------- Capability graph (force-directed) ---------- */

.tpi-cap-graph-wrap {
    position: relative;
    /* Full-bleed across the entire white wrapper — sits outside .container. */
    margin-block: 1.5rem 1.5rem;
    background: radial-gradient(ellipse at center, rgba(12, 56, 72, 0.05), transparent 70%);
    padding: 1.5rem 0 0.5rem;
}

.tpi-cap-svg {
    display: block;
    width: 100%;
    height: auto;
    /* Slightly faded edges look better than crisp ones at this density. */
    font-family: var(--default-font-family);
}

.tpi-cap-edge {
    stroke: rgba(12, 56, 72, 0.18);
    stroke-width: 1.1;
    transition: stroke 0.2s ease, stroke-width 0.2s ease, opacity 0.2s ease;
}

.tpi-cap-svg.is-focused .tpi-cap-edge { opacity: 0.18; }
.tpi-cap-edge.is-active {
    stroke: #0c3848;
    stroke-width: 2;
    opacity: 1 !important;
}

.tpi-cap-node {
    cursor: pointer;
    transition: opacity 0.2s ease;
}
.tpi-cap-node:focus { outline: none; }

.tpi-cap-halo {
    fill: rgba(12, 56, 72, 0);
    transition: fill 0.2s ease, r 0.2s ease;
}
.tpi-cap-dot {
    fill: #0c3848;
    stroke: #ffffff;
    stroke-width: 2;
    transition: r 0.2s ease, fill 0.2s ease;
}
.tpi-cap-label {
    font-size: 14px;
    font-weight: 600;
    fill: #111111;
    pointer-events: none;
    transition: fill 0.2s ease, font-weight 0.2s ease;
}

/* Capability icon seated inside each dot (boxicons glyph via foreignObject). */
.tpi-cap-icon-fo {
    overflow: visible;
    /* Let hover/click fall through to the circle + link underneath. */
    pointer-events: none;
}
.tpi-cap-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
    line-height: 1;
    color: #ffffff;
}
.tpi-cap-icon i {
    line-height: 1;
}

/* Hover/focus states */
.tpi-cap-node:hover .tpi-cap-halo,
.tpi-cap-node.is-focus .tpi-cap-halo {
    fill: rgba(12, 56, 72, 0.15);
}
.tpi-cap-node:hover .tpi-cap-dot,
.tpi-cap-node.is-focus .tpi-cap-dot {
    fill: #0c3848;
    stroke: #ffffff;
    stroke-width: 3;
}
.tpi-cap-node.is-neighbor .tpi-cap-dot {
    fill: #0c3848;
}
.tpi-cap-svg.is-focused .tpi-cap-node.is-faded {
    opacity: 0.3;
}
.tpi-cap-svg.is-focused .tpi-cap-node.is-faded .tpi-cap-label {
    fill: #5b6470;
}
.tpi-cap-node.is-focus .tpi-cap-label {
    fill: #0c3848;
    font-weight: 700;
}

/* Tooltip — floats over the graph on hover, follows the cursor. */
.tpi-cap-graph-wrap #capability-graph {
    position: relative;
}
.tpi-cap-tooltip {
    position: absolute;
    z-index: 5;
    width: 300px;
    max-width: calc(100% - 24px);
    background: #ffffff;
    border: 1px solid rgba(12, 56, 72, 0.18);
    border-radius: 10px;
    box-shadow: 0 12px 28px rgba(12, 56, 72, 0.18);
    padding: 0.85rem 1rem 0.9rem;
    pointer-events: none;
    opacity: 0;
    transform: translateY(4px);
    transition: opacity 0.15s ease, transform 0.15s ease;
}
.tpi-cap-tooltip.is-visible {
    opacity: 1;
    transform: translateY(0);
}
.tpi-cap-tt-name {
    font-weight: 700;
    color: #0c3848;
    font-size: 0.95rem;
    line-height: 1.25;
    margin-bottom: 0.4rem;
}
.tpi-cap-tt-summary {
    font-size: 0.82rem;
    color: #444;
    line-height: 1.45;
    margin: 0 0 0.5rem;
}
.tpi-cap-tt-related {
    font-size: 0.75rem;
    line-height: 1.45;
    color: #5b6470;
    padding-top: 0.5rem;
    border-top: 1px solid rgba(12, 56, 72, 0.08);
}
.tpi-cap-tt-label {
    font-weight: 600;
    color: #0c3848;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    font-size: 0.7rem;
    display: block;
    margin-bottom: 0.2rem;
}
.tpi-cap-tt-cta {
    font-size: 0.78rem;
    font-weight: 600;
    color: #0c3848;
    margin-top: 0.55rem;
}

/* Legend / hint underneath. */
.tpi-cap-hint {
    text-align: center;
    color: #5b6470;
    font-size: 0.9rem;
    margin-top: 1rem;
}
.tpi-cap-hint strong { color: #0c3848; font-weight: 600; }

/* Hide the redundant 8-card grid on screens where the graph fits well. */
@media (min-width: 768px) {
    .tpi-cap-cards { display: none; }
}
/* On narrow viewports the graph gets too cramped — fall back to the cards. */
@media (max-width: 767.98px) {
    .tpi-cap-graph-wrap { display: none; }
}

/* ---------- Statistics band ---------- */

.tpi-stats {
    /* Near-black so the band reads as a distinct beat against the petrol
       gutters and the white content card — not just more petrol bleeding in. */
    background: #111111;
    color: #ffffff;
    padding-block: 3rem;
    position: relative;
}
.tpi-stats::before {
    /* Subtle petrol hairline at the top so the band still feels brand-aware. */
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 3px;
    background: linear-gradient(to right, transparent, #0c3848, transparent);
}
.tpi-stats .tpi-stat-value {
    font-size: clamp(2.5rem, 4vw, 3.5rem);
    font-weight: 700;
    line-height: 1;
    color: #ffffff;
    margin-bottom: 0.35rem;
    letter-spacing: -0.02em;
}
.tpi-stats .tpi-stat-suffix {
    font-size: 0.7em;
    margin-inline-start: 0.1em;
    opacity: 0.9;
}
.tpi-stats .tpi-stat-label {
    /* Petrol on near-black for label colour, keeps the brand thread visible. */
    font-size: 0.9rem;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: rgba(255, 255, 255, 0.65);
}

/* The statistics band is FULL-BLEED on the white wrapper — it should touch
   the wrapper's left/right edges without horizontal padding from .container. */
.landing-body .landing-page-wrapper > .tpi-stats {
    width: 100%;
}

/* ---------- Alternating image+text rows ---------- */

.tpi-alt-row {
    padding-block: 4rem 0;
}
.tpi-alt-row:last-of-type {
    padding-block-end: 4rem;
}
.tpi-alt-row .tpi-alt-eyebrow {
    color: #0c3848;
    font-weight: 600;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    font-size: 0.8rem;
    margin-bottom: 0.5rem;
}
.tpi-alt-row h3 {
    font-weight: 600;
    margin-bottom: 1rem;
}
.tpi-alt-row .tpi-alt-bullets {
    list-style: none;
    padding: 0;
    margin: 1.25rem 0 0;
}
.tpi-alt-row .tpi-alt-bullets li {
    padding-left: 1.5rem;
    position: relative;
    margin-bottom: 0.5rem;
    color: #5b6470;
}
.tpi-alt-row .tpi-alt-bullets li::before {
    content: "";
    position: absolute;
    left: 0;
    top: 0.55em;
    width: 8px;
    height: 8px;
    background: #0c3848;
    border-radius: 50%;
}

/* Interoperability cards */
.tpi-interop-card {
    position: relative;
    padding: 2rem 1.75rem 1.75rem;
    border: 1px solid #e6e6e6;
    border-radius: 12px;
    background: #ffffff;
    height: 100%;
    overflow: hidden;
    transition: border-color .18s ease, box-shadow .18s ease, transform .18s ease;
}

/* Subtle petrol tab at the top of each card. Reads as a visual "signature"
   that ties the trio together without shouting. */
.tpi-interop-card::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 3px;
    background: #0c3848;
    opacity: 0.35;
    transition: opacity .18s ease;
}

.tpi-interop-card:hover {
    border-color: #d4d4d4;
    box-shadow: 0 10px 30px rgba(12, 56, 72, 0.10);
    transform: translateY(-3px);
}
.tpi-interop-card:hover::before {
    opacity: 1;
}

/* Header row: icon + title block, horizontally aligned. */
.tpi-interop-head {
    display: flex;
    align-items: center;
    gap: 1rem;
    margin-bottom: 1.1rem;
}

.tpi-interop-icon {
    flex: 0 0 auto;
    width: 56px;
    height: 56px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 10px;
    background: rgba(12, 56, 72, 0.07);
    color: #0c3848;
    font-size: 1.7rem;
}

.tpi-interop-title {
    display: flex;
    flex-direction: column;
    gap: .15rem;
    min-width: 0;
}

.tpi-interop-card h3 {
    font-weight: 700;
    margin: 0;
    color: #0c3848;
    font-size: 1.4rem;
    line-height: 1.1;
    letter-spacing: -0.01em;
}

.tpi-interop-meta {
    font-size: .72rem;
    font-weight: 600;
    color: #0c3848;
    letter-spacing: .12em;
    text-transform: uppercase;
    opacity: 0.75;
}

.tpi-interop-card p {
    color: #5b6470;
    margin: 0;
    font-size: .94rem;
    line-height: 1.6;
}

@media (max-width: 575.98px) {
    .tpi-interop-card {
        padding: 1.5rem;
    }
    .tpi-interop-icon {
        width: 48px;
        height: 48px;
        font-size: 1.4rem;
    }
    .tpi-interop-card h3 {
        font-size: 1.2rem;
    }
}

/* ---------- Capabilities overview page ---------- */

.landing-body .section.tpi-cap-page-hero {
    padding-block: 3.5rem 2rem;
}

.tpi-cap-page-hero h1 {
    font-size: clamp(2rem, 3.5vw, 2.75rem);
    letter-spacing: -0.01em;
}

@media (max-width: 767.98px) {
    .landing-body .section.tpi-cap-page-hero {
        padding-block: 2.25rem 1.5rem;
    }
}

/* ---------- Demo / booking page ---------- */

/* Higher-specificity overrides so the demo page sets its own vertical
   rhythm (otherwise .landing-body .section's 5.5rem padding wins). */
.landing-body .section.tpi-demo-hero {
    padding-block: 3rem 1.25rem;
}
.landing-body .section.tpi-demo-form-section {
    padding-block: 2.5rem 5rem;
}

.tpi-demo-hero h1 {
    font-size: clamp(2rem, 3.5vw, 2.75rem);
    letter-spacing: -0.01em;
}

@media (max-width: 767.98px) {
    .landing-body .section.tpi-demo-hero {
        padding-block: 2rem 1rem;
    }
    .landing-body .section.tpi-demo-form-section {
        padding-block: 1.5rem 3rem;
    }
}

.tpi-demo-form-card {
    background: #ffffff;
    border: 1px solid #e6e6e6;
    border-radius: 14px;
    padding: 2.25rem;
    box-shadow: 0 6px 24px rgba(12, 56, 72, 0.05);
    position: relative;   /* containing block for the form's hidden honeypot field */
}

@media (max-width: 575.98px) {
    .tpi-demo-form-card {
        padding: 1.5rem;
    }
}

.tpi-demo-form .form-label {
    font-weight: 600;
    color: #111111;
    font-size: 0.85rem;
    letter-spacing: 0.01em;
    margin-bottom: 0.5rem;
    line-height: 1.3;
    /* Reserve room so labels with and without the required asterisk
       sit on the same baseline across columns. */
    min-height: 1.3em;
}

.tpi-demo-form .form-label .text-danger {
    color: #c43d3d !important;
    font-weight: 700;
    margin-left: 0.15rem;
}

.tpi-demo-form .form-control,
.tpi-demo-form .form-select {
    border: 1px solid #d8dde2;
    border-radius: 8px;
    padding: 0.65rem 0.9rem;
    font-size: 0.95rem;
    line-height: 1.45;
    height: 46px;
    color: #111111;
    background-color: #ffffff;
    transition: border-color .15s ease, box-shadow .15s ease;
}

.tpi-demo-form textarea.form-control {
    height: auto;
}

.tpi-demo-form .form-select {
    /* Bootstrap adds extra right padding for the chevron — keep it consistent. */
    padding-right: 2.5rem;
}

.tpi-demo-form .form-control:focus,
.tpi-demo-form .form-select:focus {
    border-color: #0c3848;
    box-shadow: 0 0 0 3px rgba(12, 56, 72, 0.12);
    outline: none;
}

.tpi-demo-form textarea.form-control {
    resize: vertical;
    min-height: 110px;
}

.tpi-demo-form.was-validated .form-control:invalid,
.tpi-demo-form.was-validated .form-select:invalid {
    border-color: #c43d3d;
    box-shadow: 0 0 0 3px rgba(196, 61, 61, 0.12);
}

.tpi-demo-success {
    text-align: center;
    padding: 2rem 1rem;
}

.tpi-demo-success-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 64px;
    height: 64px;
    border-radius: 50%;
    background: rgba(12, 56, 72, 0.08);
    color: #0c3848;
    font-size: 2rem;
    margin-bottom: 1rem;
}

.tpi-demo-aside {
    padding: 1rem 0 0 0;
}

@media (min-width: 992px) {
    .tpi-demo-aside {
        padding: 1rem 0 0 1.5rem;
        position: sticky;
        top: 2rem;
    }
}

.tpi-demo-aside .landing-title.text-start {
    margin-inline: 0 0;
}

.tpi-demo-expect {
    list-style: none;
    padding: 0;
    margin: 0 0 2rem;
}

.tpi-demo-expect li {
    display: flex;
    gap: 1rem;
    padding: 1.1rem 0;
    border-bottom: 1px solid #e6e6e6;
}

.tpi-demo-expect li:last-child {
    border-bottom: 0;
}

.tpi-demo-expect strong {
    display: block;
    color: #111111;
    font-weight: 600;
    margin-bottom: 0.25rem;
    font-size: 1rem;
}

.tpi-demo-expect p {
    color: #5b6470;
    font-size: 0.9rem;
    line-height: 1.55;
    margin: 0;
}

.tpi-demo-step {
    flex: 0 0 auto;
    width: 38px;
    height: 38px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    background: #0c3848;
    color: #ffffff;
    font-weight: 700;
    font-size: 0.82rem;
    letter-spacing: 0.04em;
}

.tpi-demo-nofit {
    background: #ffffff;
    border: 1px solid #e6e6e6;
    border-left: 3px solid #0c3848;
    border-radius: 8px;
    padding: 1.1rem 1.25rem;
}

.tpi-demo-nofit h4 {
    color: #0c3848;
    font-size: 0.95rem;
}

.tpi-demo-nofit p {
    font-size: 0.88rem;
    line-height: 1.5;
}

/* ---------- IAAPA show-week elements ---------- */

/* Hero subline noting booth meetings run on Eastern (show-floor) time. */
.tpi-iaapa-tzline {
    color: #0c3848;
    font-size: 0.95rem;
    font-weight: 500;
}

/* Drop-in panel that replaces the demo/partner calendar during the show. */
.tpi-iaapa-redirect {
    text-align: center;
    padding: 1.5rem 0.5rem;
}

.tpi-iaapa-redirect-badge {
    display: inline-block;
    background: #0c3848;
    color: #ffffff;
    font-size: 0.8rem;
    font-weight: 600;
    letter-spacing: 0.02em;
    padding: 0.35rem 0.8rem;
    border-radius: 999px;
}

.tpi-iaapa-redirect h3 {
    color: #0c3848;
}

.tpi-iaapa-redirect p {
    max-width: 32rem;
    margin-left: auto;
    margin-right: auto;
}

/* ---------- Step eyebrows inside the form card ---------- */

.tpi-demo-step-eyebrow {
    display: flex;
    align-items: baseline;
    gap: 0.65rem;
    color: #0c3848;
    font-size: 1.05rem;
    font-weight: 700;
    margin: 0 0 1.25rem;
    padding-bottom: 0.75rem;
    border-bottom: 1px solid #e6e6e6;
    letter-spacing: -0.005em;
}

.tpi-demo-step-eyebrow span {
    font-size: 0.7rem;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: #0c3848;
    background: rgba(12, 56, 72, 0.08);
    padding: 0.2rem 0.55rem;
    border-radius: 4px;
}

.tpi-demo-divider {
    border: 0;
    border-top: 1px dashed #d8dde2;
    margin: 2.25rem 0 1.75rem;
}

/* ---------- Calendar widget (static stub for Office 365 Bookings) ---------- */

.tpi-cal {
    border: 1px solid #e6e6e6;
    border-radius: 10px;
    padding: 0.85rem;
    background: #ffffff;
    height: 100%;
}

.tpi-cal-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 0.65rem;
    padding: 0 0.25rem;
}

.tpi-cal-month {
    font-weight: 700;
    color: #0c3848;
    font-size: 0.95rem;
}

.tpi-cal-nav {
    width: 28px;
    height: 28px;
    border: 0;
    background: transparent;
    color: #5b6470;
    border-radius: 6px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 1.15rem;
    line-height: 1;
}

.tpi-cal-nav:hover:not(:disabled) {
    background: rgba(12, 56, 72, 0.08);
    color: #0c3848;
}

.tpi-cal-nav:disabled {
    opacity: 0.35;
    cursor: not-allowed;
}

.tpi-cal-grid {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    gap: 0.2rem;
}

.tpi-cal-dayname {
    font-size: 0.7rem;
    font-weight: 700;
    color: #8a929c;
    text-align: center;
    padding: 0.25rem 0 0.4rem;
    letter-spacing: 0.05em;
}

.tpi-cal-day {
    aspect-ratio: 1;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 0.82rem;
    color: #111111;
    border-radius: 6px;
    cursor: pointer;
    transition: background .12s ease, color .12s ease, border-color .12s ease;
    border: 1.5px solid transparent;
}

.tpi-cal-day.is-empty {
    visibility: hidden;
    cursor: default;
}

.tpi-cal-day.is-past,
.tpi-cal-day.is-weekend {
    color: #c0c5cc;
    cursor: not-allowed;
}

.tpi-cal-day.is-available {
    background: rgba(12, 56, 72, 0.06);
    color: #0c3848;
    font-weight: 600;
}

.tpi-cal-day.is-available:hover {
    background: rgba(12, 56, 72, 0.16);
}

.tpi-cal-day.is-today {
    border-color: #0c3848;
    font-weight: 700;
    color: #0c3848;
}

.tpi-cal-day.is-selected {
    background: #0c3848;
    color: #ffffff;
    border-color: #0c3848;
}

.tpi-cal-slots {
    background: #f6f7f8;
    border: 1px solid #e6e6e6;
    border-radius: 10px;
    padding: 0.95rem 1rem 1rem;
    height: 100%;
    display: flex;
    flex-direction: column;
}

.tpi-cal-slots-head {
    font-weight: 700;
    color: #0c3848;
    font-size: 0.9rem;
    margin-bottom: 0.1rem;
}

.tpi-cal-slots-zone {
    font-size: 0.7rem;
    color: #8a929c;
    margin-bottom: 0.9rem;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    font-weight: 600;
}

.tpi-cal-slots-list {
    display: grid;
    gap: 0.45rem;
}

.tpi-cal-slot {
    width: 100%;
    text-align: center;
    background: #ffffff;
    border: 1px solid #d8dde2;
    border-radius: 6px;
    padding: 0.55rem 0.5rem;
    font-size: 0.85rem;
    font-weight: 600;
    color: #0c3848;
    cursor: pointer;
    transition: border-color .12s ease, background .12s ease, color .12s ease;
}

.tpi-cal-slot:hover {
    border-color: #0c3848;
    background: rgba(12, 56, 72, 0.06);
}

.tpi-cal-slot.is-selected {
    background: #0c3848;
    color: #ffffff;
    border-color: #0c3848;
}

.tpi-cal-note {
    font-size: 0.78rem;
    color: #5b6470;
    margin: 0.95rem 0 0;
    font-style: italic;
    line-height: 1.5;
}

/* =========================================================================
   Capability detail pages (/capabilities/*.html)
   Shared component set so all 24 deep pages read as one consistent system.
   ========================================================================= */

/* Compact petrol hero — no photo dependency, so every capability page can
   ship without bespoke imagery. */
.tpi-cap-hero {
    position: relative;
    background: linear-gradient(135deg, #0c3848 0%, #08242e 100%);
    color: #ffffff;
    overflow: hidden;
}
/* Sash's .landing-banner forces background-image:none !important + white bg;
   re-assert the petrol gradient at higher specificity so the hero isn't white.
   Fixed height (matching the homepage/overview hero) + vertical centering so
   every capability hero is the SAME height regardless of content length. */
.landing-body .landing-banner.tpi-cap-hero {
    background: linear-gradient(135deg, #0c3848 0%, #08242e 100%) !important;
    min-height: 600px;
    display: flex;
    align-items: center;
}
@media (max-width: 767.98px) {
    .landing-body .landing-banner.tpi-cap-hero { min-height: 480px; }
}
/* Photo hero variant — drop a background image behind a left-heavy petrol
   scrim so the white hero text stays legible. Reuses the pillar imagery; set
   the image per page via the --tpi-cap-hero-photo custom property, e.g.
   style="--tpi-cap-hero-photo: url('/assets/images/operations-safety.jpg')".
   Must come AFTER the rule above (equal specificity + !important → order wins). */
.landing-body .landing-banner.tpi-cap-hero--photo {
    background:
        linear-gradient(to right,
            rgba(8, 36, 46, 0.94) 0%,
            rgba(8, 36, 46, 0.82) 38%,
            rgba(8, 36, 46, 0.45) 78%,
            rgba(8, 36, 46, 0.35) 100%),
        var(--tpi-cap-hero-photo, none) #08242e center / cover no-repeat !important;
}
@media (max-width: 767.98px) {
    /* Narrow screens: text spans full width, so use a top-to-bottom scrim. */
    .landing-body .landing-banner.tpi-cap-hero--photo {
        background:
            linear-gradient(to bottom,
                rgba(8, 36, 46, 0.92) 0%,
                rgba(8, 36, 46, 0.84) 55%,
                rgba(8, 36, 46, 0.9) 100%),
            var(--tpi-cap-hero-photo, none) #08242e center / cover no-repeat !important;
    }
}
.tpi-cap-hero::after {
    content: "";
    position: absolute;
    inset: 0;
    background: radial-gradient(circle at 86% 18%, rgba(255, 255, 255, 0.07), transparent 46%);
    pointer-events: none;
}
.tpi-cap-hero__inner {
    position: relative;
    z-index: 1;
    max-width: 780px;
    padding: 4rem 0 4.25rem;
}
.tpi-cap-hero__eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    color: rgba(255, 255, 255, 0.72);
    font-size: 0.8rem;
    font-weight: 600;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    margin-bottom: 1.1rem;
}
.tpi-cap-hero__eyebrow a {
    color: rgba(255, 255, 255, 0.72);
    text-decoration: none;
    transition: color .15s ease;
}
.tpi-cap-hero__eyebrow a:hover { color: #ffffff; }
.tpi-cap-hero__icon {
    width: 64px;
    height: 64px;
    border-radius: 15px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: rgba(255, 255, 255, 0.12);
    color: #ffffff;
    font-size: 2rem;
    margin-bottom: 1.3rem;
}
.tpi-cap-hero h1 {
    color: #ffffff;
    font-weight: 700;
    margin-bottom: 1.05rem;
    line-height: 1.15;
}
.tpi-cap-hero__lede {
    color: rgba(255, 255, 255, 0.85);
    font-size: 1.18rem;
    line-height: 1.6;
    margin-bottom: 1.85rem;
}
.tpi-cap-hero .btn-outline-light {
    border-color: rgba(255, 255, 255, 0.75) !important;
    color: #ffffff !important;
    background: rgba(255, 255, 255, 0.06);
}
.tpi-cap-hero .btn-outline-light:hover,
.tpi-cap-hero .btn-outline-light:focus {
    background: #ffffff !important;
    color: #0c3848 !important;
    border-color: #ffffff !important;
}
@media (max-width: 767.98px) {
    .tpi-cap-hero__inner { padding: 3rem 0 3.25rem; }
    .tpi-cap-hero__lede { font-size: 1.05rem; }
}

/* Left-aligned section header used throughout the detail pages. */
.tpi-cap-sec-head {
    max-width: 720px;
    margin-bottom: 2.6rem;
}
.tpi-cap-sec-head h2 {
    font-weight: 600;
    margin-bottom: 0.75rem;
}
.tpi-cap-sec-head p {
    color: #5b6470;
    margin-bottom: 0;
    font-size: 1.02rem;
    line-height: 1.6;
}

/* "Why it matters" lead copy — slightly larger, warmer. */
.tpi-cap-lead p {
    font-size: 1.12rem;
    line-height: 1.75;
    color: #3a4149;
}
.tpi-cap-lead p:last-child { margin-bottom: 0; }

/* Feature cards — one per "Key features" subsection. */
.tpi-feature-card {
    height: 100%;
    border: 1px solid #e6e6e6;
    border-radius: 12px;
    background: #ffffff;
    padding: 1.6rem 1.6rem 1.4rem;
    transition: border-color .18s ease, box-shadow .18s ease, transform .18s ease;
}
.tpi-feature-card:hover {
    border-color: #0c3848;
    box-shadow: 0 10px 28px rgba(12, 56, 72, 0.09);
    transform: translateY(-2px);
}
.tpi-feature-card__icon {
    width: 44px;
    height: 44px;
    border-radius: 10px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: rgba(12, 56, 72, 0.08);
    color: #0c3848;
    font-size: 1.3rem;
    margin-bottom: 0.9rem;
}
.tpi-feature-card h5 {
    font-size: 1.05rem;
    font-weight: 700;
    color: #0c3848;
    margin-bottom: 0.75rem;
    letter-spacing: -0.005em;
}
.tpi-feature-card ul {
    list-style: none;
    padding: 0;
    margin: 0;
}
.tpi-feature-card li {
    position: relative;
    padding-left: 1.1rem;
    margin-bottom: 0.45rem;
    font-size: 0.9rem;
    color: #5b6470;
    line-height: 1.5;
}
.tpi-feature-card li:last-child { margin-bottom: 0; }
.tpi-feature-card li::before {
    content: "";
    position: absolute;
    left: 0;
    top: 0.5em;
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: #0c3848;
    opacity: 0.45;
}

/* Benefit-first lead line on a feature card — the outcome, above the bullets. */
.tpi-feature-card__benefit {
    color: #1f2a30;
    font-weight: 600;
    font-size: 0.96rem;
    line-height: 1.45;
    margin: 0 0 0.85rem;
}
/* Optional "Explore →" action at the foot of a feature card (used on the
   services overview, where each card links onward). */
.tpi-feature-card__link {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    margin-top: 1.1rem;
    color: #0c3848;
    font-weight: 600;
    font-size: 0.9rem;
    text-decoration: none;
}
.tpi-feature-card__link i { transition: transform .18s ease; }
.tpi-feature-card:hover .tpi-feature-card__link i { transform: translateX(3px); }

/* ---------- Legal / policy pages ---------- */
.tpi-legal h2 { margin-top: 2.25rem; margin-bottom: 0.75rem; font-size: 1.3rem; color: #0c3848; }
.tpi-legal h3 { margin-top: 1.25rem; margin-bottom: 0.5rem; color: #1f2a30; }
.tpi-legal p,
.tpi-legal li { color: #4b5563; line-height: 1.7; }
.tpi-legal ul { margin-bottom: 1.1rem; padding-left: 1.1rem; }
.tpi-legal li { margin-bottom: 0.4rem; }
.tpi-legal a { color: #0c3848; text-decoration: underline; }

/* "Why it matters" outcome highlights — scannable benefits beneath the lead,
   so the section reads as outcomes rather than one block of prose. */
.tpi-outcome { height: 100%; }
.tpi-outcome__icon {
    width: 48px;
    height: 48px;
    border-radius: 12px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: rgba(12, 56, 72, 0.08);
    color: #0c3848;
    font-size: 1.5rem;
    margin-bottom: 0.85rem;
}
.tpi-outcome__title {
    font-size: 1.05rem;
    font-weight: 700;
    color: #0c3848;
    margin-bottom: 0.35rem;
}
.tpi-outcome p {
    color: #5b6470;
    font-size: 0.94rem;
    line-height: 1.55;
    margin: 0;
}

/* Cited research stats in "Why it matters" — industry data, with sources. */
.tpi-statline__num {
    font-size: 2.5rem;
    font-weight: 800;
    color: #0c3848;
    line-height: 1;
    letter-spacing: -0.01em;
}
.tpi-statline__label {
    color: #5b6470;
    font-size: 0.95rem;
    line-height: 1.5;
    margin-top: 0.5rem;
}
.tpi-statband-sources {
    color: #8a929b;
    font-size: 0.78rem;
    line-height: 1.5;
    margin: 1.1rem 0 0;
}

/* "Specific to parks" — differentiator rows. */
.tpi-parks-list {
    background: #ffffff;
    border: 1px solid #e6e6e6;
    border-radius: 14px;
    padding: 0.5rem 1.75rem;
}
.tpi-parks-item {
    display: flex;
    gap: 1.1rem;
    padding: 1.3rem 0;
    border-bottom: 1px solid #ececec;
}
.tpi-parks-item:last-child { border-bottom: 0; }
.tpi-parks-item__mark {
    flex: 0 0 auto;
    width: 40px;
    height: 40px;
    border-radius: 50%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: rgba(12, 56, 72, 0.08);
    color: #0c3848;
    font-size: 1.2rem;
}
.tpi-parks-item__body strong {
    display: block;
    color: #0c3848;
    font-weight: 700;
    margin-bottom: 0.25rem;
    font-size: 1rem;
}
.tpi-parks-item__body p {
    margin: 0;
    color: #5b6470;
    font-size: 0.95rem;
    line-height: 1.55;
}

/* Sample workflow cards — numbered story steps. */
.tpi-workflow {
    height: 100%;
    border: 1px solid #e6e6e6;
    border-radius: 14px;
    background: #ffffff;
    padding: 1.85rem 1.85rem 1.6rem;
}
.tpi-workflow__title {
    display: flex;
    align-items: center;
    gap: 0.7rem;
    font-weight: 700;
    color: #0c3848;
    font-size: 1.12rem;
    margin-bottom: 1.2rem;
}
.tpi-workflow__title .tpi-workflow__tag {
    flex: 0 0 auto;
    font-size: 0.68rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: #0c3848;
    background: rgba(12, 56, 72, 0.08);
    border-radius: 5px;
    padding: 0.28rem 0.55rem;
}
.tpi-workflow > p {
    color: #3a4149;
    line-height: 1.65;
    margin-bottom: 1.1rem;
}
.tpi-workflow > p:last-child { margin-bottom: 0; }
.tpi-workflow ol {
    counter-reset: step;
    list-style: none;
    margin: 0;
    padding: 0;
}
.tpi-workflow ol li {
    position: relative;
    padding-left: 2.4rem;
    margin-bottom: 0.9rem;
    color: #3a4149;
    line-height: 1.55;
    font-size: 0.96rem;
}
.tpi-workflow ol li:last-child { margin-bottom: 0; }
.tpi-workflow ol li::before {
    counter-increment: step;
    content: counter(step);
    position: absolute;
    left: 0;
    top: -0.05em;
    width: 1.65rem;
    height: 1.65rem;
    border-radius: 50%;
    background: #0c3848;
    color: #ffffff;
    font-size: 0.8rem;
    font-weight: 700;
    display: flex;
    align-items: center;
    justify-content: center;
}

/* "Who uses it" — persona pills. */
.tpi-who {
    display: flex;
    flex-wrap: wrap;
    gap: 0.6rem;
    list-style: none;
    padding: 0;
    margin: 0;
}
.tpi-who li {
    background: #ffffff;
    border: 1px solid #e6e6e6;
    border-radius: 999px;
    padding: 0.5rem 1.05rem;
    font-size: 0.9rem;
    color: #3a4149;
    font-weight: 500;
}
.tpi-who li i {
    color: #0c3848;
    margin-right: 0.45rem;
}

/* External integrations — tidy chips. */
.tpi-integrations {
    display: flex;
    flex-wrap: wrap;
    gap: 0.7rem;
    list-style: none;
    padding: 0;
    margin: 0;
}
.tpi-integrations li {
    display: inline-flex;
    align-items: center;
    gap: 0.55rem;
    background: #ffffff;
    border: 1px solid #e6e6e6;
    border-radius: 10px;
    padding: 0.7rem 1.05rem;
    font-size: 0.92rem;
    color: #3a4149;
    line-height: 1.4;
}
.tpi-integrations li i {
    color: #0c3848;
    font-size: 1.05rem;
    flex: 0 0 auto;
}

/* Related-capability cards reuse .capability-card (homepage style). */
