﻿/*namespace SRParyavaran.Web.wwwroot.css
{
    public class srpepl_solutions
    {
    }
}
*/


/*
 * ═══════════════════════════════════════════════════════════════
 *  SRPEPL — Solutions Pages Global Stylesheet
 *  Link on every solution page AFTER srpepl-global.css:
 *
 *  <link rel="stylesheet" href="/assets/css/srpepl-global.css">
 *  <link rel="stylesheet" href="/assets/css/srpepl-solutions.css">
 *
 *  This file covers: layout, hero, side-nav, shared components
 *  (answer blocks, KPI strip, process flow, scope grid, diff cards,
 *  project cards, tables, tabs, FAQ, CTA, image placeholders),
 *  and all responsive breakpoints.
 *
 *  Page-specific overrides go in a <style> block on each page.
 * ═══════════════════════════════════════════════════════════════
 */

/* ── WIDTH NORMALISATION ────────────────────────────────────── */
/* Ensures hero, layout wrapper and footer share the same box model */
/*.page-hero,
.page-layout,
footer,
.site-footer {
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
}*/

/* ── PAGE LAYOUT ─────────────────────────────────────────────── */
/*.page-layout {
    display: grid;
    grid-template-columns: 220px minmax(0, 1fr);
    gap: 0;
    align-items: start;
}

.page-content {
    padding: 4rem 5vw 4rem 3vw;
    min-width: 0;
    width: 100%;
    box-sizing: border-box;
}*/

/* ── HERO ────────────────────────────────────────────────────── */
/* Base hero styles live in srpepl-global.css (.page-hero, .page-hero-title etc.)
   Solutions pages just need the standard inline style:
   style="position:relative;min-height:72vh;display:flex;align-items:center;width:100%;box-sizing:border-box" */

/* ── SIDE NAV ────────────────────────────────────────────────── */
/*.side-nav {
    position: sticky;
    top: 2rem;
    align-self: start;
    padding: 2rem 0 2rem 5vw;
}

.side-nav-title {
    font-family: var(--font-cond);
    font-size: .65rem;
    font-weight: 700;
    letter-spacing: .16em;
    text-transform: uppercase;
    color: var(--text-light);
    margin-bottom: .8rem;
}

.side-nav a {
    display: block;
    font-size: .8rem;
    color: var(--text-light);
    text-decoration: none;
    padding: .35rem 0 .35rem .9rem;
    border-left: 2px solid #dde3ef;
    margin-bottom: .1rem;
    transition: color .2s, border-color .2s;
}

    .side-nav a:hover,
    .side-nav a.active {
        color: var(--blue-accent);
        border-left-color: var(--blue-accent);
    }*/

/* ── SECTION DIVIDER ─────────────────────────────────────────── */
/*.sec-divider {
    height: 1px;
    background: linear-gradient(to right, var(--blue-accent), transparent);
    margin: 3.5rem 0;
    opacity: .25;
}*/

/* ── ANSWER BLOCKS ───────────────────────────────────────────── */
/*.answer-block {
    background: var(--panel-bg);
    border-left: 4px solid var(--blue-accent);
    border-radius: 0 12px 12px 0;
    padding: 1.6rem 1.8rem;
    margin-bottom: 2rem;
}

    .answer-block p {
        font-size: .97rem;
        color: var(--text-mid);
        line-height: 1.82;
    }

    .answer-block strong {
        color: var(--navy);
    }

    .answer-block.dark {
        background: var(--navy);
        border-left-color: var(--blue-stripe);
        margin-top: -1rem;
    }

        .answer-block.dark p {
            color: var(--lavender);
        }

        .answer-block.dark strong {
            color: var(--white);
        }*/

/* ── PULL QUOTE ──────────────────────────────────────────────── */
/*.pull-quote {
    font-size: 1.1rem;
    font-weight: 700;
    color: var(--navy);
    line-height: 1.5;
    border-left: 4px solid var(--blue-accent);
    padding-left: 1.3rem;
    margin: 2rem 0;
}*/

/* ── KPI STRIP ───────────────────────────────────────────────── */
/*.kpi-strip {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1rem;
    margin: 2.5rem 0;
}

.kpi-card {
    background: var(--white);
    border: 1px solid #dde3ef;
    border-radius: 12px;
    padding: 1.2rem 1.3rem;
    text-align: center;
    transition: transform .22s, box-shadow .22s;
}

    .kpi-card:hover {
        transform: translateY(-3px);
        box-shadow: 0 8px 22px rgba(15,27,53,.1);
    }

.kpi-val {
    font-family: var(--font-cond);
    font-size: 2rem;
    font-weight: 700;
    color: var(--blue-accent);
    line-height: 1;
}

.kpi-lbl {
    font-size: .74rem;
    color: var(--text-light);
    margin-top: .3rem;
    line-height: 1.4;
}*/

/* ── INLINE NOTE ─────────────────────────────────────────────── */
/*.inline-note {
    background: rgba(46,79,163,.06);
    border: 1px solid rgba(46,79,163,.15);
    border-radius: 8px;
    padding: .8rem 1.1rem;
    font-size: .8rem;
    color: var(--text-mid);
    line-height: 1.6;
    margin-top: 1rem;
}

    .inline-note strong {
        color: var(--navy);
    }

    .inline-note.dark {
        background: rgba(255,255,255,.05);
        border-color: rgba(74,127,212,.3);
    }

        .inline-note.dark strong {
            color: var(--white);
        }

        .inline-note.dark,
        .inline-note.dark a {
            color: var(--lavender);
        }*/

/* ── NOT INCLUDED BLOCK ──────────────────────────────────────── */
/*.not-included {
    background: rgba(200,80,60,.04);
    border: 1px solid rgba(200,80,60,.15);
    border-radius: 10px;
    padding: 1.2rem 1.4rem;
    margin-top: 1.5rem;
}

.not-included-title {
    font-family: var(--font-cond);
    font-size: .66rem;
    font-weight: 700;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: #aa3322;
    margin-bottom: .7rem;
}

.not-included li {
    font-size: .83rem;
    color: var(--text-mid);
    line-height: 1.6;
    padding: .2rem 0;
    border-bottom: 1px solid rgba(200,80,60,.1);
    list-style: none;
    display: flex;
    align-items: flex-start;
    gap: .5rem;
}

    .not-included li:last-child {
        border-bottom: none;
    }

    .not-included li::before {
        content: '✕';
        color: #cc4433;
        font-size: .7rem;
        margin-top: .18rem;
        flex-shrink: 0;
    }*/

/* ── IMAGE PLACEHOLDER ───────────────────────────────────────── */
/*.img-placeholder {
    width: 100%;
    background: var(--panel-bg);
    border: 2px dashed #c8d0e8;
    border-radius: 12px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: .6rem;
    color: var(--text-light);
    font-family: var(--font-cond);
    font-size: .72rem;
    font-weight: 700;
    letter-spacing: .12em;
    text-transform: uppercase;
    text-align: center;*/
   /* padding: 1rem;*/
/*}

    .img-placeholder svg {
        width: 32px;
        height: 32px;
        opacity: .4;
    }

.img-placeholder-sm {
    height: 220px;
}

.img-placeholder-md {
    height: 280px;
}

.img-placeholder-lg {
    height: 360px;
}*/

/* ── TABS (shared: config-tab, tech-tab both use same pattern) ── */
/*.sol-tabs {
    display: flex;
    gap: .5rem;
    margin-bottom: 2rem;
    flex-wrap: wrap;
}

.sol-tab {
    padding: .5rem 1.1rem;
    border-radius: 6px;
    font-family: var(--font-cond);
    font-size: .75rem;
    font-weight: 700;
    letter-spacing: .1em;
    text-transform: uppercase;
    cursor: pointer;
    border: 1.5px solid #dde3ef;
    background: var(--white);
    color: var(--text-mid);
    transition: background .2s, color .2s, border-color .2s;
}

    .sol-tab.active,
    .sol-tab:hover {
        background: var(--blue-accent);
        color: var(--white);
        border-color: var(--blue-accent);
    }

.sol-panel {
    display: none;
}

    .sol-panel.active {
        display: block;
    }*/

/* Dark-section tab variants */
/*.sol-tabs.dark .sol-tab {
    border-color: rgba(74,127,212,.3);
    background: rgba(255,255,255,.05);
    color: var(--lavender);
}

    .sol-tabs.dark .sol-tab.active,
    .sol-tabs.dark .sol-tab:hover {
        background: var(--blue-accent);
        color: var(--white);
        border-color: var(--blue-accent);
    }*/

/* ── TECH PANEL GRID ─────────────────────────────────────────── */
/*.tech-panel-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 2rem;
    align-items: start;
}

.tech-spec-list {
    display: flex;
    flex-direction: column;
    gap: .55rem;
}

.tech-spec-row {
    display: flex;
    gap: .8rem;
    font-size: .84rem;
    border-bottom: 1px solid #f0f2f8;
    padding-bottom: .5rem;
}

.tech-spec-key {
    color: var(--text-light);
    flex: 0 0 140px;
    font-size: .78rem;
}

.tech-spec-val {
    color: var(--navy);
    font-weight: 600;
    flex: 1;
}

.tech-apply-list {
    display: flex;
    flex-direction: column;
    gap: .4rem;
    margin-top: .8rem;
}

.tech-apply-item {
    font-size: .83rem;
    color: var(--text-mid);
    display: flex;
    gap: .5rem;
    align-items: flex-start;
    line-height: 1.5;
}

    .tech-apply-item::before {
        content: '·';
        color: var(--blue-accent);
        font-size: 1.2rem;
        line-height: 1;
        flex-shrink: 0;
        margin-top: -.05rem;
    }*/

/* Dark panel overrides */
/*.tech-spec-row.dark {
    border-bottom-color: rgba(74,127,212,.15);
}

.tech-spec-key.dark {
    color: var(--lavender);
}

.tech-spec-val.dark {
    color: var(--white);
}

.tech-apply-item.dark {
    color: var(--lavender);
}*/

/* ── PROCESS FLOW ────────────────────────────────────────────── */
/*.process-flow {
    display: flex;
    align-items: stretch;
    gap: 0;
    margin: 2rem 0;
    overflow-x: auto;
    padding-bottom: .5rem;
}

.pf-block {
    flex: 1;
    min-width: 140px;
    display: flex;
    flex-direction: column;
    position: relative;
}

    .pf-block:not(:last-child)::after {
        content: '';
        position: absolute;
        right: -1px;
        top: 50%;
        transform: translateY(-50%);
        width: 0;
        height: 0;
        border-top: 10px solid transparent;
        border-bottom: 10px solid transparent;
        border-left: 12px solid var(--blue-accent);
        z-index: 2;
    }

.pf-box {
    background: var(--navy-mid);
    border: 1px solid rgba(74,127,212,.25);
    border-radius: 10px;
    padding: 1.1rem 1rem;
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    transition: background .25s, border-color .25s;
}

.pf-block:hover .pf-box {
    background: var(--navy-light);
    border-color: rgba(74,127,212,.5);
}

.pf-num {
    font-family: var(--font-cond);
    font-size: .65rem;
    font-weight: 700;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: var(--blue-stripe);
    margin-bottom: .4rem;
}

.pf-icon {
    width: 36px;
    height: 36px;
    margin: 0 auto .7rem;
}

.pf-title {
    font-size: .88rem;
    font-weight: 700;
    color: var(--white);
    line-height: 1.2;
    margin-bottom: .35rem;
}

.pf-sub {
    font-size: .74rem;
    color: var(--lavender);
    line-height: 1.5;
}*/

/* ── CONFIG CONTEXT ──────────────────────────────────────────── */
/*.config-context {
    background: var(--navy-mid);
    border-radius: 12px;
    padding: 1.3rem 1.5rem;
    margin-bottom: 1.5rem;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1.2rem;
}

.ctx-block-title {
    font-family: var(--font-cond);
    font-size: .66rem;
    font-weight: 700;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: var(--blue-stripe);
    margin-bottom: .4rem;
}

.ctx-block-body {
    font-size: .82rem;
    color: var(--lavender);
    line-height: 1.6;
}*/

/* ── TABLES ──────────────────────────────────────────────────── */
/* Shared base */
/*.sol-table {
    width: 100%;
    border-collapse: collapse;
    font-size: .83rem;
    margin: 1.2rem 0;
}

    .sol-table thead tr {
        background: var(--navy);
        color: var(--white);
    }

    .sol-table th {
        padding: .65rem .9rem;
        text-align: left;
        font-weight: 600;
        font-size: .7rem;
        letter-spacing: .06em;
        text-transform: uppercase;
    }

    .sol-table tbody tr {
        border-bottom: 1px solid #e8ecf5;
        transition: background .18s;
    }

        .sol-table tbody tr:nth-child(even) {
            background: var(--off-white);
        }

        .sol-table tbody tr:hover {
            background: var(--panel-bg);
        }

    .sol-table td {
        padding: .6rem .9rem;
        color: var(--text-mid);
        vertical-align: middle;
    }

        .sol-table td:first-child {
            font-weight: 700;
            color: var(--navy);
        }

        .sol-table td:nth-child(2) {
            color: var(--blue-accent);
            font-weight: 600;
        }*/

/* Scrollable table wrapper */
/*.table-wrap {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    border-radius: 8px;
}*/

/* Comparison table variant */
/*.compare-table {
    width: 100%;
    border-collapse: collapse;
    font-size: .83rem;
    margin: 1.5rem 0;
}

    .compare-table thead tr {
        background: var(--navy);
        color: var(--white);
    }

    .compare-table th {
        padding: .7rem 1rem;
        text-align: left;
        font-weight: 700;
        font-size: .72rem;
        letter-spacing: .06em;
        text-transform: uppercase;
    }

        .compare-table th:first-child {
            width: 30%;
        }

    .compare-table tbody tr {
        border-bottom: 1px solid #e8ecf5;
        transition: background .18s;
    }

        .compare-table tbody tr:nth-child(even) {
            background: var(--off-white);
        }

        .compare-table tbody tr:hover {
            background: var(--panel-bg);
        }

    .compare-table td {
        padding: .7rem 1rem;
        font-size: .83rem;
        vertical-align: top;
        line-height: 1.5;
        color: var(--text-mid);
    }

        .compare-table td:first-child {
            font-weight: 600;
            color: var(--navy);
            font-size: .78rem;
        }

        .compare-table td.good {
            color: #1a7a4a;
            font-weight: 600;
        }

        .compare-table td.bad {
            color: #aa3322;
        }*/

/* ── SCOPE GRID ──────────────────────────────────────────────── */
/*.scope-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1rem;
    margin: 1.5rem 0;
}

.scope-item {
    background: var(--white);
    border: 1px solid #dde3ef;
    border-radius: 10px;
    padding: 1rem;
    display: flex;
    gap: .7rem;
    align-items: flex-start;
    transition: border-color .2s, transform .2s;
}

    .scope-item:hover {
        border-color: var(--blue-accent);
        transform: translateY(-2px);
    }

.scope-icon {
    width: 34px;
    height: 34px;
    border-radius: 7px;
    background: var(--panel-bg);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

    .scope-icon svg {
        width: 17px;
        height: 17px;
        color: var(--blue-accent);
    }

.scope-title {
    font-size: .84rem;
    font-weight: 700;
    color: var(--navy);
    margin-bottom: .18rem;
}

.scope-desc {
    font-size: .75rem;
    color: var(--text-light);
    line-height: 1.5;
}*/

/* ── DIFF / WHY CARDS ────────────────────────────────────────── */
/*.diff-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1.2rem;
}

.diff-card {
    background: var(--white);
    border: 1px solid #dde3ef;
    border-radius: 12px;
    padding: 1.5rem;
    display: flex;
    gap: 1rem;
    transition: transform .25s, box-shadow .25s;
}

    .diff-card:hover {
        transform: translateY(-4px);
        box-shadow: 0 10px 28px rgba(15,27,53,.1);
    }

    .diff-card.accent {
        border-color: var(--blue-accent);
        background: rgba(46,79,163,.03);
    }

.diff-num {
    font-family: var(--font-cond);
    font-size: 2.5rem;
    font-weight: 800;
    color: var(--panel-bg);
    line-height: 1;
    flex-shrink: 0;
    width: 44px;
    text-align: center;
}

.diff-title {
    font-size: .95rem;
    font-weight: 700;
    color: var(--navy);
    margin-bottom: .5rem;
    line-height: 1.3;
}

    .diff-title.accent {
        color: var(--blue-accent);
    }

.diff-body {
    font-size: .83rem;
    color: var(--text-mid);
    line-height: 1.7;
}*/

/* ── CONTRACT CARDS ──────────────────────────────────────────── */
/*.contract-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.2rem;
}

.contract-card {
    border-radius: 12px;
    padding: 1.5rem;
    border: 1px solid #dde3ef;
    background: var(--white);
    transition: transform .22s, box-shadow .22s;
}

    .contract-card:hover {
        transform: translateY(-4px);
        box-shadow: 0 10px 28px rgba(15,27,53,.1);
    }

.contract-badge {
    display: inline-block;
    padding: .18rem .6rem;
    border-radius: 4px;
    font-family: var(--font-cond);
    font-size: .66rem;
    font-weight: 700;
    letter-spacing: .1em;
    text-transform: uppercase;
    background: var(--panel-bg);
    color: var(--blue-accent);
    margin-bottom: .85rem;
}

.contract-title {
    font-size: .97rem;
    font-weight: 700;
    color: var(--navy);
    margin-bottom: .55rem;
    line-height: 1.3;
}

.contract-desc {
    font-size: .82rem;
    color: var(--text-mid);
    line-height: 1.65;
    margin-bottom: .8rem;
}

.contract-tag {
    font-size: .74rem;
    color: var(--text-light);
    display: flex;
    gap: .4rem;
    align-items: center;
    margin-top: .3rem;
}

    .contract-tag::before {
        content: '';
        width: 6px;
        height: 6px;
        border-radius: 50%;
        background: var(--blue-accent);
        flex-shrink: 0;
    }*/

/* ── PROJECT CARDS ───────────────────────────────────────────── */
/*.proj-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1.6rem;
}

.proj-card {
    border-radius: 14px;
    overflow: hidden;
    border: 1px solid #dde3ef;
    display: flex;
    flex-direction: column;
    transition: transform .28s, box-shadow .28s;
}

    .proj-card:hover {
        transform: translateY(-5px);
        box-shadow: 0 16px 40px rgba(15,27,53,.12);
    }

.proj-img-wrap {
    position: relative;
}

.proj-status {
    position: absolute;
    top: .85rem;
    right: .85rem;
    font-size: .66rem;
    font-weight: 700;
    letter-spacing: .07em;
    text-transform: uppercase;
    padding: .2rem .6rem;
    border-radius: 20px;
}

    .proj-status.commissioned {
        background: rgba(26,122,74,.85);
        color: #fff;
    }

    .proj-status.wip {
        background: rgba(46,79,163,.85);
        color: #fff;
    }

.proj-val {
    position: absolute;
    bottom: .85rem;
    left: 1rem;
    font-family: var(--font-cond);
    font-size: 1.45rem;
    font-weight: 700;
    color: #fff;
    text-shadow: 0 2px 8px rgba(0,0,0,.5);
}

.proj-body {
    padding: 1.3rem;
    flex: 1;
    display: flex;
    flex-direction: column;
    background: var(--white);
}

.proj-client {
    font-size: .68rem;
    font-weight: 700;
    letter-spacing: .1em;
    text-transform: uppercase;
    color: var(--blue-accent);
    margin-bottom: .35rem;
}

.proj-title {
    font-size: .98rem;
    font-weight: 700;
    color: var(--navy);
    line-height: 1.3;
    margin-bottom: .35rem;
}

.proj-meta {
    display: flex;
    flex-wrap: wrap;
    gap: .4rem .8rem;
    margin-bottom: .75rem;
}

.proj-meta-item {
    font-size: .74rem;
    color: var(--text-light);
    display: flex;
    align-items: center;
    gap: .25rem;
}

    .proj-meta-item svg {
        width: 12px;
        height: 12px;
    }

.proj-spec-row {
    display: flex;
    gap: .6rem;
    font-size: .8rem;
    border-bottom: 1px solid #f0f2f8;
    padding: .28rem 0;
}

.proj-spec-key {
    color: var(--text-light);
    flex: 0 0 80px;
    font-size: .74rem;
}

.proj-spec-val {
    color: var(--text-mid);
    flex: 1;
    font-weight: 600;
}

.proj-hook {
    font-size: .83rem;
    color: var(--text-mid);
    line-height: 1.65;
    margin-top: .75rem;
    flex: 1;
}

.proj-link {
    font-size: .8rem;
    font-weight: 700;
    color: var(--blue-accent);
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    gap: .3rem;
    margin-top: .9rem;
    transition: gap .2s;
}

    .proj-link:hover {
        gap: .55rem;
    }*/

/* ── GENERIC 3-COL CARD GRID ─────────────────────────────────── */
/*.card-grid-3 {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.2rem;
}

.gen-card {
    background: var(--white);
    border: 1px solid #dde3ef;
    border-radius: 12px;
    padding: 1.3rem;
    transition: transform .22s, box-shadow .22s, border-color .22s;
}

    .gen-card:hover {
        transform: translateY(-4px);
        box-shadow: 0 10px 28px rgba(15,27,53,.1);
        border-color: var(--blue-accent);
    }

.gen-card-icon {
    width: 42px;
    height: 42px;
    border-radius: 9px;
    background: var(--panel-bg);
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: .9rem;
}

    .gen-card-icon svg {
        width: 22px;
        height: 22px;
        color: var(--blue-accent);
    }

.gen-card-label {
    font-family: var(--font-cond);
    font-size: .66rem;
    font-weight: 700;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: var(--blue-accent);
    margin-bottom: .3rem;
}

.gen-card-title {
    font-size: .95rem;
    font-weight: 700;
    color: var(--navy);
    margin-bottom: .4rem;
    line-height: 1.3;
}

.gen-card-desc {
    font-size: .8rem;
    color: var(--text-mid);
    line-height: 1.65;
}*/

/* ── RELATED LINKS ───────────────────────────────────────────── */
/*.related-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1rem;
}

.related-card {
    background: var(--white);
    border: 1px solid #dde3ef;
    border-radius: 10px;
    padding: 1.2rem;
    text-decoration: none;
    display: flex;
    flex-direction: column;
    gap: .45rem;
    transition: transform .22s, box-shadow .22s, border-color .22s;
}

    .related-card:hover {
        transform: translateY(-3px);
        box-shadow: 0 8px 22px rgba(15,27,53,.09);
        border-color: var(--blue-accent);
    }

.related-label {
    font-family: var(--font-cond);
    font-size: .64rem;
    font-weight: 700;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: var(--blue-accent);
}

.related-title {
    font-size: .88rem;
    font-weight: 700;
    color: var(--navy);
    line-height: 1.3;
}

.related-desc {
    font-size: .76rem;
    color: var(--text-light);
    line-height: 1.5;
    flex: 1;
}

.related-arrow {
    font-size: .78rem;
    font-weight: 700;
    color: var(--blue-accent);
}*/

/* ── FAQ ─────────────────────────────────────────────────────── */
/*.faq-item {
    border-bottom: 1px solid #dde3ef;
}

.faq-question {
    width: 100%;
    background: none;
    border: none;
    text-align: left;
    padding: 1.1rem 0;
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-family: var(--font-body);
    font-size: .97rem;
    font-weight: 700;
    color: var(--navy);
    cursor: pointer;
    gap: 1rem;
    transition: color .2s;
}

    .faq-question:hover {
        color: var(--blue-accent);
    }

.faq-icon {
    width: 20px;
    height: 20px;
    flex-shrink: 0;
    border-radius: 50%;
    background: var(--panel-bg);
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background .2s, transform .3s;
}

    .faq-icon svg {
        width: 12px;
        height: 12px;
        stroke: var(--blue-accent);
    }

.faq-item.open .faq-icon {
    background: var(--blue-accent);
    transform: rotate(45deg);
}

    .faq-item.open .faq-icon svg {
        stroke: var(--white);
    }

.faq-answer {
    max-height: 0;
    overflow: hidden;
    transition: max-height .4s ease;
}

    .faq-answer p {
        font-size: .9rem;
        color: var(--text-mid);
        line-height: 1.75;
        padding-bottom: 1.1rem;
    }*/

/* ── BOTTOM CTA ──────────────────────────────────────────────── */
/*.bottom-cta {
    background: var(--navy);
    border-radius: 16px;
    padding: 3rem 3.5rem;
    text-align: center;
    position: relative;
    overflow: hidden;
    margin-top: 3rem;
}

    .bottom-cta::before {
        content: '';
        position: absolute;
        inset: 0;
        opacity: .06;
        background: url('https://images.unsplash.com/photo-1504711434969-e33886168f5c?w=1200&q=40') center/cover no-repeat;
    }

.bottom-cta-title {
    font-size: clamp(1.4rem, 2.5vw, 2.2rem);
    font-weight: 800;
    color: var(--white);
    margin-bottom: .7rem;
    position: relative;
}

.bottom-cta-sub {
    font-size: .95rem;
    color: var(--lavender);
    margin-bottom: 2rem;
    position: relative;
    max-width: 580px;
    margin-left: auto;
    margin-right: auto;
}

.bottom-cta-btns {
    display: flex;
    justify-content: center;
    gap: 1rem;
    flex-wrap: wrap;
    position: relative;
}*/

/* ── SHARED JS PATTERNS ──────────────────────────────────────── */
/* Shared reveal animation — add class .reveal to elements, JS adds .visible */
/*.reveal {
    opacity: 0;
    transform: translateY(24px);
    transition: opacity .7s ease, transform .7s ease;
}

    .reveal.visible {
        opacity: 1;
        transform: translateY(0);
    }*/

/* ═══════════════════════════════════════════════════════════════
   RESPONSIVE
   All breakpoints in one place. Page-specific overrides go inline.
═══════════════════════════════════════════════════════════════ */

/* ── ≤1024px — hide side-nav, stack layout ── */
/*@media (max-width: 1024px) {
    .side-nav {
        display: none !important;
    }

    .page-hero-breadcrumb {
        display: none !important;
    }

    .page-layout {
        grid-template-columns: 1fr;
    }

    .page-content {
        padding: 2rem 4vw;
    }*/
    /* Full-bleed coloured sections */
    /*.full-bleed-dark,
    .full-bleed-off,
    .full-bleed-panel {
        margin-left: -4vw !important;
        margin-right: -4vw !important;
        padding-left: 4vw !important;
        padding-right: 4vw !important;
    }
}*/

/* ── 641–1024px — tablet ── */
/*@media (min-width: 641px) and (max-width: 1024px) {
    .page-content {
        padding: 2.5rem 4vw;
    }

    .page-hero-title {
        font-size: 2.5rem !important;
    }

    .kpi-strip {
        grid-template-columns: repeat(2, 1fr);
    }

    .diff-grid {
        grid-template-columns: 1fr;
    }

    .proj-grid {
        grid-template-columns: 1fr;
    }

    .scope-grid {
        grid-template-columns: 1fr 1fr;
    }

    .contract-grid {
        grid-template-columns: 1fr;
    }

    .card-grid-3 {
        grid-template-columns: 1fr 1fr;
    }

    .related-grid {
        grid-template-columns: 1fr 1fr;
    }

    .tech-panel-grid {
        grid-template-columns: 1fr;
    }

    .config-context {
        grid-template-columns: 1fr;
    }

    .process-flow {
        overflow-x: auto;
        padding-bottom: 1rem;
    }

    .pf-block {
        min-width: 130px;
    }

    .compare-table {
        font-size: .76rem;
    }
}*/

/* ── ≤640px — mobile ── */
/*@media (max-width: 640px) {
    .page-content {
        padding: 1.5rem 4vw;
    }

    section[id] {
        padding-bottom: 2rem !important;
    }

    .sec-divider {
        margin: 1.8rem 0;
    }*/

    /* Hero */
    /*.page-hero {
        min-height: auto !important;
        padding: 2.8rem 4vw 2.2rem;
    }

    .page-hero-title {
        font-size: 1.9rem !important;
    }

    .page-hero-sub {
        font-size: .9rem !important;
    }

    .page-hero-lead {
        font-size: .86rem;
        line-height: 1.7;
    }

    .page-hero-meta {
        gap: .8rem !important;
        margin-top: 1.4rem !important;
        flex-wrap: wrap;
    }

    .page-hero-meta-item {
        font-size: .7rem;
        min-width: calc(50% - .4rem);
    }*/

    /* Section headers */
    /*.section-title {
        font-size: 1.45rem !important;
    }

    .section-lead {
        font-size: .88rem;
        margin-bottom: 1.4rem;
    }*/

    /* KPI */
    /*.kpi-strip {
        grid-template-columns: 1fr 1fr;
        gap: .65rem;
        margin: 1.4rem 0;
    }

    .kpi-val {
        font-size: 1.55rem;
    }

    .kpi-lbl {
        font-size: .66rem;
    }*/

    /* Grids all to 1 col */
    /*.diff-grid {
        grid-template-columns: 1fr !important;
    }

    .proj-grid {
        grid-template-columns: 1fr;
    }

    .scope-grid {
        grid-template-columns: 1fr;
    }

    .contract-grid {
        grid-template-columns: 1fr;
    }

    .card-grid-3 {
        grid-template-columns: 1fr;
    }

    .related-grid {
        grid-template-columns: 1fr 1fr;
    }

    .tech-panel-grid {
        grid-template-columns: 1fr;
    }

    .config-context {
        grid-template-columns: 1fr;
        gap: .8rem;
    }*/

    /* Cards */
    /*.diff-card {
        padding: 1.1rem;
    }

    .diff-num {
        font-size: 1.9rem;
        width: 34px;
    }*/

    /* Process flow — vertical on mobile */
    /*.process-flow {
        flex-direction: column !important;
        gap: .85rem;
        overflow-x: visible;
    }

    .pf-block::after {
        display: none !important;
    }

    .pf-block {
        min-width: unset;
    }

    .pf-box {
        flex-direction: row;
        align-items: flex-start;
        text-align: left;
        gap: .75rem;
        padding: .85rem;
    }

    .pf-icon {
        width: 26px;
        height: 26px;
        flex-shrink: 0;
        margin: 0;
    }

    .pf-num {
        display: none;
    }

    .pf-title {
        font-size: .82rem;
        margin-bottom: .15rem;
    }

    .pf-sub {
        font-size: .7rem;
    }*/

    /* Answer blocks */
    /*.answer-block {
        padding: 1rem 1.1rem;
        margin-bottom: 1.2rem;
    }

        .answer-block p {
            font-size: .86rem;
            line-height: 1.75;
        }*/

    /* Pull quote */
    /*.pull-quote {
        font-size: .93rem;
        padding-left: 1rem;
        margin: 1.3rem 0;
    }*/

    /* Tables */
    /*.table-wrap {
        border: 1px solid #e8ecf5;
        border-radius: 8px;
    }

    .sol-table {
        font-size: .74rem;
        min-width: 440px;
    }

        .sol-table th, .sol-table td {
            padding: .45rem .6rem;
        }

    .compare-table {
        min-width: 480px;
        font-size: .74rem;
    }

        .compare-table th, .compare-table td {
            padding: .45rem .7rem;
        }*/

    /* Spec rows */
    /*.tech-spec-key {
        flex: 0 0 100px;
    }*/

    /* FAQ */
    /*.faq-question {
        font-size: .86rem;
        padding: .85rem 0;
    }

    .faq-answer p {
        font-size: .82rem;
        line-height: 1.7;
    }*/

    /* Not included */
    /*.not-included li {
        font-size: .78rem;
    }*/

    /* Image placeholders */
    /*.img-placeholder-lg {
        height: 220px;
    }

    .img-placeholder-md {
        height: 200px;
    }

    .img-placeholder-sm {
        height: 160px;
    }*/

    /* Bottom CTA */
    /*.bottom-cta {
        padding: 1.8rem 1.2rem !important;
        border-radius: 10px;
    }

    .bottom-cta-title {
        font-size: 1.25rem !important;
    }

    .bottom-cta-btns {
        flex-direction: column;
        align-items: stretch;
        gap: .75rem;
    }

        .bottom-cta-btns .btn-pill {
            text-align: center;
        }
}*/

/* ── ≤400px ── */
/*@media (max-width: 400px) {
    .related-grid {
        grid-template-columns: 1fr;
    }

    .kpi-strip {
        grid-template-columns: 1fr 1fr;
    }
}*/





/*
 * ═══════════════════════════════════════════════════════════════
 *  SRPEPL — Solutions Pages Global Stylesheet
 *  Link on every solution page AFTER srpepl-global.css:
 *
 *  <link rel="stylesheet" href="/assets/css/srpepl-global.css">
 *  <link rel="stylesheet" href="/assets/css/srpepl-solutions.css">
 *
 *  This file covers: layout, hero, side-nav, shared components
 *  (answer blocks, KPI strip, process flow, scope grid, diff cards,
 *  project cards, tables, tabs, FAQ, CTA, image placeholders),
 *  and all responsive breakpoints.
 *
 *  Page-specific overrides go in a <style> block on each page.
 * ═══════════════════════════════════════════════════════════════
 */

/* ── WIDTH NORMALISATION ────────────────────────────────────── */
/* Ensures hero, layout wrapper and footer share the same box model */
.page-hero,
.page-layout,
footer,
.site-footer {
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
}

/* ── PAGE LAYOUT ─────────────────────────────────────────────── */
.page-layout {
    display: grid;
    grid-template-columns: 220px minmax(0, 1fr);
    gap: 0;
    align-items: start;
}

.page-content {
    padding: 4rem 5vw 4rem 3vw;
    min-width: 0;
    width: 100%;
    box-sizing: border-box;
}

/* ── HERO ────────────────────────────────────────────────────── */
/* Base hero styles live in srpepl-global.css (.page-hero, .page-hero-title etc.)
   Solutions pages just need the standard inline style:
   style="position:relative;min-height:72vh;display:flex;align-items:center;width:100%;box-sizing:border-box" */

/* ── SIDE NAV ────────────────────────────────────────────────── */
.side-nav {
    position: sticky;
    top: 2rem;
    align-self: start;
    padding: 2rem 0 2rem 5vw;
}

.side-nav-title {
    font-family: var(--font-cond);
    font-size: .65rem;
    font-weight: 700;
    letter-spacing: .16em;
    text-transform: uppercase;
    color: var(--text-light);
    margin-bottom: .8rem;
}

.side-nav a {
    display: block;
    font-size: .8rem;
    color: var(--text-light);
    text-decoration: none;
    padding: .35rem 0 .35rem .9rem;
    border-left: 2px solid #dde3ef;
    margin-bottom: .1rem;
    transition: color .2s, border-color .2s;
}

    .side-nav a:hover,
    .side-nav a.active {
        color: var(--blue-accent);
        border-left-color: var(--blue-accent);
    }

/* ── SECTION DIVIDER ─────────────────────────────────────────── */
.sec-divider {
    height: 1px;
    background: linear-gradient(to right, var(--blue-accent), transparent);
    margin: 1.5rem 0;
    opacity: .25;
}

/* ── ANSWER BLOCKS ───────────────────────────────────────────── */
.answer-block {
    background: var(--panel-bg);
    border-left: 4px solid var(--blue-accent);
    border-radius: 0 12px 12px 0;
    padding: 1.6rem 1.8rem;
    margin-bottom: 2rem;
}

    .answer-block p {
        font-size: .97rem;
        color: var(--text-mid);
        line-height: 1.82;
    }

    .answer-block strong {
        color: var(--navy);
    }

    .answer-block.dark {
        background: var(--navy);
        border-left-color: var(--blue-stripe);
        margin-top: -1rem;
    }

        .answer-block.dark p {
            color: var(--lavender);
        }

        .answer-block.dark strong {
            color: var(--white);
        }

/* ── PULL QUOTE ──────────────────────────────────────────────── */
.pull-quote {
    font-size: 1.1rem;
    font-weight: 700;
    color: var(--navy);
    line-height: 1.5;
    border-left: 4px solid var(--blue-accent);
    padding-left: 1.3rem;
    margin: 2rem 0;
}

/* ── KPI STRIP ───────────────────────────────────────────────── */
.kpi-strip {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1rem;
    margin: 2.5rem 0;
}

.kpi-card {
    background: var(--white);
    border: 1px solid #dde3ef;
    border-radius: 12px;
    padding: 1.2rem 1.3rem;
    text-align: center;
    transition: transform .22s, box-shadow .22s;
}

    .kpi-card:hover {
        transform: translateY(-3px);
        box-shadow: 0 8px 22px rgba(15,27,53,.1);
    }

.kpi-val {
    font-family: var(--font-cond);
    font-size: 2rem;
    font-weight: 700;
    color: var(--blue-accent);
    line-height: 1;
}

.kpi-lbl {
    font-size: .74rem;
    color: var(--text-light);
    margin-top: .3rem;
    line-height: 1.4;
}

/* ── INLINE NOTE ─────────────────────────────────────────────── */
.inline-note {
    background: rgba(46,79,163,.06);
    border: 1px solid rgba(46,79,163,.15);
    border-radius: 8px;
    padding: .8rem 1.1rem;
/*    font-size: .8rem;
*/    font-size: .9rem;
    color: var(--text-mid);
    line-height: 1.6;
    margin-top: 1rem;
}

    .inline-note strong {
        color: var(--navy);
    }

    .inline-note.dark {
        background: rgba(255,255,255,.05);
        border-color: rgba(74,127,212,.3);
    }

        .inline-note.dark strong {
            color: var(--white);
        }

        .inline-note.dark,
        .inline-note.dark a {
            color: var(--lavender);
        }

/* ── NOT INCLUDED BLOCK ──────────────────────────────────────── */
.not-included {
    background: rgba(200,80,60,.04);
    border: 1px solid rgba(200,80,60,.15);
    border-radius: 10px;
    padding: 1.2rem 1.4rem;
    margin-top: 1.5rem;
}

.not-included-title {
    font-family: var(--font-cond);
    font-size: .66rem;
    font-weight: 700;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: #aa3322;
    margin-bottom: .7rem;
}

.not-included li {
    font-size: .83rem;
    color: var(--text-mid);
    line-height: 1.6;
    padding: .2rem 0;
    border-bottom: 1px solid rgba(200,80,60,.1);
    list-style: none;
    display: flex;
    align-items: flex-start;
    gap: .5rem;
}

    .not-included li:last-child {
        border-bottom: none;
    }

    .not-included li::before {
        content: '✕';
        color: #cc4433;
        font-size: .7rem;
        margin-top: .18rem;
        flex-shrink: 0;
    }

/* ── IMAGE PLACEHOLDER ───────────────────────────────────────── */
.img-placeholder {
    width: 100%;
    background: var(--panel-bg);
    border: 2px dashed #c8d0e8;
    border-radius: 12px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: .6rem;
    color: var(--text-light);
    font-family: var(--font-cond);
    font-size: .72rem;
    font-weight: 700;
    letter-spacing: .12em;
    text-transform: uppercase;
    text-align: center;
  /*  padding: 1rem;*/
}

    .img-placeholder svg {
        width: 32px;
        height: 32px;
        opacity: .4;
    }

.img-placeholder-sm {
    height: 220px;
}

.img-placeholder-md {
    height: 280px;
}

.img-placeholder-lg {
    height: 360px;
}

/* ── TABS (shared: config-tab, tech-tab both use same pattern) ── */
.sol-tabs {
    display: flex;
    gap: .5rem;
    margin-bottom: 2rem;
    flex-wrap: wrap;
}

.sol-tab {
    padding: .5rem 1.1rem;
    border-radius: 6px;
    font-family: var(--font-cond);
    font-size: .75rem;
    font-weight: 700;
    letter-spacing: .1em;
    text-transform: uppercase;
    cursor: pointer;
    border: 1.5px solid #dde3ef;
    background: var(--white);
    color: var(--text-mid);
    transition: background .2s, color .2s, border-color .2s;
}

    .sol-tab.active,
    .sol-tab:hover {
        background: var(--blue-accent);
        color: var(--white);
        border-color: var(--blue-accent);
    }

.sol-panel {
    display: none;
}

    .sol-panel.active {
        display: block;
    }

/* Dark-section tab variants */
.sol-tabs.dark .sol-tab {
    border-color: rgba(74,127,212,.3);
    background: rgba(255,255,255,.05);
    color: var(--lavender);
}

    .sol-tabs.dark .sol-tab.active,
    .sol-tabs.dark .sol-tab:hover {
        background: var(--blue-accent);
        color: var(--white);
        border-color: var(--blue-accent);
    }

/* ── TECH PANEL GRID ─────────────────────────────────────────── */
.tech-panel-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 2rem;
    align-items: start;
}

.tech-spec-list {
    display: flex;
    flex-direction: column;
    gap: .55rem;
}

.tech-spec-row {
    display: flex;
    gap: .8rem;
    font-size: .84rem;
    border-bottom: 1px solid #f0f2f8;
    padding-bottom: .5rem;
}

.tech-spec-key {
    color: var(--text-light);
    flex: 0 0 140px;
    font-size: .78rem;
}

.tech-spec-val {
    color: var(--navy);
    font-weight: 600;
    flex: 1;
}

.tech-apply-list {
    display: flex;
    flex-direction: column;
    gap: .4rem;
    margin-top: .8rem;
}

.tech-apply-item {
    font-size: .83rem;
    color: var(--text-mid);
    display: flex;
    gap: .5rem;
    align-items: flex-start;
    line-height: 1.5;
}

    .tech-apply-item::before {
        content: '·';
        color: var(--blue-accent);
        font-size: 1.2rem;
        line-height: 1;
        flex-shrink: 0;
        margin-top: -.05rem;
    }

/* Dark panel overrides */
.tech-spec-row.dark {
    border-bottom-color: rgba(74,127,212,.15);
}

.tech-spec-key.dark {
    color: var(--lavender);
}

.tech-spec-val.dark {
    color: var(--white);
}

.tech-apply-item.dark {
    color: var(--lavender);
}

/* ── PROCESS FLOW ────────────────────────────────────────────── */
.process-flow {
    display: flex;
    align-items: stretch;
    gap: 0;
    margin: 2rem 0;
    overflow-x: auto;
    padding-bottom: .5rem;
}

.pf-block {
    flex: 1;
    min-width: 140px;
    display: flex;
    flex-direction: column;
    position: relative;
}

    .pf-block:not(:last-child)::after {
        content: '';
        position: absolute;
        right: -1px;
        top: 50%;
        transform: translateY(-50%);
        width: 0;
        height: 0;
        border-top: 10px solid transparent;
        border-bottom: 10px solid transparent;
        border-left: 12px solid var(--blue-accent);
        z-index: 2;
    }

.pf-box {
    background: var(--navy-mid);
    border: 1px solid rgba(74,127,212,.25);
    border-radius: 10px;
    padding: 1.1rem 1rem;
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    transition: background .25s, border-color .25s;
}

.pf-block:hover .pf-box {
    background: var(--navy-light);
    border-color: rgba(74,127,212,.5);
}

.pf-num {
    font-family: var(--font-cond);
    font-size: .65rem;
    font-weight: 700;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: var(--blue-stripe);
    margin-bottom: .4rem;
}

.pf-icon {
    width: 36px;
    height: 36px;
    margin: 0 auto .7rem;
}

.pf-title {
    font-size: .88rem;
    font-weight: 700;
    color: var(--white);
    line-height: 1.2;
    margin-bottom: .35rem;
}

.pf-sub {
    font-size: .74rem;
    color: var(--lavender);
    line-height: 1.5;
}

/* ── CONFIG CONTEXT ──────────────────────────────────────────── */
.config-context {
    background: var(--navy-mid);
    border-radius: 12px;
    padding: 1.3rem 1.5rem;
    margin-bottom: 1.5rem;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1.2rem;
}

.ctx-block-title {
    font-family: var(--font-cond);
    font-size: .66rem;
    font-weight: 700;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: var(--blue-stripe);
    margin-bottom: .4rem;
}

.ctx-block-body {
    font-size: .82rem;
    color: var(--lavender);
    line-height: 1.6;
}

/* ── TABLES ──────────────────────────────────────────────────── */
/* Shared base */
.sol-table {
    width: 100%;
    border-collapse: collapse;
    font-size: .83rem;
    margin: 1.2rem 0;
}

    .sol-table thead tr {
        background: var(--navy);
        color: var(--white);
    }

    .sol-table th {
        padding: .65rem .9rem;
        text-align: left;
        font-weight: 600;
        font-size: .7rem;
        letter-spacing: .06em;
        text-transform: uppercase;
    }

    .sol-table tbody tr {
        border-bottom: 1px solid #e8ecf5;
        transition: background .18s;
    }

        .sol-table tbody tr:nth-child(even) {
            background: var(--off-white);
        }

        .sol-table tbody tr:hover {
            background: var(--panel-bg);
        }

    .sol-table td {
        padding: .6rem .9rem;
        color: var(--text-mid);
        vertical-align: middle;
    }

        .sol-table td:first-child {
            font-weight: 700;
            color: var(--navy);
        }

        .sol-table td:nth-child(2) {
            color: var(--blue-accent);
            font-weight: 600;
        }

/* Scrollable table wrapper */
.table-wrap {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    border-radius: 8px;
}

/* Comparison table variant */
.compare-table {
    width: 100%;
    border-collapse: collapse;
    font-size: .83rem;
    margin: 1.5rem 0;
}

    .compare-table thead tr {
        background: var(--navy);
        color: var(--white);
    }

    .compare-table th {
        padding: .7rem 1rem;
        text-align: left;
        font-weight: 700;
        font-size: .72rem;
        letter-spacing: .06em;
        text-transform: uppercase;
    }

        .compare-table th:first-child {
            width: 30%;
        }

    .compare-table tbody tr {
        border-bottom: 1px solid #e8ecf5;
        transition: background .18s;
    }

        .compare-table tbody tr:nth-child(even) {
            background: var(--off-white);
        }

        .compare-table tbody tr:hover {
            background: var(--panel-bg);
        }

    .compare-table td {
        padding: .7rem 1rem;
        font-size: .83rem;
        vertical-align: top;
        line-height: 1.5;
        color: var(--text-mid);
    }

        .compare-table td:first-child {
            font-weight: 600;
            color: var(--navy);
            font-size: .78rem;
        }

        .compare-table td.good {
            color: #1a7a4a;
            font-weight: 600;
        }

        .compare-table td.bad {
            color: #aa3322;
        }

/* ── SCOPE GRID ──────────────────────────────────────────────── */
.scope-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1rem;
    margin: 1.5rem 0;
}

.scope-item {
    background: var(--white);
    border: 1px solid #dde3ef;
    border-radius: 10px;
    padding: 1rem;
    display: flex;
    gap: .7rem;
    align-items: flex-start;
    transition: border-color .2s, transform .2s;
}

    .scope-item:hover {
        border-color: var(--blue-accent);
        transform: translateY(-2px);
    }

.scope-icon {
    width: 34px;
    height: 34px;
    border-radius: 7px;
    background: var(--panel-bg);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

    .scope-icon svg {
        width: 17px;
        height: 17px;
        color: var(--blue-accent);
    }

.scope-title {
    font-size: .84rem;
    font-weight: 700;
    color: var(--navy);
    margin-bottom: .18rem;
}

.scope-desc {
    font-size: .75rem;
    color: var(--text-light);
    line-height: 1.5;
}

/* ── DIFF / WHY CARDS ────────────────────────────────────────── */
.diff-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1.2rem;
}

.diff-card {
    background: var(--white);
    border: 1px solid #dde3ef;
    border-radius: 12px;
    padding: 1.5rem;
    display: flex;
    gap: 1rem;
    transition: transform .25s, box-shadow .25s;
}

    .diff-card:hover {
        transform: translateY(-4px);
        box-shadow: 0 10px 28px rgba(15,27,53,.1);
    }

    .diff-card.accent {
        border-color: var(--blue-accent);
        background: rgba(46,79,163,.03);
    }

.diff-num {
    font-family: var(--font-cond);
    font-size: 2.5rem;
    font-weight: 800;
    color: var(--panel-bg);
    line-height: 1;
    flex-shrink: 0;
    width: 44px;
    text-align: center;
}

.diff-title {
    font-size: .95rem;
    font-weight: 700;
    color: var(--navy);
    margin-bottom: .5rem;
    line-height: 1.3;
}

    .diff-title.accent {
        color: var(--blue-accent);
    }

.diff-body {
    font-size: .83rem;
    color: var(--text-mid);
    line-height: 1.7;
}

/* ── CONTRACT CARDS ──────────────────────────────────────────── */
.contract-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.2rem;
}

.contract-card {
    border-radius: 12px;
    padding: 1.5rem;
    border: 1px solid #dde3ef;
    background: var(--white);
    transition: transform .22s, box-shadow .22s;
}

    .contract-card:hover {
        transform: translateY(-4px);
        box-shadow: 0 10px 28px rgba(15,27,53,.1);
    }

.contract-badge {
    display: inline-block;
    padding: .18rem .6rem;
    border-radius: 4px;
    font-family: var(--font-cond);
    font-size: .66rem;
    font-weight: 700;
    letter-spacing: .1em;
    text-transform: uppercase;
    background: var(--panel-bg);
    color: var(--blue-accent);
    margin-bottom: .85rem;
}

.contract-title {
    font-size: .97rem;
    font-weight: 700;
    color: var(--navy);
    margin-bottom: .55rem;
    line-height: 1.3;
}

.contract-desc {
    font-size: .82rem;
    color: var(--text-mid);
    line-height: 1.65;
    margin-bottom: .8rem;
}

.contract-tag {
    font-size: .74rem;
    color: var(--text-light);
    display: flex;
    gap: .4rem;
    align-items: center;
    margin-top: .3rem;
}

    .contract-tag::before {
        content: '';
        width: 6px;
        height: 6px;
        border-radius: 50%;
        background: var(--blue-accent);
        flex-shrink: 0;
    }

/* ── PROJECT CARDS ───────────────────────────────────────────── */
.proj-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1.6rem;
}

.proj-card {
    border-radius: 14px;
    overflow: hidden;
    border: 1px solid #dde3ef;
    display: flex;
    flex-direction: column;
    transition: transform .28s, box-shadow .28s;
}

    .proj-card:hover {
        transform: translateY(-5px);
        box-shadow: 0 16px 40px rgba(15,27,53,.12);
    }

.proj-img-wrap {
    position: relative;
}

.proj-status {
    position: absolute;
    top: .85rem;
    right: .85rem;
    font-size: .66rem;
    font-weight: 700;
    letter-spacing: .07em;
    text-transform: uppercase;
    padding: .2rem .6rem;
    border-radius: 20px;
}

    .proj-status.commissioned {
        background: rgba(26,122,74,.85);
        color: #fff;
    }

    .proj-status.wip {
        background: rgba(46,79,163,.85);
        color: #fff;
    }

.proj-val {
    position: absolute;
    bottom: .85rem;
    left: 1rem;
    font-family: var(--font-cond);
    font-size: 1.45rem;
    font-weight: 700;
    color: #fff;
    text-shadow: 0 2px 8px rgba(0,0,0,.5);
}

.proj-body {
    padding: 1.3rem;
    flex: 1;
    display: flex;
    flex-direction: column;
    background: var(--white);
}

.proj-client {
    font-size: .68rem;
    font-weight: 700;
    letter-spacing: .1em;
    text-transform: uppercase;
    color: var(--blue-accent);
    margin-bottom: .35rem;
}

.proj-title {
    font-size: .98rem;
    font-weight: 700;
    color: var(--navy);
    line-height: 1.3;
    margin-bottom: .35rem;
}

.proj-meta {
    display: flex;
    flex-wrap: wrap;
    gap: .4rem .8rem;
    margin-bottom: .75rem;
}

.proj-meta-item {
    font-size: .74rem;
    color: var(--text-light);
    display: flex;
    align-items: center;
    gap: .25rem;
}

    .proj-meta-item svg {
        width: 12px;
        height: 12px;
    }

.proj-spec-row {
    display: flex;
    gap: .6rem;
    font-size: .8rem;
    border-bottom: 1px solid #f0f2f8;
    padding: .28rem 0;
}

.proj-spec-key {
    color: var(--text-light);
    flex: 0 0 80px;
    font-size: .74rem;
}

.proj-spec-val {
    color: var(--text-mid);
    flex: 1;
    font-weight: 600;
}

.proj-hook {
    font-size: .83rem;
    color: var(--text-mid);
    line-height: 1.65;
    margin-top: .75rem;
    flex: 1;
}

.proj-link {
    font-size: .8rem;
    font-weight: 700;
    color: var(--blue-accent);
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    gap: .3rem;
    margin-top: .9rem;
    transition: gap .2s;
}

    .proj-link:hover {
        gap: .55rem;
    }

/* ── GENERIC 3-COL CARD GRID ─────────────────────────────────── */
.card-grid-3 {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.2rem;
}

.gen-card {
    background: var(--white);
    border: 1px solid #dde3ef;
    border-radius: 12px;
    padding: 1.3rem;
    transition: transform .22s, box-shadow .22s, border-color .22s;
}

    .gen-card:hover {
        transform: translateY(-4px);
        box-shadow: 0 10px 28px rgba(15,27,53,.1);
        border-color: var(--blue-accent);
    }

.gen-card-icon {
    width: 42px;
    height: 42px;
    border-radius: 9px;
    background: var(--panel-bg);
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: .9rem;
}

    .gen-card-icon svg {
        width: 22px;
        height: 22px;
        color: var(--blue-accent);
    }

.gen-card-label {
    font-family: var(--font-cond);
    font-size: .66rem;
    font-weight: 700;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: var(--blue-accent);
    margin-bottom: .3rem;
}

.gen-card-title {
    font-size: .95rem;
    font-weight: 700;
    color: var(--navy);
    margin-bottom: .4rem;
    line-height: 1.3;
}

.gen-card-desc {
    font-size: .8rem;
    color: var(--text-mid);
    line-height: 1.65;
}

/* ── RELATED LINKS ───────────────────────────────────────────── */
.related-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1rem;
}

.related-card {
    background: var(--white);
    border: 1px solid #dde3ef;
    border-radius: 10px;
    padding: 1.2rem;
    text-decoration: none;
    display: flex;
    flex-direction: column;
    gap: .45rem;
    transition: transform .22s, box-shadow .22s, border-color .22s;
}

    .related-card:hover {
        transform: translateY(-3px);
        box-shadow: 0 8px 22px rgba(15,27,53,.09);
        border-color: var(--blue-accent);
    }

.related-label {
    font-family: var(--font-cond);
    font-size: .64rem;
    font-weight: 700;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: var(--blue-accent);
}

.related-title {
    font-size: .88rem;
    font-weight: 700;
    color: var(--navy);
    line-height: 1.3;
}

.related-desc {
    font-size: .76rem;
    color: var(--text-light);
    line-height: 1.5;
    flex: 1;
}

.related-arrow {
    font-size: .78rem;
    font-weight: 700;
    color: var(--blue-accent);
}

/* ── FAQ ─────────────────────────────────────────────────────── */
.faq-item {
    border-bottom: 1px solid #dde3ef;
}

.faq-question {
    width: 100%;
    background: none;
    border: none;
    text-align: left;
    padding: 1.1rem 0;
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-family: var(--font-body);
    font-size: .97rem;
    font-weight: 700;
    color: var(--navy);
    cursor: pointer;
    gap: 1rem;
    transition: color .2s;
}

    .faq-question:hover {
        color: var(--blue-accent);
    }

.faq-icon {
    width: 20px;
    height: 20px;
    flex-shrink: 0;
    border-radius: 50%;
    background: var(--panel-bg);
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background .2s, transform .3s;
}

    .faq-icon svg {
        width: 12px;
        height: 12px;
        stroke: var(--blue-accent);
    }

.faq-item.open .faq-icon {
    background: var(--blue-accent);
    transform: rotate(45deg);
}

    .faq-item.open .faq-icon svg {
        stroke: var(--white);
    }

.faq-answer {
    max-height: 0;
    overflow: hidden;
    transition: max-height .4s ease;
}

    .faq-answer p {
        font-size: .9rem;
        color: var(--text-mid);
        line-height: 1.75;
        padding-bottom: 1.1rem;
    }

/* ── BOTTOM CTA ──────────────────────────────────────────────── */
.bottom-cta {
    background: var(--navy);
    border-radius: 16px;
    padding: 3rem 3.5rem;
    text-align: center;
    position: relative;
    overflow: hidden;
    margin-top: 3rem;
}

    .bottom-cta::before {
        content: '';
        position: absolute;
        inset: 0;
        opacity: .06;
        background: url('https://images.unsplash.com/photo-1504711434969-e33886168f5c?w=1200&q=40') center/cover no-repeat;
    }

.bottom-cta-title {
    font-size: clamp(1.4rem, 2.5vw, 2.2rem);
    font-weight: 800;
    color: var(--white);
    margin-bottom: .7rem;
    position: relative;
}

.bottom-cta-sub {
    font-size: .95rem;
    color: var(--lavender);
    margin-bottom: 2rem;
    position: relative;
    max-width: 580px;
    margin-left: auto;
    margin-right: auto;
}

.bottom-cta-btns {
    display: flex;
    justify-content: center;
    gap: 1rem;
    flex-wrap: wrap;
    position: relative;
}

/* ── SHARED JS PATTERNS ──────────────────────────────────────── */
/* Shared reveal animation — add class .reveal to elements, JS adds .visible */
.reveal {
    opacity: 0;
    transform: translateY(24px);
    transition: opacity .7s ease, transform .7s ease;
}

    .reveal.visible {
        opacity: 1;
        transform: translateY(0);
    }

/* ═══════════════════════════════════════════════════════════════
   RESPONSIVE
   All breakpoints in one place. Page-specific overrides go inline.
═══════════════════════════════════════════════════════════════ */

/* ── ≤1024px — hide side-nav, stack layout ── */
@media (max-width: 1024px) {
    .side-nav {
        display: none !important;
    }

    .page-hero-breadcrumb {
        display: none !important;
    }

    .page-layout {
        grid-template-columns: 1fr;
    }

    .page-content {
        padding: 2rem 4vw;
    }
    /* Full-bleed coloured sections */
    .full-bleed-dark,
    .full-bleed-off,
    .full-bleed-panel {
        margin-left: -4vw !important;
        margin-right: -4vw !important;
        padding-left: 4vw !important;
        padding-right: 4vw !important;
    }
}

/* ── 641–1024px — tablet ── */
@media (min-width: 641px) and (max-width: 1024px) {
    .page-content {
        padding: 2.5rem 4vw;
    }

    .page-hero-title {
        font-size: 2.5rem !important;
    }

    .kpi-strip {
        grid-template-columns: repeat(2, 1fr);
    }

    .diff-grid {
        grid-template-columns: 1fr;
    }

    .proj-grid {
        grid-template-columns: 1fr;
    }

    .scope-grid {
        grid-template-columns: 1fr 1fr;
    }

    .contract-grid {
        grid-template-columns: 1fr;
    }

    .card-grid-3 {
        grid-template-columns: 1fr 1fr;
    }

    .related-grid {
        grid-template-columns: 1fr 1fr;
    }

    .tech-panel-grid {
        grid-template-columns: 1fr;
    }

    .config-context {
        grid-template-columns: 1fr;
    }

    .process-flow {
        overflow-x: auto;
        padding-bottom: 1rem;
    }

    .pf-block {
        min-width: 130px;
    }

    .compare-table {
        font-size: .76rem;
    }
}

/* ── ≤640px — mobile ── */
@media (max-width: 640px) {
    .page-content {
        padding: 1.5rem 4vw;
    }

    section[id] {
        padding-bottom: 2rem !important;
    }

    .sec-divider {
        margin: 1.8rem 0;
    }

    /* Hero */
    .page-hero {
        min-height: auto !important;
        padding: 2.8rem 4vw 2.2rem;
    }

    .page-hero-title {
        font-size: 1.9rem !important;
    }

    .page-hero-sub {
        font-size: .9rem !important;
    }

    .page-hero-lead {
        font-size: .86rem;
        line-height: 1.7;
    }

    .page-hero-meta {
        gap: .8rem !important;
        margin-top: 1.4rem !important;
        flex-wrap: wrap;
    }

    .page-hero-meta-item {
        font-size: .7rem;
        min-width: calc(50% - .4rem);
    }

    /* Section headers */
    .section-title {
        font-size: 1.45rem !important;
    }

    .section-lead {
        font-size: .88rem;
        margin-bottom: 1.4rem;
    }

    /* KPI */
    .kpi-strip {
        grid-template-columns: 1fr 1fr;
        gap: .65rem;
        margin: 1.4rem 0;
    }

    .kpi-val {
        font-size: 1.55rem;
    }

    .kpi-lbl {
        font-size: .66rem;
    }

    /* Grids all to 1 col */
    .diff-grid {
        grid-template-columns: 1fr !important;
    }

    .proj-grid {
        grid-template-columns: 1fr;
    }

    .scope-grid {
        grid-template-columns: 1fr;
    }

    .contract-grid {
        grid-template-columns: 1fr;
    }

    .card-grid-3 {
        grid-template-columns: 1fr;
    }

    .related-grid {
        grid-template-columns: 1fr 1fr;
    }

    .tech-panel-grid {
        grid-template-columns: 1fr;
    }

    .config-context {
        grid-template-columns: 1fr;
        gap: .8rem;
    }

    /* Cards */
    .diff-card {
        padding: 1.1rem;
    }

    .diff-num {
        font-size: 1.9rem;
        width: 34px;
    }

    /* Process flow — vertical on mobile */
    .process-flow {
        flex-direction: column !important;
        gap: .85rem;
        overflow-x: visible;
    }

    .pf-block::after {
        display: none !important;
    }

    .pf-block {
        min-width: unset;
    }

    .pf-box {
        flex-direction: row;
        align-items: flex-start;
        text-align: left;
        gap: .75rem;
        padding: .85rem;
    }

    .pf-icon {
        width: 26px;
        height: 26px;
        flex-shrink: 0;
        margin: 0;
    }

    .pf-num {
        display: none;
    }

    .pf-title {
        font-size: .82rem;
        margin-bottom: .15rem;
    }

    .pf-sub {
        font-size: .7rem;
    }

    /* Answer blocks */
    .answer-block {
        padding: 1rem 1.1rem;
        margin-bottom: 1.2rem;
    }

        .answer-block p {
            font-size: .86rem;
            line-height: 1.75;
        }

    /* Pull quote */
    .pull-quote {
        font-size: .93rem;
        padding-left: 1rem;
        margin: 1.3rem 0;
    }

    /* Tables */
    .table-wrap {
        border: 1px solid #e8ecf5;
        border-radius: 8px;
    }

    .sol-table {
        font-size: .74rem;
        min-width: 440px;
    }

        .sol-table th, .sol-table td {
            padding: .45rem .6rem;
        }

    .compare-table {
        min-width: 480px;
        font-size: .74rem;
    }

        .compare-table th, .compare-table td {
            padding: .45rem .7rem;
        }

    /* Spec rows */
    .tech-spec-key {
        flex: 0 0 100px;
    }

    /* FAQ */
    .faq-question {
        font-size: .86rem;
        padding: .85rem 0;
    }

    .faq-answer p {
        font-size: .82rem;
        line-height: 1.7;
    }

    /* Not included */
    .not-included li {
        font-size: .78rem;
    }

    /* Image placeholders */
    .img-placeholder-lg {
        height: 220px;
    }

    .img-placeholder-md {
        height: 200px;
    }

    .img-placeholder-sm {
        height: 160px;
    }

    /* Bottom CTA */
    .bottom-cta {
        padding: 1.8rem 1.2rem !important;
        border-radius: 10px;
    }

    .bottom-cta-title {
        font-size: 1.25rem !important;
    }

    .bottom-cta-btns {
        flex-direction: column;
        align-items: stretch;
        gap: .75rem;
    }

        .bottom-cta-btns .btn-pill {
            text-align: center;
        }
}

/* ── ≤400px ── */
@media (max-width: 400px) {
    .related-grid {
        grid-template-columns: 1fr;
    }

    .kpi-strip {
        grid-template-columns: 1fr 1fr;
    }
}