

:root {
    --font-sans: 'Instrument Sans', ui-sans-serif, system-ui, sans-serif, 'Apple Color Emoji', 'Segoe UI Emoji',
        'Segoe UI Symbol', 'Noto Color Emoji';
    --page-bg: #f8fafc;
    --nv-navy: #0c1a2e;
    --nv-navy-2: #112240;
    --nv-blue: #0057b8;
    --nv-blue-light: #1a6fd4;
    --nv-cyan: #00b4d8;
    --nv-border: #d1dde8;
    --nv-text: #0f1923;
    --nv-muted: #64748b;
    --nv-mist: #f0f4f8;
    --nv-white: #ffffff;
}

body {
    min-height: 100vh;
}

.nodvolt-site {
    background: var(--page-bg);
    color: var(--nv-text);
    font-family: 'Inter', sans-serif;
}

@media (max-width: 640px) {
    .rf-hero {
        padding: 2rem 0 1.8rem;
    }

    .rf-hero-inner,
    .rf-step-inner,
    .rf-body {
        max-width: none;
        width: 100%;
        padding-left: 1rem;
        padding-right: 1rem;
    }

    .rf-title {
        font-size: 2rem;
        line-height: 1.08;
    }

    .rf-sub {
        font-size: 0.9rem;
        line-height: 1.6;
    }

    .rf-report-strip {
        align-items: flex-start;
        max-width: none;
        padding: 0.85rem;
    }

    .rf-report-meta {
        overflow-wrap: anywhere;
    }

    .rf-step-inner {
        min-height: auto;
        padding-top: 0.6rem;
        padding-bottom: 0.6rem;
        overflow-x: auto;
    }

    .rf-step {
        flex: 0 0 auto;
        padding-right: 0.75rem;
        font-size: 0.72rem;
    }

    .rf-step-arrow {
        padding-right: 0.75rem;
    }

    .rf-body {
        display: block;
        padding-top: 1.25rem;
        padding-bottom: 5rem;
    }

    .rf-left {
        display: none;
    }

    .rf-form-card {
        position: static;
        width: 100%;
        max-width: none;
        border-radius: 8px;
        overflow: hidden;
    }

    .rf-form-head {
        padding: 1rem;
    }

    .rf-form-title {
        font-size: 1.25rem;
    }

    .rf-form-sub {
        font-size: 0.78rem;
    }

    .rf-form-delivery {
        padding: 0.65rem 1rem;
        font-size: 0.62rem;
        line-height: 1.45;
    }

    .rf-form-body {
        padding: 1rem;
    }

    .rf-row,
    .rf-row-full {
        grid-template-columns: 1fr;
        gap: 0.75rem;
        margin-bottom: 0.75rem;
    }

    .rf-field input,
    .rf-field select,
    .rf-field textarea {
        min-width: 0;
        font-size: 0.84rem;
    }

    .rf-field textarea {
        min-height: 7rem;
    }

    .rf-success {
        margin: 0 1rem 0.8rem;
    }
}

.sla-page {
    max-width: 1200px;
    margin: 0 auto;
    padding: 2.75rem 2.5rem 6rem;
}

.sla-breadcrumb {
    display: flex;
    flex-wrap: wrap;
    gap: 0.35rem;
    margin-bottom: 2.25rem;
    color: var(--nv-muted);
    font-size: 0.72rem;
}

.sla-breadcrumb a {
    color: var(--nv-blue);
    font-weight: 700;
}

.sla-report-id {
    display: flex;
    gap: 1.75rem;
    align-items: center;
    margin-bottom: 3rem;
    border-radius: 6px;
    background: var(--nv-navy);
    padding: 1.75rem 2rem;
}

.sla-report-badge {
    flex: 0 0 auto;
    display: grid;
    gap: 0.2rem;
    place-items: center;
    border: 1px solid rgba(0, 180, 216, 0.28);
    border-radius: 4px;
    background: rgba(0, 87, 184, 0.5);
    padding: 0.65rem 0.9rem;
}

.sla-report-badge span {
    color: var(--nv-cyan);
    font-family: 'Playfair Display', serif;
    font-size: 1.35rem;
    font-weight: 800;
}

.sla-report-badge small,
.sla-report-sector,
.sla-section-label span,
.sla-tier,
.sla-sub-eyebrow {
    font-family: 'IBM Plex Mono', monospace;
    letter-spacing: 0.1em;
    text-transform: uppercase;
}

.sla-report-badge small {
    color: rgba(255, 255, 255, 0.44);
    font-size: 0.55rem;
}

.sla-report-sector {
    margin-bottom: 0.4rem;
    color: var(--nv-cyan);
    font-size: 0.64rem;
}

.sla-report-main h1 {
    margin: 0 0 0.65rem;
    color: #fff;
    font-family: 'Playfair Display', serif;
    font-size: 1.25rem;
    line-height: 1.35;
}

.sla-report-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 0.6rem 0;
}

.sla-report-meta span {
    padding-right: 1rem;
    margin-right: 1rem;
    border-right: 1px solid rgba(255, 255, 255, 0.1);
    color: rgba(255, 255, 255, 0.42);
    font-size: 0.72rem;
}

.sla-report-meta strong {
    color: rgba(255, 255, 255, 0.78);
}

.sla-section-label {
    display: flex;
    align-items: baseline;
    gap: 0.75rem;
    margin-bottom: 0.5rem;
}

.sla-section-label span {
    border-radius: 2px;
    background: #e8f0fb;
    color: var(--nv-blue);
    padding: 0.18rem 0.55rem;
    font-size: 0.62rem;
}

.sla-section-label h2 {
    margin: 0;
    color: var(--nv-navy);
    font-family: 'Playfair Display', serif;
    font-size: 1.35rem;
}

.sla-section-copy {
    max-width: 42rem;
    margin: 0 0 1.35rem;
    color: var(--nv-muted);
    font-size: 0.84rem;
    line-height: 1.65;
}

.sla-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0.9rem;
    margin-bottom: 0.9rem;
}

.sla-card {
    position: relative;
    display: flex;
    flex-direction: column;
    min-height: 100%;
    border: 1.5px solid var(--nv-border);
    border-radius: 6px;
    background: #fff;
    padding: 1.75rem 1.35rem 1.5rem;
    cursor: pointer;
    color: inherit;
    text-decoration: none;
    transition: border-color 0.18s, box-shadow 0.18s, transform 0.18s;
}

.sla-card:hover,
.sla-card.active {
    border-color: var(--nv-blue);
    box-shadow: 0 0 0 3px rgba(0, 87, 184, 0.12), 0 4px 20px rgba(0, 87, 184, 0.1);
    transform: translateY(-1px);
}

.sla-card.subscription-card {
    border-style: dashed;
    background: var(--nv-mist);
}

.sla-ribbon {
    position: absolute;
    top: -1px;
    left: 50%;
    transform: translateX(-50%);
    border-radius: 0 0 4px 4px;
    background: var(--nv-blue);
    color: #fff;
    padding: 0.25rem 0.8rem;
    font-family: 'IBM Plex Mono', monospace;
    font-size: 0.55rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    white-space: nowrap;
}

.sla-radio {
    width: 1.08rem;
    height: 1.08rem;
    border: 1.5px solid var(--nv-border);
    border-radius: 999px;
    display: grid;
    place-items: center;
    margin-bottom: 1.05rem;
}

.sla-card.active .sla-radio,
.sla-sub-block.active .sla-radio {
    border-color: var(--nv-blue);
}

.sla-radio span {
    width: 0.5rem;
    height: 0.5rem;
    border-radius: 999px;
    background: var(--nv-blue);
    display: none;
}

.sla-card.active .sla-radio span,
.sla-sub-block.active .sla-radio span {
    display: block;
}

.sla-tier {
    margin-bottom: 0.25rem;
    color: var(--nv-blue);
    font-size: 0.6rem;
}

.sla-card h3 {
    margin: 0 0 0.2rem;
    color: var(--nv-navy);
    font-family: 'Playfair Display', serif;
    font-size: 1.03rem;
}

.sla-card p {
    min-height: 2.1rem;
    margin: 0 0 1rem;
    color: var(--nv-muted);
    font-size: 0.72rem;
    line-height: 1.45;
}

.sla-price {
    color: var(--nv-navy);
    font-family: 'IBM Plex Mono', monospace;
    font-size: 1.55rem;
    font-weight: 800;
    line-height: 1;
}

.sla-card.subscription-card .sla-price {
    color: #9a6a14;
}

.sla-price-unit {
    margin: 0.2rem 0 1rem;
    color: var(--nv-muted);
    font-family: 'IBM Plex Mono', monospace;
    font-size: 0.65rem;
}

.sla-card hr,
.sla-form-card hr {
    width: 100%;
    border: 0;
    border-top: 1px solid var(--nv-border);
    margin: 0 0 1rem;
}

.sla-card ul {
    display: grid;
    gap: 0.5rem;
    margin: auto 0 0;
    padding: 0;
    list-style: none;
}

.sla-card li {
    display: flex;
    gap: 0.45rem;
    color: var(--nv-slate, #475569);
    font-size: 0.75rem;
    line-height: 1.45;
}

.sla-card li span {
    color: var(--nv-blue);
    font-weight: 900;
}

.sla-sub-block {
    position: relative;
    display: flex;
    align-items: center;
    gap: 2rem;
    margin: 0 0 3.25rem;
    border: 1.5px solid #1e3a5f;
    border-radius: 6px;
    background: var(--nv-navy-2);
    padding: 1.9rem 2rem;
    cursor: pointer;
}

.sla-sub-block.active {
    border-color: var(--nv-cyan);
    box-shadow: 0 0 0 2px rgba(0, 180, 216, 0.15);
}

.sla-sub-accent {
    position: absolute;
    top: 0;
    right: 2rem;
    border-radius: 0 0 4px 4px;
    background: var(--nv-cyan);
    color: var(--nv-navy);
    padding: 0.32rem 0.85rem;
    font-family: 'IBM Plex Mono', monospace;
    font-size: 0.55rem;
    font-weight: 900;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.sla-sub-left {
    flex: 1;
}

.sla-sub-eyebrow {
    color: var(--nv-cyan);
    font-size: 0.6rem;
    margin-bottom: 0.5rem;
}

.sla-sub-left h3 {
    margin: 0 0 0.35rem;
    color: #fff;
    font-family: 'Playfair Display', serif;
    font-size: 1.1rem;
}

.sla-sub-left p {
    margin: 0 0 0.9rem;
    max-width: 42rem;
    color: rgba(255, 255, 255, 0.58);
    font-size: 0.8rem;
    line-height: 1.65;
}

.sla-pills {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}

.sla-pills span {
    border-radius: 2px;
    background: rgba(0, 180, 216, 0.12);
    color: var(--nv-cyan);
    padding: 0.25rem 0.6rem;
    font-family: 'IBM Plex Mono', monospace;
    font-size: 0.62rem;
}

.sla-sub-right {
    flex: 0 0 12rem;
    text-align: right;
}

.sla-was {
    color: rgba(255, 255, 255, 0.3);
    text-decoration: line-through;
    font-family: 'IBM Plex Mono', monospace;
    font-size: 0.8rem;
}

.sla-sub-price {
    color: #fff;
    font-family: 'IBM Plex Mono', monospace;
    font-size: 1.85rem;
    font-weight: 800;
}

.sla-sub-unit {
    color: rgba(255, 255, 255, 0.42);
    font-size: 0.7rem;
}

.sla-save {
    display: inline-block;
    margin-top: 0.65rem;
    border-radius: 2px;
    background: var(--nv-cyan);
    color: var(--nv-navy);
    padding: 0.25rem 0.65rem;
    font-size: 0.65rem;
    font-weight: 900;
}

.sla-compare {
    overflow-x: auto;
    margin: 1rem 0 3.25rem;
    border: 1px solid var(--nv-border);
    border-radius: 6px;
    background: #fff;
}

.sla-compare table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.78rem;
}

.sla-compare th {
    background: var(--nv-navy);
    color: rgba(255, 255, 255, 0.64);
    padding: 0.8rem 1rem;
    text-align: left;
    font-family: 'IBM Plex Mono', monospace;
    font-size: 0.58rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.sla-compare td {
    border-bottom: 1px solid var(--nv-border);
    color: var(--nv-muted);
    padding: 0.75rem 1rem;
}

.sla-compare td:first-child {
    color: var(--nv-navy);
    font-weight: 700;
}

.sla-assurance {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1px;
    overflow: hidden;
    margin-bottom: 2.5rem;
    border: 1px solid var(--nv-border);
    border-radius: 6px;
    background: var(--nv-border);
}

.sla-assurance div {
    background: #fff;
    padding: 1.25rem;
}

.sla-assurance strong,
.sla-assurance span {
    display: block;
}

.sla-assurance strong {
    color: var(--nv-navy);
    font-size: 0.85rem;
    margin-bottom: 0.35rem;
}

.sla-assurance span {
    color: var(--nv-muted);
    font-size: 0.75rem;
    line-height: 1.55;
}

.sla-checkout {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 340px;
    gap: 1.5rem;
    align-items: start;
}

.sla-form-card,
.sla-summary {
    border: 1px solid var(--nv-border);
    border-radius: 6px;
    background: #fff;
}

.sla-form-card {
    padding: 2rem;
}

.sla-form-section {
    margin-bottom: 1rem;
    padding-bottom: 0.5rem;
    border-bottom: 1px solid var(--nv-mist);
    color: var(--nv-blue);
    font-size: 0.68rem;
    font-weight: 900;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.sla-form-row {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.9rem;
    margin-bottom: 0.9rem;
}

.sla-form-row.full {
    grid-template-columns: 1fr;
}

.sla-form-row label {
    display: grid;
    gap: 0.3rem;
    color: var(--nv-navy);
    font-size: 0.74rem;
    font-weight: 800;
}

.sla-form-row small {
    color: var(--nv-muted);
    font-weight: 500;
    line-height: 1.4;
}

.sla-form-row input,
.sla-form-row select,
.sla-form-row textarea {
    width: 100%;
    min-height: 2.65rem;
    border: 1px solid var(--nv-border);
    border-radius: 4px;
    background: #fff;
    color: var(--nv-text);
    padding: 0 0.75rem;
    outline: none;
    font-size: 0.86rem;
}

.sla-form-row textarea {
    padding-top: 0.75rem;
    line-height: 1.55;
}

.sla-form-row input:focus,
.sla-form-row select:focus,
.sla-form-row textarea:focus {
    border-color: var(--nv-blue);
    box-shadow: 0 0 0 3px rgba(0, 87, 184, 0.08);
}

.sla-pay-options {
    display: grid;
    gap: 0.65rem;
}

.sla-pay-options label {
    display: flex;
    gap: 0.75rem;
    align-items: center;
    border: 1.5px solid var(--nv-border);
    border-radius: 4px;
    padding: 0.8rem 0.9rem;
    cursor: pointer;
}

.sla-pay-options label.selected {
    border-color: var(--nv-blue);
    background: #f5f9ff;
}

.sla-pay-options input {
    width: auto;
}

.sla-pay-options span,
.sla-pay-options strong,
.sla-pay-options small {
    display: block;
}

.sla-pay-options strong {
    color: var(--nv-navy);
    font-size: 0.82rem;
}

.sla-pay-options small {
    color: var(--nv-muted);
    font-size: 0.7rem;
}

.sla-summary {
    position: sticky;
    top: 5rem;
    padding: 1.5rem;
}

.sla-summary h3 {
    margin: 0 0 1rem;
    color: var(--nv-navy);
    font-family: 'Playfair Display', serif;
    font-size: 1.05rem;
}

.sla-summary-report {
    margin-bottom: 0.9rem;
    padding-bottom: 0.9rem;
    border-bottom: 1px solid var(--nv-border);
}

.sla-summary-report strong,
.sla-summary-report span {
    display: block;
}

.sla-summary-report strong {
    color: var(--nv-navy);
    font-size: 0.8rem;
    line-height: 1.45;
}

.sla-summary-report span {
    margin-top: 0.2rem;
    color: var(--nv-muted);
    font-size: 0.72rem;
}

.sla-summary-row {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 0.6rem;
    font-size: 0.78rem;
}

.sla-summary-row span {
    color: var(--nv-muted);
}

.sla-summary-row strong {
    color: var(--nv-navy);
    text-align: right;
}

.sla-saving {
    display: none;
    margin: 0.8rem 0;
    border: 1px solid #bbf7d0;
    border-radius: 4px;
    background: #f0fdf4;
    color: #166534;
    padding: 0.55rem 0.7rem;
    font-size: 0.72rem;
}

.sla-saving.show {
    display: block;
}

.sla-total {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    margin-top: 0.9rem;
    padding-top: 0.9rem;
    border-top: 1px solid var(--nv-border);
}

.sla-total span {
    color: var(--nv-navy);
    font-weight: 900;
}

.sla-total strong {
    color: var(--nv-blue);
    font-family: 'IBM Plex Mono', monospace;
    font-size: 1.35rem;
}

.sla-note,
.sla-secure {
    color: var(--nv-muted);
    font-size: 0.7rem;
    line-height: 1.45;
}

.sla-note {
    margin: 0.25rem 0 1rem;
}

.sla-buy-btn,
.sla-invoice-btn {
    width: 100%;
    min-height: 2.85rem;
    border-radius: 4px;
    font-weight: 900;
}

.sla-buy-btn {
    border: 0;
    background: var(--nv-blue);
    color: #fff;
}

.sla-invoice-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-top: 0.55rem;
    border: 1.5px solid var(--nv-border);
    color: var(--nv-blue);
}

.sla-secure {
    margin-top: 0.75rem;
    text-align: center;
}

@media (max-width: 1100px) {
    .sla-grid,
    .sla-assurance {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .sla-checkout {
        grid-template-columns: 1fr;
    }

    .sla-summary {
        position: static;
    }
}

@media (max-width: 700px) {
    .sla-page {
        padding: 1.5rem 1rem 5.5rem;
    }

    .sla-report-id,
    .sla-sub-block {
        align-items: flex-start;
        flex-direction: column;
        gap: 1rem;
        padding: 1.25rem;
    }

    .sla-sub-right {
        flex: 0 0 auto;
        width: 100%;
        text-align: left;
    }

    .sla-grid,
    .sla-assurance,
    .sla-form-row {
        grid-template-columns: 1fr;
    }

    .sla-form-card,
    .sla-summary {
        padding: 1rem;
    }
}

.voc-hero {
    background: var(--nv-navy-2);
    padding: 4rem 0;
    position: relative;
    overflow: hidden;
}

.voc-hero::before {
    content: '';
    position: absolute;
    inset: 0;
    background-image: linear-gradient(rgba(0, 87, 184, 0.05) 1px, transparent 1px),
        linear-gradient(90deg, rgba(0, 87, 184, 0.05) 1px, transparent 1px);
    background-size: 40px 40px;
}

.voc-hero-inner,
.voc-inner,
.voc-cta-inner {
    max-width: 1280px;
    margin: 0 auto;
    padding: 0 2.5rem;
}

.voc-hero-inner {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: minmax(0, 1fr) 400px;
    gap: 3.5rem;
    align-items: center;
}

.voc-kicker,
.voc-eye {
    font-family: 'IBM Plex Mono', monospace;
    font-size: 0.66rem;
    letter-spacing: 0.14em;
    text-transform: uppercase;
}

.voc-kicker {
    color: var(--nv-cyan);
    margin-bottom: 1rem;
}

.voc-hero h1,
.voc-sec h2,
.voc-cta h2 {
    font-family: 'Playfair Display', serif;
    line-height: 1.15;
}

.voc-hero h1 {
    max-width: 42rem;
    color: #fff;
    font-size: clamp(2.35rem, 5vw, 3.35rem);
    margin: 0 0 1rem;
}

.voc-hero h1 em {
    color: var(--nv-cyan);
}

.voc-hero p,
.voc-sub {
    color: rgba(255, 255, 255, 0.62);
    line-height: 1.75;
}

.voc-hero p {
    max-width: 38rem;
    margin-bottom: 2rem;
}

.voc-actions,
.voc-cta-inner > div:last-child {
    display: flex;
    gap: 0.75rem;
    flex-wrap: wrap;
}

.voc-actions a,
.voc-cta a {
    min-height: 2.8rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 4px;
    padding: 0 1.4rem;
    font-size: 0.82rem;
    font-weight: 800;
}

.voc-btn-primary,
.voc-cta a:first-child {
    background: var(--nv-cyan);
    color: var(--nv-navy);
}

.voc-btn-ghost,
.voc-cta a:last-child {
    border: 1px solid rgba(255, 255, 255, 0.26);
    color: #fff;
}

.voc-stat-stack {
    display: grid;
    gap: 0.75rem;
}

.voc-stat-stack div {
    border: 1px solid rgba(255, 255, 255, 0.09);
    border-radius: 5px;
    background: rgba(255, 255, 255, 0.04);
    padding: 1.15rem 1.35rem;
}

.voc-stat-stack strong {
    display: block;
    color: #fff;
    font-family: 'Playfair Display', serif;
    font-size: 1.75rem;
}

.voc-stat-stack span {
    color: rgba(255, 255, 255, 0.48);
    font-size: 0.78rem;
    line-height: 1.55;
}

.voc-sec {
    padding: 4.5rem 0;
}

.voc-eye {
    color: var(--nv-blue);
    margin-bottom: 0.6rem;
}

.voc-sec h2 {
    color: var(--nv-navy);
    font-size: clamp(1.8rem, 3vw, 2.35rem);
    margin: 0 0 0.7rem;
}

.voc-sec .voc-sub {
    max-width: 46rem;
    margin: 0 0 2.5rem;
    color: var(--nv-muted);
}

.voc-why-grid,
.voc-role-grid,
.voc-assurance {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1rem;
}

.voc-why-grid div,
.voc-role-card,
.voc-use-card,
.voc-type-card,
.voc-question-card {
    border: 1px solid var(--nv-border);
    border-radius: 6px;
    background: #fff;
}

.voc-why-grid div {
    border-left: 3px solid var(--nv-blue);
    padding: 1.25rem;
}

.voc-why-grid strong {
    display: block;
    color: var(--nv-navy);
    font-family: 'Playfair Display', serif;
    font-size: 1.7rem;
    line-height: 1;
}

.voc-why-grid strong span {
    color: var(--nv-blue);
    font-family: 'Inter', sans-serif;
    font-size: 0.85rem;
}

.voc-why-grid p,
.voc-use-card p,
.voc-role-card p,
.voc-type-card p {
    color: var(--nv-muted);
    font-size: 0.82rem;
    line-height: 1.65;
}

.voc-use-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1.25rem;
}

.voc-use-card,
.voc-type-card,
.voc-question-card,
.voc-role-card {
    padding: 1.5rem;
}

.voc-use-type,
.voc-question-card > div {
    color: var(--nv-blue);
    font-family: 'IBM Plex Mono', monospace;
    font-size: 0.62rem;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    margin-bottom: 0.55rem;
}

.voc-use-card h3,
.voc-type-card h3,
.voc-question-card h3,
.voc-role-card h3 {
    color: var(--nv-navy);
    font-family: 'Playfair Display', serif;
    font-size: 1.05rem;
    line-height: 1.35;
    margin: 0 0 0.6rem;
}

.voc-use-card div:last-child {
    display: flex;
    gap: 0.4rem;
    flex-wrap: wrap;
    margin-top: 1rem;
}

.voc-use-card span {
    background: var(--nv-mist);
    color: var(--nv-muted);
    border-radius: 2px;
    padding: 0.2rem 0.55rem;
    font-family: 'IBM Plex Mono', monospace;
    font-size: 0.62rem;
}

.voc-type-grid,
.voc-question-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1.25rem;
}

.voc-question-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.voc-table-wrap {
    overflow-x: auto;
    border: 1px solid var(--nv-border);
    border-radius: 6px;
    background: #fff;
}

.voc-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.82rem;
}

.voc-table th {
    background: var(--nv-navy);
    color: rgba(255, 255, 255, 0.72);
    padding: 0.85rem 1rem;
    text-align: left;
    font-family: 'IBM Plex Mono', monospace;
    font-size: 0.62rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
}

.voc-table td {
    border-bottom: 1px solid var(--nv-border);
    color: var(--nv-muted);
    padding: 0.85rem 1rem;
    vertical-align: top;
}

.voc-row-highlight td {
    background: #f5f8ff;
    color: var(--nv-navy);
    border-left: 3px solid var(--nv-blue);
}

.voc-navy {
    background: var(--nv-navy);
}

.voc-navy .voc-eye {
    color: var(--nv-cyan);
}

.voc-navy h2 {
    color: #fff;
}

.voc-navy .voc-sub {
    color: rgba(255, 255, 255, 0.58);
}

.voc-advantage {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 420px;
    gap: 2rem;
    align-items: start;
}

.voc-adv-list {
    display: grid;
    gap: 1rem;
}

.voc-adv-list div {
    display: flex;
    gap: 0.9rem;
    color: rgba(255, 255, 255, 0.72);
}

.voc-adv-list strong {
    color: var(--nv-cyan);
    font-family: 'IBM Plex Mono', monospace;
}

.voc-bars {
    display: grid;
    gap: 0;
    border-radius: 6px;
    background: var(--nv-navy-2);
    padding: 1.5rem;
}

.voc-bar-row {
    display: grid;
    grid-template-columns: 1fr 1fr 2.5rem;
    gap: 0.85rem;
    align-items: center;
    padding: 0.75rem 0;
    border-bottom: 1px solid rgba(255, 255, 255, 0.07);
}

.voc-bar-row span {
    color: rgba(255, 255, 255, 0.64);
    font-size: 0.78rem;
}

.voc-bar-row div {
    height: 6px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.1);
    overflow: hidden;
}

.voc-bar-row i {
    display: block;
    height: 100%;
    background: var(--nv-cyan);
}

.voc-bar-row b {
    color: var(--nv-cyan);
    font-family: 'IBM Plex Mono', monospace;
    font-size: 0.7rem;
}

.voc-question-card ul {
    display: grid;
    gap: 0.45rem;
    margin: 0;
    padding: 0;
    list-style: none;
}

.voc-question-card li {
    border-left: 2px solid var(--nv-border);
    border-radius: 3px;
    background: var(--nv-mist);
    color: var(--nv-muted);
    padding: 0.5rem 0.7rem;
    font-size: 0.78rem;
    line-height: 1.45;
}

.voc-process {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 1rem;
}

.voc-process div {
    text-align: center;
}

.voc-process span {
    width: 3.25rem;
    height: 3.25rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    background: var(--nv-navy);
    color: #fff;
    font-family: 'IBM Plex Mono', monospace;
    margin-bottom: 0.85rem;
}

.voc-process strong {
    display: block;
    color: var(--nv-navy);
    font-size: 0.85rem;
}

.voc-cta {
    background: var(--nv-blue);
    padding: 4rem 0;
}

.voc-cta-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 2rem;
}

.voc-cta h2 {
    margin: 0;
    color: #fff;
    font-size: 2rem;
}

.voc-cta p {
    margin: 0.5rem 0 0;
    color: rgba(255, 255, 255, 0.72);
}

@media (max-width: 1100px) {
    .voc-hero-inner,
    .voc-advantage,
    .voc-cta-inner {
        grid-template-columns: 1fr;
        display: grid;
    }

    .voc-why-grid,
    .voc-role-grid,
    .voc-use-grid,
    .voc-question-grid,
    .voc-process {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 700px) {
    .voc-hero-inner,
    .voc-inner,
    .voc-cta-inner {
        padding: 0 1rem;
    }

    .voc-hero {
        padding: 3rem 0;
    }

    .voc-stat-stack,
    .voc-why-grid,
    .voc-role-grid,
    .voc-use-grid,
    .voc-type-grid,
    .voc-question-grid,
    .voc-process {
        grid-template-columns: 1fr;
    }

    .voc-sec {
        padding: 3rem 0;
    }

    .voc-bar-row {
        grid-template-columns: 1fr;
    }
}

.error-page {
    min-height: 68vh;
    display: flex;
    align-items: center;
    background: var(--nv-navy-2);
    color: #fff;
    padding: 5rem 1.5rem;
    position: relative;
    overflow: hidden;
}

.error-page::before {
    content: '';
    position: absolute;
    inset: 0;
    background-image: linear-gradient(rgba(0, 180, 216, 0.06) 1px, transparent 1px),
        linear-gradient(90deg, rgba(0, 180, 216, 0.06) 1px, transparent 1px);
    background-size: 44px 44px;
}

.error-inner {
    position: relative;
    z-index: 1;
    max-width: 760px;
    margin: 0 auto;
    text-align: center;
}

.error-code {
    font-family: 'IBM Plex Mono', monospace;
    color: var(--nv-cyan);
    font-size: 0.78rem;
    font-weight: 800;
    letter-spacing: 0.18em;
    text-transform: uppercase;
}

.error-inner h1 {
    margin: 0.55rem 0 0.8rem;
    font-family: 'Playfair Display', serif;
    font-size: clamp(2.5rem, 7vw, 5rem);
    line-height: 1;
}

.error-inner p {
    margin: 0 auto;
    max-width: 38rem;
    color: rgba(255, 255, 255, 0.68);
    font-size: 1rem;
    line-height: 1.75;
}

.error-search {
    margin: 2rem auto 1.35rem;
    max-width: 620px;
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 0.75rem;
    background: rgba(255, 255, 255, 0.08);
    border: 1px solid rgba(255, 255, 255, 0.12);
    border-radius: 8px;
    padding: 0.75rem;
}

.error-search input,
.error-search button {
    min-height: 3rem;
    border-radius: 5px;
    border: 0;
}

.error-search input {
    padding: 0 1rem;
    color: var(--nv-navy);
}

.error-search button,
.error-primary {
    background: var(--nv-cyan);
    color: var(--nv-navy);
    font-family: 'IBM Plex Mono', monospace;
    font-size: 0.72rem;
    font-weight: 900;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    padding: 0 1rem;
}

.error-actions {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 0.75rem;
}

.error-actions a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 2.8rem;
    border: 1px solid rgba(255, 255, 255, 0.18);
    border-radius: 5px;
    padding: 0 1rem;
    color: #fff;
    font-weight: 800;
}

.error-actions .error-primary {
    border-color: var(--nv-cyan);
}

.error-note {
    margin-top: 1.6rem;
    color: rgba(255, 255, 255, 0.42);
    font-family: 'IBM Plex Mono', monospace;
    font-size: 0.72rem;
    overflow-wrap: anywhere;
}

.error-note span {
    color: rgba(255, 255, 255, 0.68);
}

@media (max-width: 640px) {
    .error-page {
        align-items: flex-start;
        padding: 3rem 1rem 6rem;
    }

    .error-search {
        grid-template-columns: 1fr;
    }

    .error-actions {
        display: grid;
        grid-template-columns: 1fr;
    }
}

.skip-link {
    position: fixed;
    left: 1rem;
    top: 1rem;
    z-index: 10000;
    transform: translateY(-150%);
    background: var(--nv-cyan);
    color: var(--nv-navy);
    padding: 0.65rem 0.9rem;
    border-radius: 4px;
    font-weight: 800;
}

.skip-link:focus {
    transform: translateY(0);
}

.cookie-consent {
    position: fixed;
    left: 1rem;
    right: 1rem;
    bottom: 1rem;
    z-index: 9999;
    max-width: 720px;
    margin: 0 auto;
    display: flex;
    gap: 1rem;
    justify-content: space-between;
    align-items: center;
    background: #fff;
    border: 1px solid var(--nv-border);
    box-shadow: 0 18px 48px rgba(12, 26, 46, 0.18);
    border-radius: 6px;
    padding: 1rem;
    color: var(--nv-text);
}

.cookie-consent strong,
.cookie-consent span {
    display: block;
}

.cookie-consent span {
    margin-top: 0.25rem;
    color: var(--nv-muted);
    font-size: 0.8rem;
    line-height: 1.5;
}

.cookie-consent-actions {
    display: flex;
    gap: 0.5rem;
}

.cookie-consent button {
    border: 1px solid var(--nv-border);
    background: #fff;
    color: var(--nv-navy);
    border-radius: 4px;
    padding: 0.55rem 0.8rem;
    font-weight: 800;
    cursor: pointer;
}

.cookie-consent button[data-consent="granted"] {
    background: var(--nv-blue);
    border-color: var(--nv-blue);
    color: #fff;
}

.nv-header {
    position: sticky;
    top: 0;
    z-index: 100;
}

.nv-mobile-topbar,
.nv-mobile-menu,
.nv-mobile-bottom-nav,
.nv-mobile-search-panel,
.nv-mobile-modal-backdrop,
.nv-mobile-sample-modal {
    display: none;
}

.nv-nav-shell {
    background: var(--nv-navy);
    border-bottom: 1px solid rgba(0, 180, 216, 0.18);
}

.nv-nav-inner {
    max-width: 1280px;
    margin: 0 auto;
    min-height: 58px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1.5rem;
    padding: 0 1.5rem;
}

.nv-logo {
    display: inline-flex;
    align-items: center;
    line-height: 0;
}

.nv-logo-lockup {
    width: 174px;
    height: auto;
    display: block;
    filter: drop-shadow(0 2px 6px rgba(0, 87, 184, 0.18));
}

.nv-footer-brand span {
    color: #2fb9ff;
}

.nv-nav-links {
    display: flex;
    align-items: center;
    gap: 1.25rem;
    flex-wrap: wrap;
}

.nv-nav-item {
    position: relative;
}

.nv-nav-item-mega {
    padding-bottom: 1rem;
    margin-bottom: -1rem;
}

.nv-nav-links a {
    font-size: 0.8125rem;
    font-weight: 500;
    color: rgba(255, 255, 255, 0.7);
    letter-spacing: 0.01em;
    transition: color 0.2s ease, background-color 0.2s ease;
}

.nv-nav-links a:hover,
.nv-nav-links a.is-active {
    color: var(--nv-white);
}

.nv-nav-cta {
    background: var(--nv-blue);
    color: var(--nv-white) !important;
    font-size: 0.78125rem;
    font-weight: 600;
    padding: 0.5rem 1.25rem;
    border-radius: 3px;
    letter-spacing: 0.02em;
}

.nv-nav-cta:hover {
    background: var(--nv-blue-light);
}

.nv-mega-menu {
    position: absolute;
    left: 50%;
    top: calc(100% + 0.35rem);
    transform: translateX(-50%);
    width: min(1120px, calc(100vw - 3rem));
    background: #0d1a26;
    border: 1px solid rgba(0, 180, 216, 0.14);
    border-radius: 0;
    box-shadow: 0 28px 80px rgba(1, 8, 18, 0.45);
    padding: 0;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: opacity 0.18s ease, transform 0.18s ease;
    z-index: 150;
}

.nv-mega-menu::before {
    content: '';
    position: absolute;
    left: 0;
    right: 0;
    top: -0.75rem;
    height: 0.75rem;
}

.nv-nav-item-mega:hover .nv-mega-menu,
.nv-nav-item-mega:focus-within .nv-mega-menu {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transform: translateX(-50%) translateY(0);
}

.nv-mega-toolbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 0.7rem 1rem;
    border-bottom: 1px solid rgba(255, 255, 255, 0.06);
    background: #112130;
}

.nv-mega-search {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    min-width: 0;
    flex: 1 1 auto;
    max-width: 760px;
}

.nv-mega-search input {
    min-width: 0;
    height: 34px;
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-right: 0;
    background: rgba(255, 255, 255, 0.06);
    color: #e8f0f8;
    padding: 0 0.95rem;
    font-size: 0.84rem;
    outline: none;
}

.nv-mega-search input::placeholder {
    color: rgba(232, 240, 248, 0.42);
}

.nv-mega-search button {
    height: 34px;
    border: 0;
    background: linear-gradient(135deg, #0085b5, #00a8d6);
    color: #fff;
    font-size: 0.82rem;
    font-weight: 700;
    padding: 0 1.2rem;
    cursor: pointer;
}

.nv-mega-metrics {
    display: flex;
    align-items: center;
    gap: 1rem;
    color: rgba(232, 240, 248, 0.56);
    font-family: 'IBM Plex Mono', monospace;
    font-size: 0.68rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    white-space: nowrap;
}

.nv-mega-metrics strong {
    color: var(--nv-cyan);
    font-size: 0.76rem;
}

.nv-mega-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0;
    border-bottom: 1px solid rgba(255, 255, 255, 0.06);
}

.nv-mega-col {
    min-width: 0;
    padding: 0.7rem 0.95rem 0.65rem;
    border-right: 1px solid rgba(255, 255, 255, 0.06);
    border-bottom: 1px solid rgba(255, 255, 255, 0.06);
    background: transparent;
    transition: background-color 0.18s ease;
}

.nv-mega-col:hover {
    background: rgba(255, 255, 255, 0.025);
}

.nv-mega-col-head {
    display: flex;
    align-items: center;
    gap: 0.65rem;
    min-height: 24px;
    padding-bottom: 0.4rem;
    margin-bottom: 0;
    border-bottom: 1px solid rgba(255, 255, 255, 0.06);
}

.nv-mega-icon {
    width: 1.2rem;
    height: 1.2rem;
    border: 1px solid rgba(0, 180, 216, 0.22);
    background:
        radial-gradient(circle at center, rgba(0, 180, 216, 0.5) 0.14rem, transparent 0.16rem),
        transparent;
    flex: 0 0 auto;
}

.nv-mega-sector {
    display: block;
    color: #f2f7fb !important;
    font-size: 0.8rem !important;
    font-weight: 700 !important;
    letter-spacing: -0.01em;
    line-height: 1.15;
}

.nv-mega-viewall {
    display: inline-flex;
    align-items: center;
    color: var(--nv-cyan) !important;
    font-size: 0.78rem !important;
    font-weight: 500 !important;
    letter-spacing: 0.01em;
}

.nv-mega-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 0.7rem 1rem;
    background: #0b1721;
}

.nv-mega-footer-stats {
    display: flex;
    align-items: center;
    gap: 1rem;
    color: rgba(232, 240, 248, 0.56);
    font-family: 'IBM Plex Mono', monospace;
    font-size: 0.64rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
}

.nv-mega-footer-stats strong {
    color: #eef7ff;
}

.nv-mega-footer-cta {
    display: flex;
    align-items: center;
    gap: 0.8rem;
}

.nv-mega-footer-link {
    color: var(--nv-cyan) !important;
    font-size: 0.78rem !important;
    font-weight: 600 !important;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.nv-mega-footer-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 34px;
    padding: 0 0.9rem;
    background: linear-gradient(135deg, #0085b5, #00a8d6);
    color: #fff !important;
    font-size: 0.76rem !important;
    font-weight: 700 !important;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.nv-mega-viewall:hover,
.nv-mega-sector:hover,
.nv-mega-footer-link:hover {
    color: #7be7ff !important;
}

.nv-footer {
    background: var(--nv-navy);
    padding: 3.5rem 0 1.75rem;
}

.nv-footer-inner {
    max-width: 1280px;
    margin: 0 auto;
    padding: 0 1.5rem;
}

.nv-footer-top {
    display: grid;
    grid-template-columns: 280px 1fr;
    gap: 2.5rem;
    margin-bottom: 2.5rem;
}

.nv-footer-brand {
    font-family: 'Playfair Display', serif;
    font-size: 1.0625rem;
    color: var(--nv-white);
    margin-bottom: 0.625rem;
}

.nv-footer-tagline {
    font-size: 0.8125rem;
    color: rgba(255, 255, 255, 0.45);
    line-height: 1.6;
}

.nv-footer-identity {
    margin-top: 1rem;
    display: grid;
    gap: 0.28rem;
    color: rgba(255, 255, 255, 0.45);
    font-size: 0.75rem;
    line-height: 1.5;
}

.nv-footer-identity a {
    color: rgba(255, 255, 255, 0.72);
}

.nv-footer-cols {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 2rem;
}

.nv-footer-col-head {
    font-family: 'IBM Plex Mono', monospace;
    font-size: 0.65625rem;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: rgba(255, 255, 255, 0.4);
    margin-bottom: 0.875rem;
}

.nv-footer-col a {
    display: block;
    font-size: 0.8125rem;
    color: rgba(255, 255, 255, 0.55);
    margin-bottom: 0.5rem;
    transition: color 0.2s ease;
}

.nv-footer-col a:hover {
    color: var(--nv-white);
}

.nv-footer-bottom {
    border-top: 1px solid rgba(255, 255, 255, 0.08);
    padding-top: 1.5rem;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
}

.nv-footer-copy,
.nv-footer-legal a {
    font-size: 0.75rem;
    color: rgba(255, 255, 255, 0.3);
}

.nv-footer-legal {
    display: flex;
    gap: 1.5rem;
}

@media (max-width: 900px) {
    .nv-nav-inner,
    .nv-footer-top,
    .nv-footer-bottom {
        display: block;
    }

    .nv-nav-inner {
        padding-top: 0.875rem;
        padding-bottom: 0.875rem;
    }

    .nv-nav-links {
        margin-top: 0.875rem;
        gap: 0.875rem 1rem;
    }

    .nv-mega-menu {
        position: static;
        transform: none;
        width: 100%;
        margin-top: 0.75rem;
        opacity: 1;
        visibility: visible;
        pointer-events: auto;
        box-shadow: none;
        border-color: rgba(255, 255, 255, 0.12);
        background: #0d1a26;
        border-radius: 16px;
    }

    .nv-mega-toolbar,
    .nv-mega-footer {
        display: block;
    }

    .nv-mega-metrics,
    .nv-mega-footer-stats,
    .nv-mega-footer-cta {
        margin-top: 0.85rem;
    }

    .nv-mega-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .nv-mega-col {
        border-color: rgba(255, 255, 255, 0.08);
    }

    .nv-mega-sector {
        color: var(--nv-white) !important;
    }

    .nv-footer-cols {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        margin-top: 1.75rem;
    }

    .nv-footer-bottom {
        padding-top: 1.25rem;
    }

    .nv-footer-legal {
        margin-top: 0.875rem;
    }

    .contact-shell,
    .contact-steps,
    .contact-meta-grid,
    .rf-body {
        grid-template-columns: 1fr;
    }

    .contact-form-grid,
    .rf-row,
    .rf-trust-grid {
        grid-template-columns: 1fr;
    }

    .rf-feature-row-rich {
        grid-template-columns: 2rem minmax(0, 1fr);
    }

    .rf-mini-tag {
        grid-column: 2;
        justify-self: start;
    }

    .rf-form-card {
        position: static;
    }

    .rf-hero-inner,
    .rf-step-inner,
    .rf-body {
        padding-left: 1.25rem;
        padding-right: 1.25rem;
    }
}

@media (max-width: 640px) {
    .nv-footer-cols {
        grid-template-columns: 1fr;
    }

    .nv-nav-links {
        flex-direction: column;
        align-items: flex-start;
    }

    .nv-mega-grid {
        grid-template-columns: 1fr;
    }

    .contact-hero {
        padding: 3rem 0 2.5rem;
    }

    .contact-form-card {
        padding: 1rem;
        border-radius: 20px;
    }

    .contact-form-actions {
        display: block;
    }

    .contact-form-note {
        margin-top: 0.85rem;
        text-align: left;
    }

    .rf-hero {
        padding: 2.6rem 0 2.2rem;
    }

    .rf-step:nth-child(n+5) {
        display: none;
    }
}

.hero {
    background: var(--nv-navy-2);
    min-height: 540px;
    display: flex;
    align-items: center;
    position: relative;
    overflow: hidden;
}

.hero::before {
    content: '';
    position: absolute;
    inset: 0;
    background: radial-gradient(ellipse at 70% 50%, rgba(0, 180, 216, 0.08) 0%, transparent 60%);
}

.hero-grid {
    position: absolute;
    inset: 0;
    background-image: linear-gradient(rgba(0, 87, 184, 0.06) 1px, transparent 1px),
        linear-gradient(90deg, rgba(0, 87, 184, 0.06) 1px, transparent 1px);
    background-size: 48px 48px;
    pointer-events: none;
}

.hero-inner,
.sec-inner,
.data-strip-inner,
.clients-inner,
.cta-band-inner {
    max-width: 1280px;
    margin: 0 auto;
    padding-left: 1.5rem;
    padding-right: 1.5rem;
}

.hero-inner {
    position: relative;
    z-index: 1;
    padding-top: 5rem;
    padding-bottom: 5rem;
    display: grid;
    grid-template-columns: minmax(0, 1fr) 420px;
    gap: 4rem;
    align-items: center;
}

.hero-kicker,
.sec-eye,
.ds-eye,
.clients-label,
.ticker-label,
.ticker-val,
.ticker-chg,
.ds-label,
.ds-val,
.ds-chg,
.price-badge,
.rc-tag,
.ic-type,
.nv-footer-col-head,
.why-num,
.wv-source {
    font-family: 'IBM Plex Mono', monospace;
}

.hero-kicker {
    font-size: 0.6875rem;
    text-transform: uppercase;
    letter-spacing: 0.14em;
    color: var(--nv-cyan);
    margin-bottom: 1.25rem;
}

.hero-h1,
.sec-title,
.ds-title,
.cta-band-title,
.price-amt,
.sc-name,
.rc-title,
.ic-title,
.why-visual-title {
    font-family: 'Playfair Display', serif;
}

.hero-h1 {
    font-size: clamp(2.4rem, 5vw, 3rem);
    line-height: 1.12;
    color: #fff;
    margin-bottom: 1.5rem;
    font-weight: 700;
}

.hero-h1 em {
    font-style: italic;
    color: var(--nv-cyan);
}

.hero-sub {
    font-size: 0.9375rem;
    color: rgba(255, 255, 255, 0.62);
    line-height: 1.7;
    max-width: 480px;
    margin-bottom: 2.25rem;
}

.hero-btns,
.cta-band-btns {
    display: flex;
    gap: 0.875rem;
    flex-wrap: wrap;
}

.btn-prim,
.btn-sec,
.btn-white,
.btn-ghost,
.btn-ol,
.btn-fl {
    display: inline-block;
    border-radius: 3px;
    font-size: 0.8125rem;
    transition: 0.2s ease;
}

.btn-prim,
.btn-fl {
    background: var(--nv-blue);
    color: #fff;
    font-weight: 600;
    padding: 0.75rem 1.75rem;
    letter-spacing: 0.02em;
}

.btn-prim:hover,
.btn-fl:hover,
.nv-nav-cta:hover {
    background: var(--nv-blue-light);
}

.btn-sec {
    border: 1px solid rgba(255, 255, 255, 0.25);
    color: rgba(255, 255, 255, 0.8);
    font-weight: 500;
    padding: 0.75rem 1.5rem;
}

.btn-sec:hover {
    border-color: rgba(255, 255, 255, 0.5);
    color: #fff;
}

.hero-stats {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.hero-stat-card {
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.09);
    border-radius: 6px;
    padding: 1.25rem 1.5rem;
}

.hero-stat-val {
    font-family: 'Playfair Display', serif;
    font-size: 1.75rem;
    color: #fff;
    font-weight: 600;
}

.hero-stat-val span {
    font-family: 'IBM Plex Mono', monospace;
    font-size: 0.8125rem;
    color: var(--nv-cyan);
    margin-left: 0.375rem;
}

.hero-stat-lbl {
    font-size: 0.75rem;
    color: rgba(255, 255, 255, 0.5);
    margin-top: 0.25rem;
}

.ticker-bar {
    background: var(--nv-navy);
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
    padding: 0.625rem 0;
    overflow: hidden;
}

.ticker-inner {
    display: flex;
    width: max-content;
    animation: ticker 38s linear infinite;
}

.ticker-bar:hover .ticker-inner {
    animation-play-state: paused;
}

.ticker-item {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0 2rem;
    border-right: 1px solid rgba(255, 255, 255, 0.1);
    white-space: nowrap;
    text-decoration: none;
    transition: background-color 160ms ease, opacity 160ms ease;
}

.ticker-item:hover {
    background: rgba(255, 255, 255, 0.04);
}

.ticker-item:hover .ticker-label,
.ticker-item:hover .ticker-val {
    color: #fff;
}

.ticker-label {
    font-size: 0.6875rem;
    color: rgba(255, 255, 255, 0.45);
    letter-spacing: 0.06em;
}

.ticker-val {
    font-size: 0.75rem;
    color: #fff;
    font-weight: 500;
}

.ticker-chg,
.ds-chg {
    font-size: 0.6875rem;
}

.up {
    color: #22c55e;
}

.dn {
    color: #ef4444;
}

.flat {
    color: rgba(255, 255, 255, 0.4);
}

@keyframes ticker {
    0% {
        transform: translateX(0);
    }
    100% {
        transform: translateX(-50%);
    }
}

.sec {
    padding: 4.5rem 0;
}

.nv-sec-compact {
    padding: 4rem 0;
}

.bg-mist {
    background: var(--nv-mist);
}

.sec-hdr {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 2.25rem;
}

.sec-eye {
    font-size: 0.65625rem;
    text-transform: uppercase;
    letter-spacing: 0.14em;
    color: var(--nv-blue);
    margin-bottom: 0.625rem;
}

.sec-title {
    font-size: 2rem;
    color: var(--nv-navy);
    margin-bottom: 0.5rem;
}

.sec-sub,
.why-body-text,
.ic-excerpt,
.footer-tagline {
    font-size: 0.90625rem;
    color: var(--nv-muted);
    line-height: 1.7;
}

.sec-sub {
    max-width: 600px;
    margin-bottom: 2.5rem;
}

.nv-no-margin {
    margin-bottom: 2.25rem;
}

.sec-hdr-link {
    font-size: 0.8125rem;
    color: var(--nv-blue);
    font-weight: 500;
}

.sector-grid,
.reports-grid,
.insight-grid,
.test-grid,
.price-grid {
    display: grid;
    gap: 1.5rem;
}

.sector-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1.25rem;
}

.sector-card,
.report-card,
.insight-card,
.test-card,
.price-card {
    border: 1px solid var(--nv-border);
    border-radius: 6px;
    background: #fff;
}

.sector-card {
    padding: 1.75rem 1.5rem;
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.sector-card:hover,
.report-card:hover,
.insight-card:hover {
    border-color: var(--nv-blue);
    box-shadow: 0 4px 20px rgba(0, 87, 184, 0.1);
}

.sc-icon {
    font-size: 1.5rem;
    margin-bottom: 0.875rem;
}

.sc-name {
    font-size: 1rem;
    color: var(--nv-navy);
    margin-bottom: 0.5rem;
}

.sc-desc,
.rc-price,
.test-role,
.price-sub {
    font-size: 0.8125rem;
    color: var(--nv-muted);
    line-height: 1.6;
}

.sc-count,
.rc-cagr,
.ic-date {
    font-size: 0.6875rem;
    color: var(--nv-blue);
    letter-spacing: 0.04em;
}

.reports-grid,
.insight-grid,
.test-grid,
.price-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.report-card,
.insight-card,
.test-card,
.price-card {
    padding: 1.5rem;
}

.report-card,
.insight-card {
    display: block;
    color: inherit;
    text-decoration: none;
}

.rc-tag {
    display: inline-block;
    font-size: 0.625rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    padding: 0.1875rem 0.625rem;
    border-radius: 2px;
    margin-bottom: 0.875rem;
}

.rc-tag.semi {
    background: #e8f0fb;
    color: var(--nv-blue);
}

.rc-tag.elec {
    background: #e0f4f8;
    color: #0077a8;
}

.rc-tag.power {
    background: #fef3e0;
    color: #8a5c00;
}

.rc-tag.new {
    background: #fff0f0;
    color: #c0392b;
}

.rc-title,
.ic-title {
    font-size: 0.9375rem;
    color: var(--nv-navy);
    line-height: 1.5;
}

.rc-meta {
    display: flex;
    justify-content: flex-start;
    align-items: center;
    border-top: 1px solid var(--nv-border);
    padding-top: 0.875rem;
    margin-top: 0.875rem;
    gap: 1rem;
}

.reports-catalog-hero {
    padding: 3.2rem 0 2.1rem;
    background: #f6f9fe;
}

.reports-catalog-kicker {
    font-family: 'IBM Plex Mono', monospace;
    font-size: 0.6875rem;
    text-transform: uppercase;
    letter-spacing: 0.14em;
    color: var(--nv-blue);
    margin-bottom: 0.875rem;
}

.reports-catalog-title {
    max-width: 760px;
    font-size: 3rem;
    line-height: 1.05;
    color: var(--nv-navy);
    letter-spacing: -0.04em;
    margin-bottom: 0.9rem;
}

.reports-catalog-intro {
    max-width: 760px;
    color: var(--nv-muted);
    font-size: 1rem;
    line-height: 1.7;
}

.reports-catalog-chips {
    display: flex;
    flex-wrap: wrap;
    gap: 0.8rem;
    margin-top: 1.65rem;
}

.reports-catalog-chip {
    display: inline-flex;
    align-items: center;
    gap: 0.55rem;
    border: 1px solid #bfd2ee;
    border-radius: 999px;
    background: #fff;
    padding: 0.65rem 1rem;
    color: #50627d;
    font-size: 0.92rem;
}

.reports-catalog-chip strong {
    color: var(--nv-blue);
    font-weight: 700;
}

.reports-catalog-body {
    min-height: 48vh;
    padding-top: 0;
}

.reports-directory-layout {
    display: grid;
    grid-template-columns: 270px minmax(0, 1fr);
    gap: 1.8rem;
    align-items: start;
}

.reports-sidebar-card {
    border: 1px solid #bfd2ee;
    border-radius: 8px;
    overflow: hidden;
    background: #fff;
}

.reports-sidebar-head {
    background: #14253f;
    padding: 1.15rem 1rem 1rem;
}

.reports-sidebar-kicker {
    color: rgba(255, 255, 255, 0.62);
    font-family: 'IBM Plex Mono', monospace;
    font-size: 0.58rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.reports-sidebar-title {
    margin-top: 0.35rem;
    color: #fff;
    font-family: 'Playfair Display', serif;
    font-size: 1.15rem;
}

.reports-sidebar-list {
    display: grid;
}

.reports-sidebar-link {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    border-top: 1px solid #d6e3f5;
    padding: 0.95rem 1rem;
    color: var(--nv-navy);
    font-size: 0.92rem;
    text-decoration: none;
}

.reports-sidebar-link strong {
    color: #64748b;
    font-family: 'IBM Plex Mono', monospace;
    font-size: 0.7rem;
}

.reports-sidebar-link.is-active {
    border-left: 3px solid var(--nv-blue);
    background: #eef5ff;
    padding-left: calc(1rem - 3px);
}

.reports-main-panel {
    min-width: 0;
}

.reports-main-head {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1rem;
    padding-top: 0.15rem;
}

.reports-main-title {
    color: var(--nv-navy);
    font-family: 'Playfair Display', serif;
    font-size: 1.95rem;
}

.reports-catalog-filter {
    border-top: 1px solid #bfd2ee;
    padding-top: 1rem;
}

.reports-catalog-filter-grid {
    display: grid;
    grid-template-columns: minmax(320px, 1fr) minmax(240px, 300px) 120px;
    gap: 0.75rem;
    align-items: end;
}

.reports-catalog-field {
    display: grid;
    gap: 0.5rem;
}

.reports-catalog-field label {
    font-family: 'IBM Plex Mono', monospace;
    font-size: 0.6875rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--nv-navy);
}

.reports-catalog-field input,
.reports-catalog-field select {
    min-height: 48px;
    border: 1px solid #bfd2ee;
    border-radius: 8px;
    background: #fff;
    color: var(--nv-navy);
    font: inherit;
    padding: 0 0.95rem;
}

.reports-catalog-field input:focus,
.reports-catalog-field select:focus {
    outline: none;
    border-color: var(--nv-blue);
    box-shadow: 0 0 0 3px rgba(0, 87, 184, 0.1);
}

.reports-catalog-btn {
    min-height: 48px;
    width: 100%;
    border: 1px solid var(--nv-blue);
    border-radius: 8px;
    background: var(--nv-blue);
    color: #fff;
    font-weight: 700;
    padding: 0 1rem;
    cursor: pointer;
}

.reports-catalog-meta {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    margin-top: 0.8rem;
    color: #53657f;
    font-family: 'IBM Plex Mono', monospace;
    font-size: 0.72rem;
}

.reports-filter-clear {
    color: #64748b;
    font-size: 0.85rem;
    text-decoration: underline;
    text-underline-offset: 0.16em;
}

.reports-list {
    display: grid;
    gap: 0.85rem;
    margin-top: 1rem;
}

.reports-list-card {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 1rem;
    align-items: center;
    border: 1px solid #bfd2ee;
    border-radius: 8px;
    background: #fff;
    padding: 1.15rem 1.2rem;
}

.reports-list-copy {
    min-width: 0;
}

.reports-list-tag {
    display: inline-flex;
    align-items: center;
    border-radius: 999px;
    background: #eaf2ff;
    color: var(--nv-blue);
    padding: 0.3rem 0.65rem;
    font-family: 'IBM Plex Mono', monospace;
    font-size: 0.64rem;
    font-weight: 700;
    margin-bottom: 0.75rem;
}

.reports-list-title {
    color: var(--nv-navy);
    font-size: 1.05rem;
    line-height: 1.45;
    text-decoration: none;
}

.reports-list-summary {
    margin-top: 0.45rem;
    color: var(--nv-muted);
    font-size: 0.82rem;
    line-height: 1.6;
}

.reports-list-side {
    display: grid;
    justify-items: end;
    gap: 0.75rem;
}

.reports-list-metric {
    color: var(--nv-blue);
    font-family: 'IBM Plex Mono', monospace;
    font-size: 0.78rem;
    font-weight: 700;
    text-transform: uppercase;
}

.reports-list-cta {
    border: 1px solid var(--nv-blue);
    border-radius: 4px;
    color: var(--nv-blue);
    font-size: 0.85rem;
    padding: 0.45rem 0.9rem;
    text-decoration: none;
}

.reports-empty {
    border: 1px solid #bfd2ee;
    border-radius: 6px;
    background: #fff;
    color: var(--nv-muted);
    padding: 2rem;
    text-align: center;
}

.data-strip,
.cta-band {
    background: var(--nv-navy);
}

.data-strip {
    padding: 3.25rem 0;
}

.ds-eye {
    font-size: 0.65625rem;
    text-transform: uppercase;
    letter-spacing: 0.14em;
    color: var(--nv-cyan);
    margin-bottom: 0.5rem;
}

.ds-title {
    font-size: 1.625rem;
    color: #fff;
    margin-bottom: 2rem;
}

.ds-grid {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 4px;
    overflow: hidden;
}

.ds-item {
    padding: 1.25rem;
    border-right: 1px solid rgba(255, 255, 255, 0.08);
}

.ds-item:last-child {
    border-right: none;
}

.ds-label {
    font-size: 0.625rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: rgba(255, 255, 255, 0.4);
    margin-bottom: 0.5rem;
}

.ds-val {
    font-size: 1rem;
    color: #fff;
    font-weight: 500;
}

.ds-note {
    margin-top: 0.9rem;
    max-width: 58rem;
    color: rgba(255, 255, 255, 0.56);
    font-size: 0.75rem;
    line-height: 1.65;
}

.chart-source-note {
    margin-top: 0.85rem;
    color: var(--nv-muted);
    font-size: 0.75rem;
    line-height: 1.6;
}

.why-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 4rem;
    align-items: center;
}

.why-items {
    display: flex;
    flex-direction: column;
    gap: 1.75rem;
}

.why-item {
    display: flex;
    gap: 1.125rem;
}

.why-num {
    font-size: 0.6875rem;
    color: var(--nv-blue);
    font-weight: 500;
    padding-top: 0.125rem;
    min-width: 28px;
}

.why-body-title {
    font-weight: 600;
    font-size: 0.875rem;
    color: var(--nv-navy);
    margin-bottom: 0.25rem;
}

.why-visual {
    background: var(--nv-mist);
    border: 1px solid var(--nv-border);
    border-radius: 8px;
    padding: 2.25rem;
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.why-visual-title {
    font-size: 0.9375rem;
    color: var(--nv-navy);
    margin-bottom: 0.5rem;
}

.wv-row {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    align-items: center;
    padding: 0.875rem 0;
    border-bottom: 1px solid var(--nv-border);
}

.wv-row:last-child {
    border-bottom: none;
}

.wv-label {
    font-size: 0.8125rem;
    color: #475569;
}

.wv-source {
    font-size: 0.6875rem;
    background: #e8f0fb;
    color: var(--nv-blue);
    padding: 0.1875rem 0.5625rem;
    border-radius: 2px;
    white-space: nowrap;
}

.insight-strip,
.clients-strip {
    background: var(--nv-mist);
}

.insight-strip {
    border-top: 1px solid var(--nv-border);
    border-bottom: 1px solid var(--nv-border);
    padding: 3.5rem 0;
}

.ic-type {
    font-size: 0.625rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--nv-blue);
    margin-bottom: 0.625rem;
}

.ic-date {
    color: #c8d6e5;
    margin-top: 0.875rem;
}

.test-quote {
    font-size: 0.875rem;
    color: #475569;
    line-height: 1.7;
    font-style: italic;
    margin-bottom: 1.25rem;
}

.test-person {
    font-size: 0.8125rem;
    font-weight: 600;
    color: var(--nv-navy);
}

.nv-logos-band {
    background: var(--nv-navy);
    position: relative;
    overflow: hidden;
    border-top: 1px solid rgba(255, 255, 255, 0.05);
    border-bottom: 1px solid rgba(255, 255, 255, 0.05);
}

.nv-logos-band::after {
    content: "";
    position: absolute;
    inset: 0;
    background-image:
        linear-gradient(rgba(0, 87, 184, 0.04) 1px, transparent 1px),
        linear-gradient(90deg, rgba(0, 87, 184, 0.04) 1px, transparent 1px);
    background-size: 40px 40px;
    pointer-events: none;
    z-index: 0;
}

.nv-logos-fade {
    position: absolute;
    inset: 0;
    background: linear-gradient(
        90deg,
        var(--nv-navy) 0%,
        transparent 12%,
        transparent 88%,
        var(--nv-navy) 100%
    );
    pointer-events: none;
    z-index: 10;
}

.nv-logos-hdr {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 1rem;
    padding: 1.375rem 3.25rem 0.375rem;
    position: relative;
    z-index: 5;
}

.nv-hdr-line {
    flex: 1;
    max-width: 5rem;
    height: 1px;
    background: rgba(255, 255, 255, 0.06);
}

.nv-hdr-label,
.nv-hdr-count,
.nv-proof-item {
    font-family: "IBM Plex Mono", monospace;
    font-size: 0.5625rem;
    text-transform: uppercase;
    white-space: nowrap;
}

.nv-hdr-label {
    letter-spacing: 0.22em;
    color: rgba(255, 255, 255, 0.22);
    flex-shrink: 0;
}

.nv-hdr-count {
    letter-spacing: 0.15em;
    color: rgba(0, 180, 216, 0.4);
    flex-shrink: 0;
}

.nv-logos-row {
    overflow: hidden;
    padding: 0.875rem 0;
    position: relative;
    z-index: 5;
}

.nv-logos-track {
    display: flex;
    align-items: center;
    width: max-content;
    animation: nv-scroll-right 48s linear infinite;
}

.nv-logos-track:hover {
    animation-play-state: paused;
}

@keyframes nv-scroll-right {
    from { transform: translateX(0); }
    to { transform: translateX(-50%); }
}

.nv-logo-item {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0 2.75rem;
    height: 4.25rem;
    border-right: 1px solid rgba(255, 255, 255, 0.05);
    flex-shrink: 0;
    cursor: default;
    position: relative;
}

.nv-logos-track:hover .nv-logo-item {
    opacity: 0.22;
    transition: opacity 0.2s;
}

.nv-logos-track:hover .nv-logo-item:hover {
    opacity: 1;
}

.nv-logo-item::after {
    content: "";
    position: absolute;
    bottom: 0;
    left: 2.75rem;
    right: 2.75rem;
    height: 1.5px;
    background: var(--nv-cyan);
    transform: scaleX(0);
    transform-origin: left;
    transition: transform 0.22s;
}

.nv-logo-item:hover::after {
    transform: scaleX(1);
}

.nv-proof {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0;
    padding: 0.25rem 3.25rem 1.125rem;
    position: relative;
    z-index: 5;
    flex-wrap: wrap;
}

.nv-proof-item {
    display: flex;
    align-items: center;
    gap: 0.375rem;
    padding: 0 1.125rem;
    border-right: 1px solid rgba(255, 255, 255, 0.06);
    letter-spacing: 0.12em;
    color: rgba(255, 255, 255, 0.18);
}

.nv-proof-item:last-child {
    border-right: none;
}

.nv-proof-dot {
    width: 3px;
    height: 3px;
    border-radius: 50%;
    background: var(--nv-cyan);
    opacity: 0.45;
    flex-shrink: 0;
}

@media (max-width: 768px) {
    .nv-logos-hdr {
        padding: 0.875rem 1.25rem 0.25rem;
    }

    .nv-hdr-label {
        display: none;
    }

    .nv-logo-item {
        padding: 0 1.625rem;
        height: 3.5rem;
    }

    .nv-logo-item::after {
        left: 1.625rem;
        right: 1.625rem;
    }

    .nv-proof {
        padding: 0.25rem 1.25rem 0.875rem;
    }

    .nv-proof-item {
        padding: 0 0.625rem;
        font-size: 0.5rem;
    }
}

@media (max-width: 480px) {
    .nv-proof-item:nth-child(n + 3) {
        display: none;
    }

    .nv-logo-item {
        padding: 0 1.125rem;
    }

    .nv-logo-item::after {
        left: 1.125rem;
        right: 1.125rem;
    }
}

.price-card.hl {
    border-color: var(--nv-blue);
    background: #f5f8ff;
}

.price-badge {
    font-size: 0.625rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    background: var(--nv-blue);
    color: #fff;
    padding: 0.1875rem 0.625rem;
    border-radius: 2px;
    display: inline-block;
    margin-bottom: 1rem;
}

.price-tier {
    font-size: 0.8125rem;
    font-weight: 600;
    color: var(--nv-navy);
    margin-bottom: 0.5rem;
}

.price-amt {
    font-size: 2rem;
    color: var(--nv-navy);
    font-weight: 700;
}

.price-sub {
    margin-bottom: 1.25rem;
}

.price-feats {
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    margin-bottom: 1.5rem;
}

.price-feats li {
    font-size: 0.8125rem;
    color: #475569;
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.price-feats li::before {
    content: '✓';
    color: var(--nv-blue);
    font-size: 0.75rem;
    font-weight: 700;
}

.btn-ol {
    text-align: center;
    border: 1px solid var(--nv-blue);
    color: var(--nv-blue);
    font-weight: 600;
    padding: 0.6875rem;
}

.cta-band {
    padding: 4rem 0;
}

.cta-band-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 2.5rem;
}

.cta-band-title {
    font-size: 1.875rem;
    color: #fff;
}

.cta-band-sub {
    font-size: 0.875rem;
    color: rgba(255, 255, 255, 0.75);
    margin-top: 0.5rem;
}

.btn-white {
    background: #fff;
    color: var(--nv-blue);
    font-weight: 600;
    padding: 0.8125rem 1.75rem;
    white-space: nowrap;
}

.btn-ghost {
    border: 1px solid rgba(255, 255, 255, 0.4);
    color: #fff;
    font-weight: 500;
    padding: 0.8125rem 1.5rem;
    white-space: nowrap;
}

.btn-ghost:hover {
    border-color: rgba(255, 255, 255, 0.6);
}

@media (max-width: 1100px) {
    .hero-inner,
    .why-grid,
    .cta-band-inner {
        grid-template-columns: 1fr;
        display: grid;
    }

    .reports-directory-layout {
        grid-template-columns: 1fr;
    }

    .sector-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .reports-grid,
    .insight-grid,
    .test-grid,
    .price-grid,
    .ds-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .reports-catalog-filter-grid {
        grid-template-columns: 1fr 1fr;
    }

    .ds-item:nth-child(2n) {
        border-right: none;
    }
}

@media (max-width: 768px) {
    .sec-hdr,
    .clients-inner {
        flex-direction: column;
        align-items: flex-start;
    }

    .hero-inner {
        padding-top: 4rem;
        padding-bottom: 4rem;
    }

    .sector-grid,
    .reports-grid,
    .insight-grid,
    .test-grid,
    .price-grid,
    .ds-grid,
    .why-grid {
        grid-template-columns: 1fr;
    }

    .reports-catalog-title {
        font-size: 2.25rem;
    }

    .reports-catalog-chips {
        display: grid;
        grid-template-columns: 1fr;
    }

    .reports-catalog-filter-grid {
        grid-template-columns: 1fr;
    }

    .reports-catalog-btn {
        width: 100%;
    }

    .reports-list-card {
        grid-template-columns: 1fr;
    }

    .reports-list-side {
        justify-items: start;
    }

    .ds-item {
        border-right: none;
        border-bottom: 1px solid rgba(255, 255, 255, 0.08);
    }

    .ds-item:last-child {
        border-bottom: none;
    }

    .why-visual,
    .report-card,
    .insight-card,
    .test-card,
    .price-card {
        padding: 1.25rem;
    }
}

.page-hero {
    background: var(--nv-navy-2);
    padding: 4rem 0 3.5rem;
    position: relative;
    overflow: hidden;
}

.page-hero::before {
    content: '';
    position: absolute;
    inset: 0;
    background: radial-gradient(ellipse at 65% 50%, rgba(0, 180, 216, 0.07) 0%, transparent 60%);
}

.page-hero::after {
    content: '';
    position: absolute;
    inset: 0;
    background-image: linear-gradient(rgba(0, 87, 184, 0.05) 1px, transparent 1px),
        linear-gradient(90deg, rgba(0, 87, 184, 0.05) 1px, transparent 1px);
    background-size: 40px 40px;
    pointer-events: none;
}

.ph-inner {
    max-width: 1280px;
    margin: 0 auto;
    padding: 0 1.5rem;
    position: relative;
    z-index: 1;
}

.ph-kicker {
    font-family: 'IBM Plex Mono', monospace;
    font-size: 0.6875rem;
    text-transform: uppercase;
    letter-spacing: 0.14em;
    color: var(--nv-cyan);
    margin-bottom: 0.875rem;
}

.ph-h1 {
    font-family: 'Playfair Display', serif;
    font-size: clamp(2.2rem, 5vw, 2.625rem);
    color: #fff;
    line-height: 1.18;
    margin-bottom: 1rem;
    max-width: 700px;
}

.ph-sub {
    font-size: 0.9375rem;
    color: rgba(255, 255, 255, 0.58);
    max-width: 620px;
    line-height: 1.72;
}

.sc-hero {
    background: var(--nv-navy);
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 8px;
    padding: 3.25rem;
    margin-bottom: 1.75rem;
    display: grid;
    grid-template-columns: minmax(0, 1fr) 380px;
    gap: 3.5rem;
    align-items: center;
    position: relative;
    overflow: hidden;
}

.sc-hero::before {
    content: '';
    position: absolute;
    right: -60px;
    top: -60px;
    width: 320px;
    height: 320px;
    background: radial-gradient(circle, rgba(0, 180, 216, 0.08) 0%, transparent 70%);
    pointer-events: none;
}

.sc-hero-badge,
.sc-vis-label,
.svc-tag,
.sc-mod-tag,
.persona-role,
.case-tag,
.case-challenge {
    font-family: 'IBM Plex Mono', monospace;
}

.sc-hero-badge {
    font-size: 0.625rem;
    text-transform: uppercase;
    letter-spacing: 0.14em;
    background: rgba(0, 180, 216, 0.15);
    color: var(--nv-cyan);
    padding: 0.25rem 0.75rem;
    border-radius: 2px;
    display: inline-block;
    margin-bottom: 1.125rem;
}

.sc-hero-title {
    font-family: 'Playfair Display', serif;
    font-size: 1.75rem;
    color: #fff;
    line-height: 1.25;
    margin-bottom: 1rem;
}

.sc-hero-body {
    font-size: 0.875rem;
    color: rgba(255, 255, 255, 0.6);
    line-height: 1.78;
    margin-bottom: 1.75rem;
}

.sc-hero-features,
.sc-node-list {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

.sc-feat {
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
}

.sc-feat-dot {
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: var(--nv-cyan);
    margin-top: 7px;
    flex-shrink: 0;
}

.sc-feat-text {
    font-size: 0.84375rem;
    color: rgba(255, 255, 255, 0.72);
    line-height: 1.6;
}

.sc-hero-btns {
    display: flex;
    gap: 0.75rem;
    flex-wrap: wrap;
}

.btn-cyan {
    background: var(--nv-cyan);
    color: var(--nv-navy);
    font-size: 0.8125rem;
    font-weight: 700;
    padding: 0.75rem 1.625rem;
    border-radius: 3px;
}

.btn-ghost-white {
    border: 1px solid rgba(255, 255, 255, 0.25);
    color: rgba(255, 255, 255, 0.8);
    font-size: 0.8125rem;
    padding: 0.75rem 1.375rem;
    border-radius: 3px;
}

.sc-hero-visual {
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 6px;
    padding: 1.75rem;
}

.sc-vis-label {
    font-size: 0.625rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: rgba(255, 255, 255, 0.35);
    margin-bottom: 1.125rem;
}

.sc-node {
    display: flex;
    align-items: center;
    gap: 0.875rem;
}

.sc-node-icon {
    width: 36px;
    height: 36px;
    border-radius: 4px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.8125rem;
    flex-shrink: 0;
    color: #fff;
}

.sc-node-icon.wafer { background: rgba(0, 87, 184, 0.3); }
.sc-node-icon.fab { background: rgba(0, 180, 216, 0.2); }
.sc-node-icon.asm { background: rgba(181, 134, 42, 0.2); }
.sc-node-icon.dist { background: rgba(34, 197, 94, 0.15); }

.sc-node-name {
    font-size: 0.8125rem;
    font-weight: 500;
    color: #fff;
}

.sc-node-detail {
    font-family: 'IBM Plex Mono', monospace;
    font-size: 0.65625rem;
    color: rgba(255, 255, 255, 0.4);
}

.sc-node-arrow {
    margin-left: auto;
    font-family: 'IBM Plex Mono', monospace;
    font-size: 0.625rem;
    color: rgba(255, 255, 255, 0.45);
}

.services-grid,
.personas-grid,
.cases-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1.5rem;
}

.service-card {
    border: 1px solid var(--nv-border);
    border-radius: 6px;
    padding: 2rem;
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
    background: #fff;
}

.service-card:hover {
    border-color: var(--nv-blue);
    box-shadow: 0 4px 20px rgba(0, 87, 184, 0.09);
}

.svc-icon,
.sc-mod-icon {
    font-size: 1.375rem;
    margin-bottom: 1rem;
}

.svc-tag,
.sc-mod-tag,
.persona-role {
    font-size: 0.625rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--nv-blue);
    margin-bottom: 0.625rem;
}

.svc-title,
.sc-mod-title,
.persona-title,
.case-title {
    font-family: 'Playfair Display', serif;
    color: var(--nv-navy);
}

.svc-title {
    font-size: 1.125rem;
    margin-bottom: 0.75rem;
    line-height: 1.3;
}

.svc-body,
.sc-mod-body,
.persona-pain,
.ps-body,
.case-body {
    font-size: 0.84375rem;
    color: var(--nv-muted);
    line-height: 1.72;
}

.svc-deliverables,
.persona-uses {
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: 0.4375rem;
}

.svc-deliverables {
    margin: 0 0 1.5rem;
}

.svc-deliverables li,
.persona-uses li {
    font-size: 0.78125rem;
    color: #475569;
    display: flex;
    gap: 0.5rem;
    line-height: 1.5;
}

.svc-deliverables li::before {
    content: '->';
    color: var(--nv-blue);
    font-size: 0.6875rem;
    flex-shrink: 0;
}

.svc-link {
    font-size: 0.8125rem;
    color: var(--nv-blue);
    font-weight: 600;
}

.sc-modules {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1.25rem;
}

.sc-module {
    border: 1px solid var(--nv-border);
    border-radius: 6px;
    padding: 1.75rem;
    display: flex;
    gap: 1.25rem;
}

.sc-mod-title {
    font-size: 1rem;
    margin-bottom: 0.5rem;
}

.sc-mod-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 0.375rem;
    margin-top: 0.75rem;
}

.sc-mod-pill {
    font-family: 'IBM Plex Mono', monospace;
    font-size: 0.625rem;
    background: var(--nv-mist);
    color: #475569;
    padding: 0.1875rem 0.625rem;
    border-radius: 2px;
}

.persona-card {
    border-left: 3px solid var(--nv-blue);
    padding: 1.5rem 1.5rem 1.5rem 1.75rem;
    background: #fff;
    border-radius: 0 6px 6px 0;
    border-top: 1px solid var(--nv-border);
    border-right: 1px solid var(--nv-border);
    border-bottom: 1px solid var(--nv-border);
}

.persona-title {
    font-size: 1rem;
    margin-bottom: 0.625rem;
}

.persona-use {
    font-size: 0.78125rem;
    font-weight: 600;
    color: var(--nv-navy);
    margin: 0.875rem 0 0.375rem;
}

.persona-uses li::before {
    content: '.';
    color: var(--nv-cyan);
    font-weight: 700;
}

.case-card {
    background: var(--nv-navy);
    border-radius: 6px;
    padding: 1.75rem;
}

.case-tag {
    font-size: 0.625rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    background: rgba(0, 87, 184, 0.3);
    color: #7fb3ff;
    padding: 0.1875rem 0.625rem;
    border-radius: 2px;
    display: inline-block;
    margin-bottom: 1rem;
}

.case-challenge {
    font-size: 0.75rem;
    font-weight: 600;
    color: rgba(255, 255, 255, 0.45);
    text-transform: uppercase;
    letter-spacing: 0.06em;
    margin-bottom: 0.5rem;
}

.case-title {
    font-size: 1rem;
    color: #fff;
    line-height: 1.4;
    margin-bottom: 0.875rem;
}

.case-body {
    color: rgba(255, 255, 255, 0.55);
    margin-bottom: 1rem;
}

.case-outcome {
    font-family: 'IBM Plex Mono', monospace;
    font-size: 0.75rem;
    color: var(--nv-cyan);
    border-top: 1px solid rgba(255, 255, 255, 0.08);
    padding-top: 0.875rem;
}

.process-steps {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    position: relative;
}

.process-steps::before {
    content: '';
    position: absolute;
    top: 28px;
    left: calc(12.5% + 14px);
    right: calc(12.5% + 14px);
    height: 1px;
    background: var(--nv-border);
    z-index: 0;
}

.process-step {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    padding: 0 1.25rem;
    position: relative;
    z-index: 1;
}

.ps-num {
    width: 56px;
    height: 56px;
    border-radius: 50%;
    background: var(--nv-navy);
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: 'IBM Plex Mono', monospace;
    font-size: 0.875rem;
    font-weight: 500;
    margin-bottom: 1.125rem;
    border: 3px solid #fff;
    box-shadow: 0 0 0 1px var(--nv-border);
}

.ps-title {
    font-weight: 600;
    font-size: 0.875rem;
    color: var(--nv-navy);
    margin-bottom: 0.5rem;
}

@media (max-width: 1100px) {
    .sc-hero,
    .sc-modules,
    .services-grid,
    .personas-grid,
    .cases-grid,
    .process-steps {
        grid-template-columns: 1fr;
    }

    .process-steps::before {
        display: none;
    }
}

.legal-hero {
    background: var(--nv-navy-2);
    padding: 3.25rem 0;
    position: relative;
    overflow: hidden;
}

.legal-hero::after {
    content: '';
    position: absolute;
    inset: 0;
    background-image: linear-gradient(rgba(0, 87, 184, 0.05) 1px, transparent 1px),
        linear-gradient(90deg, rgba(0, 87, 184, 0.05) 1px, transparent 1px);
    background-size: 40px 40px;
    pointer-events: none;
}

.lh-inner {
    max-width: 1280px;
    margin: 0 auto;
    padding: 0 1.5rem;
    position: relative;
    z-index: 1;
}

.lh-breadcrumb,
.lh-kicker,
.lh-meta-item,
.ls-num,
.sb-toc-num {
    font-family: 'IBM Plex Mono', monospace;
}

.lh-breadcrumb {
    font-size: 0.6875rem;
    color: rgba(255, 255, 255, 0.4);
    margin-bottom: 0.875rem;
}

.lh-breadcrumb span {
    color: rgba(255, 255, 255, 0.6);
}

.lh-kicker {
    font-size: 0.65625rem;
    text-transform: uppercase;
    letter-spacing: 0.14em;
    color: var(--nv-cyan);
    margin-bottom: 0.75rem;
}

.lh-h1 {
    font-family: 'Playfair Display', serif;
    font-size: 2.25rem;
    color: #fff;
    margin-bottom: 0.75rem;
}

.lh-sub {
    font-size: 0.875rem;
    color: rgba(255, 255, 255, 0.55);
    max-width: 640px;
    line-height: 1.7;
    margin-bottom: 1.75rem;
}

.lh-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 2rem;
    border-top: 1px solid rgba(255, 255, 255, 0.1);
    padding-top: 1.125rem;
}

.lh-meta-item {
    font-size: 0.6875rem;
    color: rgba(255, 255, 255, 0.35);
}

.lh-meta-val {
    color: rgba(255, 255, 255, 0.65);
    display: block;
    margin-top: 0.25rem;
}

.legal-body {
    max-width: 1280px;
    margin: 0 auto;
    padding: 3.25rem 1.5rem;
    display: grid;
    grid-template-columns: minmax(0, 1fr) 280px;
    gap: 3.25rem;
}

.legal-section {
    margin-bottom: 3.25rem;
    padding-bottom: 3.25rem;
    border-bottom: 1px solid var(--nv-border);
}

.legal-section:last-child {
    border-bottom: none;
    margin-bottom: 0;
    padding-bottom: 0;
}

.ls-num {
    font-size: 0.625rem;
    text-transform: uppercase;
    letter-spacing: 0.14em;
    color: var(--nv-blue);
    margin-bottom: 0.625rem;
}

.ls-title {
    font-family: 'Playfair Display', serif;
    font-size: 1.375rem;
    color: var(--nv-navy);
    margin-bottom: 1rem;
}

.ls-body {
    font-size: 0.875rem;
    color: #475569;
    line-height: 1.82;
}

.ls-body p {
    margin-bottom: 0.875rem;
}

.ls-list,
.sb-toc {
    list-style: none;
}

.ls-list {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    margin: 0.875rem 0;
}

.ls-list li {
    display: flex;
    align-items: flex-start;
    gap: 0.625rem;
    font-size: 0.84375rem;
    color: #475569;
    line-height: 1.6;
}

.ls-list li::before {
    content: '->';
    color: var(--nv-blue);
    font-size: 0.6875rem;
    padding-top: 0.1875rem;
    flex-shrink: 0;
}

.ls-callout {
    background: var(--nv-mist);
    border-left: 3px solid var(--nv-blue);
    padding: 1rem 1.25rem;
    border-radius: 0 4px 4px 0;
    margin: 1.25rem 0;
}

.ls-callout.warn {
    border-left-color: #b5862a;
    background: #fef9ec;
}

.ls-callout-head {
    font-size: 0.75rem;
    font-weight: 700;
    color: var(--nv-navy);
    margin-bottom: 0.375rem;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.ls-callout-body {
    font-size: 0.8125rem;
    color: #475569;
    line-height: 1.68;
}

.contact-block {
    background: var(--nv-navy);
    border-radius: 6px;
    padding: 1.5rem;
    margin-top: 1rem;
}

.cb-label {
    font-family: 'IBM Plex Mono', monospace;
    font-size: 0.625rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: rgba(255, 255, 255, 0.4);
    margin-bottom: 0.75rem;
}

.cb-line {
    font-size: 0.84375rem;
    color: rgba(255, 255, 255, 0.75);
    margin-bottom: 0.375rem;
}

.contact-hero {
    background:
        radial-gradient(circle at 12% 18%, rgba(0, 180, 216, 0.12), transparent 26%),
        linear-gradient(180deg, #f7fbff 0%, #eef5fb 100%);
    padding: 4rem 0 3rem;
}

.contact-shell {
    display: grid;
    grid-template-columns: minmax(0, 1.05fr) minmax(380px, 0.95fr);
    gap: 2rem;
    align-items: start;
}

.contact-kicker,
.contact-form-kicker {
    font-family: 'IBM Plex Mono', monospace;
    font-size: 0.72rem;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: var(--nv-blue);
}

.contact-title {
    margin-top: 0.9rem;
    font-family: 'Playfair Display', serif;
    font-size: clamp(2.5rem, 4vw, 4rem);
    line-height: 1.04;
    letter-spacing: -0.03em;
    color: var(--nv-navy);
    max-width: 14ch;
}

.contact-intro {
    margin-top: 1.2rem;
    max-width: 60ch;
    color: #586981;
    font-size: 1rem;
    line-height: 1.8;
}

.contact-points {
    margin-top: 2rem;
    display: grid;
    gap: 1rem;
}

.contact-point {
    background: rgba(255, 255, 255, 0.82);
    border: 1px solid rgba(12, 26, 46, 0.08);
    border-radius: 18px;
    padding: 1rem 1.1rem;
}

.contact-point-head {
    font-size: 1rem;
    font-weight: 700;
    color: var(--nv-navy);
}

.contact-point-body {
    margin-top: 0.45rem;
    color: #62748a;
    font-size: 0.92rem;
    line-height: 1.65;
}

.contact-meta-grid {
    margin-top: 1.5rem;
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.9rem;
}

.contact-meta-card {
    background: #0f2033;
    border-radius: 16px;
    padding: 1rem;
    border: 1px solid rgba(0, 180, 216, 0.12);
}

.contact-meta-label {
    font-family: 'IBM Plex Mono', monospace;
    font-size: 0.66rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: rgba(255, 255, 255, 0.42);
}

.contact-meta-value {
    margin-top: 0.55rem;
    color: #edf6ff;
    font-size: 0.9rem;
    line-height: 1.5;
}

.contact-form-card {
    background: #0f1d2c;
    border-radius: 26px;
    padding: 1.4rem;
    border: 1px solid rgba(0, 180, 216, 0.14);
    box-shadow: 0 24px 64px rgba(12, 26, 46, 0.14);
}

.contact-form-card-shared {
    background: #fff;
    border: 1.5px solid var(--nv-border);
    border-radius: 8px;
    padding: 0;
    overflow: hidden;
    position: sticky;
    top: 5rem;
    box-shadow: none;
}

.contact-form-head {
    padding: 0.2rem 0.2rem 1rem;
}

.contact-form-title {
    margin-top: 0.55rem;
    font-size: 2rem;
    line-height: 1.1;
    color: #f4f8fc;
    font-family: 'Playfair Display', serif;
}

.contact-form-sub {
    margin-top: 0.65rem;
    color: rgba(244, 248, 252, 0.62);
    font-size: 0.92rem;
    line-height: 1.65;
}

.contact-form-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
}

.contact-field {
    display: grid;
    gap: 0.45rem;
}

.contact-field-full {
    grid-column: 1 / -1;
}

.contact-field label {
    font-family: 'IBM Plex Mono', monospace;
    font-size: 0.68rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: rgba(244, 248, 252, 0.58);
}

.contact-field input,
.contact-field select,
.contact-field textarea {
    width: 100%;
    border: 1px solid rgba(255, 255, 255, 0.08);
    background: rgba(255, 255, 255, 0.04);
    color: #edf6ff;
    border-radius: 14px;
    padding: 0.85rem 0.95rem;
    font-size: 0.92rem;
    outline: none;
    transition: border-color 0.18s ease, background-color 0.18s ease;
}

.contact-field textarea {
    resize: vertical;
    min-height: 150px;
}

.contact-field input::placeholder,
.contact-field textarea::placeholder {
    color: rgba(237, 246, 255, 0.34);
}

.contact-field input:focus,
.contact-field select:focus,
.contact-field textarea:focus {
    border-color: rgba(0, 180, 216, 0.46);
    background: rgba(255, 255, 255, 0.07);
}

.contact-form-actions {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding-top: 0.35rem;
}

.contact-submit {
    min-height: 46px;
    padding: 0 1.35rem;
    border: 0;
    border-radius: 999px;
    background: linear-gradient(135deg, var(--nv-blue), var(--nv-cyan));
    color: #fff;
    font-size: 0.82rem;
    font-weight: 700;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    cursor: pointer;
}

.contact-form-note {
    color: rgba(244, 248, 252, 0.54);
    font-size: 0.84rem;
    line-height: 1.55;
    text-align: right;
}

.contact-steps {
    margin-top: 2rem;
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1rem;
}

.contact-step {
    background: #fff;
    border-radius: 20px;
    padding: 1.3rem;
    border: 1px solid rgba(12, 26, 46, 0.08);
}

.contact-step-num {
    font-family: 'IBM Plex Mono', monospace;
    font-size: 0.74rem;
    color: var(--nv-blue);
    letter-spacing: 0.1em;
}

.contact-step-title {
    margin-top: 0.7rem;
    color: var(--nv-navy);
    font-size: 1.02rem;
    font-weight: 700;
}

.contact-step-body {
    margin-top: 0.55rem;
    color: #62748a;
    font-size: 0.92rem;
    line-height: 1.7;
}

.rf-hero {
    background: var(--nv-navy-2);
    padding: 3.25rem 0 3rem;
    position: relative;
    overflow: hidden;
}

.rf-hero::after {
    content: '';
    position: absolute;
    inset: 0;
    background-image: linear-gradient(rgba(0, 87, 184, 0.05) 1px, transparent 1px),
        linear-gradient(90deg, rgba(0, 87, 184, 0.05) 1px, transparent 1px);
    background-size: 40px 40px;
    pointer-events: none;
}

.rf-hero-inner,
.rf-step-inner,
.rf-body {
    max-width: 1280px;
    margin: 0 auto;
    padding-left: 2.5rem;
    padding-right: 2.5rem;
    position: relative;
    z-index: 1;
}

.rf-breadcrumb {
    font-family: 'IBM Plex Mono', monospace;
    font-size: 0.68rem;
    color: rgba(255, 255, 255, 0.42);
    letter-spacing: 0.06em;
    margin-bottom: 1rem;
}

.rf-breadcrumb span {
    color: rgba(255, 255, 255, 0.68);
}

.rf-title {
    font-family: 'Playfair Display', serif;
    font-size: clamp(2.2rem, 4vw, 3.2rem);
    line-height: 1.1;
    color: #fff;
    letter-spacing: -0.02em;
}

.rf-sub {
    margin-top: 0.8rem;
    max-width: 40rem;
    color: rgba(255, 255, 255, 0.62);
    font-size: 0.98rem;
    line-height: 1.75;
}

.rf-report-strip {
    margin-top: 1.6rem;
    display: flex;
    align-items: center;
    gap: 0.9rem;
    max-width: 42rem;
    background: rgba(255, 255, 255, 0.05);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 6px;
    padding: 0.95rem 1.1rem;
}

.rf-report-icon {
    width: 2.35rem;
    height: 2.35rem;
    background: rgba(0, 87, 184, 0.35);
    border-radius: 4px;
    flex: 0 0 auto;
}

.rf-report-label {
    font-family: 'IBM Plex Mono', monospace;
    font-size: 0.62rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: rgba(255, 255, 255, 0.4);
}

.rf-report-name {
    color: #fff;
    font-size: 0.92rem;
    font-weight: 600;
    line-height: 1.35;
}

.rf-report-meta {
    margin-top: 0.15rem;
    font-family: 'IBM Plex Mono', monospace;
    font-size: 0.66rem;
    color: rgba(255, 255, 255, 0.42);
}

.rf-step-bar {
    background: var(--nv-mist);
    border-bottom: 1px solid var(--nv-border);
}

.rf-step-inner {
    display: flex;
    align-items: center;
    gap: 0;
    min-height: 3.25rem;
}

.rf-step {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.8rem;
    font-weight: 500;
    color: var(--nv-muted);
    padding-right: 1.15rem;
}

.rf-step-num {
    width: 1.4rem;
    height: 1.4rem;
    border-radius: 999px;
    border: 1.5px solid var(--nv-border);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-family: 'IBM Plex Mono', monospace;
    font-size: 0.62rem;
    color: var(--nv-muted);
}

.rf-step.done .rf-step-num,
.rf-step.active .rf-step-num {
    background: var(--nv-blue);
    border-color: var(--nv-blue);
    color: #fff;
}

.rf-step.active {
    color: var(--nv-navy);
}

.rf-step-arrow {
    color: var(--nv-border);
    padding-right: 1.15rem;
}

.rf-body {
    padding-top: 3.25rem;
    padding-bottom: 5rem;
    display: grid;
    grid-template-columns: minmax(0, 1fr) 25rem;
    gap: 3.25rem;
    align-items: start;
}

.rf-section-label {
    font-family: 'IBM Plex Mono', monospace;
    font-size: 0.66rem;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--nv-blue);
    margin-bottom: 0.5rem;
}

.rf-section-title {
    font-family: 'Playfair Display', serif;
    font-size: 1.45rem;
    color: var(--nv-navy);
    line-height: 1.25;
}

.rf-section-sub {
    margin-top: 0.45rem;
    max-width: 34rem;
    color: var(--nv-muted);
    font-size: 0.92rem;
    line-height: 1.7;
    margin-bottom: 2rem;
}

.rf-feature-card {
    border: 1px solid var(--nv-border);
    border-radius: 8px;
    overflow: hidden;
}

.rf-feature-head {
    background: var(--nv-navy);
    padding: 1rem 1.35rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
}

.rf-feature-title {
    font-family: 'IBM Plex Mono', monospace;
    font-size: 0.64rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: rgba(255, 255, 255, 0.46);
}

.rf-feature-badge {
    font-family: 'IBM Plex Mono', monospace;
    font-size: 0.6rem;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    background: rgba(0, 180, 216, 0.18);
    color: var(--nv-cyan);
    padding: 0.2rem 0.55rem;
    border-radius: 2px;
}

.rf-feature-row {
    padding: 1rem 1.35rem;
    border-bottom: 1px solid var(--nv-border);
}

.rf-feature-row-rich {
    display: grid;
    grid-template-columns: 2rem minmax(0, 1fr) auto;
    gap: 0.9rem;
    align-items: center;
}

.rf-feature-row-muted {
    opacity: 0.62;
    background: #f8fafc;
}

.rf-feature-row:last-child {
    border-bottom: 0;
}

.rf-feature-icon {
    width: 2rem;
    height: 2rem;
    border-radius: 4px;
    position: relative;
    flex: 0 0 auto;
}

.rf-feature-icon::before,
.rf-feature-icon::after {
    content: '';
    position: absolute;
    background: currentColor;
    border-radius: 999px;
}

.rf-feature-icon::before {
    left: 0.5rem;
    right: 0.5rem;
    top: 0.62rem;
    height: 2px;
}

.rf-feature-icon::after {
    left: 0.5rem;
    right: 0.82rem;
    top: 1.05rem;
    height: 2px;
}

.rf-feature-icon-blue {
    color: var(--nv-blue);
    background: rgba(0, 87, 184, 0.1);
}

.rf-feature-icon-cyan {
    color: var(--nv-cyan);
    background: rgba(0, 180, 216, 0.12);
}

.rf-feature-icon-navy {
    color: var(--nv-navy);
    background: rgba(12, 26, 46, 0.08);
}

.rf-feature-icon-lock {
    color: var(--nv-muted);
    background: rgba(100, 116, 139, 0.1);
}

.rf-feature-icon-lock::before {
    left: 0.62rem;
    right: 0.62rem;
    top: 0.95rem;
    height: 0.52rem;
    border-radius: 2px;
}

.rf-feature-icon-lock::after {
    width: 0.62rem;
    height: 0.42rem;
    left: 0.69rem;
    right: auto;
    top: 0.52rem;
    background: transparent;
    border: 2px solid currentColor;
    border-bottom: 0;
    border-radius: 999px 999px 0 0;
}

.rf-mini-tag {
    align-self: start;
    margin-top: 0.15rem;
    font-family: 'IBM Plex Mono', monospace;
    font-size: 0.56rem;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--nv-cyan);
    background: rgba(0, 180, 216, 0.12);
    border-radius: 2px;
    padding: 0.18rem 0.45rem;
    white-space: nowrap;
}

.rf-mini-tag-muted {
    color: var(--nv-muted);
    background: rgba(100, 116, 139, 0.1);
}

.rf-feature-name {
    color: var(--nv-navy);
    font-size: 0.9rem;
    font-weight: 700;
}

.rf-feature-desc {
    margin-top: 0.2rem;
    color: var(--nv-muted);
    font-size: 0.8rem;
    line-height: 1.65;
}

.rf-note {
    margin-top: 1.5rem;
    border-left: 3px solid var(--nv-blue);
    background: #f8fafc;
    border-radius: 0 6px 6px 0;
    padding: 0.95rem 1rem;
}

.rf-note-head {
    font-size: 0.75rem;
    font-weight: 700;
    color: var(--nv-navy);
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.rf-note-body {
    margin-top: 0.35rem;
    color: var(--nv-slate);
    font-size: 0.84rem;
    line-height: 1.65;
}

.rf-trust-grid {
    margin-top: 1.5rem;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0.65rem;
}

.rf-trust-item {
    display: flex;
    align-items: center;
    min-height: 2.8rem;
    padding: 0.75rem 0.9rem;
    background: var(--nv-mist);
    border: 1px solid var(--nv-border);
    border-radius: 6px;
    color: var(--nv-muted);
    font-size: 0.78rem;
    line-height: 1.45;
}

.rf-form-card {
    border: 1.5px solid var(--nv-border);
    border-radius: 8px;
    overflow: hidden;
    position: sticky;
    top: 5rem;
    background: #fff;
}

.rf-form-head {
    background: linear-gradient(135deg, var(--nv-navy) 0%, #0d3a6b 100%);
    padding: 1.35rem 1.5rem 1.2rem;
}

.rf-form-tag {
    font-family: 'IBM Plex Mono', monospace;
    font-size: 0.62rem;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--nv-cyan);
}

.rf-form-title {
    margin-top: 0.45rem;
    font-family: 'Playfair Display', serif;
    font-size: 1.35rem;
    color: #fff;
    line-height: 1.2;
}

.rf-form-sub {
    margin-top: 0.4rem;
    color: rgba(255, 255, 255, 0.52);
    font-size: 0.8rem;
    line-height: 1.6;
}

.rf-form-delivery {
    background: rgba(0, 180, 216, 0.12);
    border-bottom: 1px solid rgba(0, 180, 216, 0.2);
    padding: 0.7rem 1.25rem;
    font-family: 'IBM Plex Mono', monospace;
    font-size: 0.68rem;
    letter-spacing: 0.08em;
    color: var(--nv-cyan);
}

.rf-form-body {
    padding: 1.35rem 1.5rem 1.25rem;
}

.rf-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0.8rem;
    margin-bottom: 0.8rem;
}

.rf-row-full {
    grid-template-columns: 1fr;
}

.rf-field {
    display: flex;
    flex-direction: column;
    gap: 0.3rem;
}

.rf-field label {
    font-family: 'IBM Plex Mono', monospace;
    font-size: 0.62rem;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--nv-navy);
    font-weight: 600;
}

.rf-field input,
.rf-field select,
.rf-field textarea {
    width: 100%;
    padding: 0.7rem 0.8rem;
    border: 1.5px solid var(--nv-border);
    border-radius: 4px;
    font-family: 'Inter', sans-serif;
    font-size: 0.85rem;
    color: var(--nv-text);
    background: #fff;
    outline: none;
}

.rf-field textarea {
    resize: vertical;
    min-height: 9rem;
}

.rf-field input::placeholder,
.rf-field textarea::placeholder {
    color: var(--nv-silver);
}

.rf-privacy {
    font-size: 0.72rem;
    color: var(--nv-muted);
    line-height: 1.6;
    margin: 0.9rem 0 1rem;
    padding: 0.8rem 0.9rem;
    background: var(--nv-mist);
    border-radius: 4px;
    border: 1px solid var(--nv-border);
}

.rf-privacy a {
    color: var(--nv-blue);
    font-weight: 700;
}

.rf-consent {
    display: flex;
    align-items: flex-start;
    gap: 0.45rem;
    margin-top: 0.6rem;
    color: var(--nv-slate);
    font-size: 0.72rem;
    line-height: 1.5;
    text-transform: none;
    letter-spacing: 0;
}

.rf-consent input {
    width: auto;
    margin-top: 0.12rem;
}

.rf-submit {
    width: 100%;
    min-height: 2.9rem;
    background: var(--nv-cyan);
    color: var(--nv-navy);
    border: 0;
    border-radius: 4px;
    font-size: 0.9rem;
    font-weight: 700;
    cursor: pointer;
}

.rf-success {
    margin: 0 1.5rem 1rem;
    padding: 0.9rem 1rem;
    border: 1px solid rgba(0, 180, 216, 0.35);
    background: #eefbfd;
    color: var(--nv-navy);
    border-radius: 4px;
    font-size: 0.8125rem;
    line-height: 1.6;
}

.rf-error-summary {
    border-color: rgba(220, 38, 38, 0.35);
    background: #fef2f2;
    color: #991b1b;
}

.nv-hp-field {
    position: absolute;
    left: -10000px;
    width: 1px;
    height: 1px;
    overflow: hidden;
}

.rf-submit-note {
    font-size: 0.68rem;
    color: var(--nv-muted);
    text-align: center;
    margin-top: 0.55rem;
}

.legal-sidebar {
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
    position: sticky;
    top: 80px;
    align-self: start;
}

.sb-card {
    border: 1px solid var(--nv-border);
    border-radius: 6px;
    padding: 1.25rem;
    background: #fff;
}

.sb-head {
    font-family: 'Playfair Display', serif;
    font-size: 0.875rem;
    color: var(--nv-navy);
    margin-bottom: 0.875rem;
}

.sb-toc {
    display: flex;
    flex-direction: column;
    gap: 0.125rem;
}

.sb-toc li a {
    font-size: 0.8125rem;
    color: var(--nv-muted);
    display: flex;
    gap: 0.625rem;
    align-items: baseline;
    padding: 0.375rem 0;
    border-bottom: 1px solid var(--nv-border);
    transition: color 0.2s ease;
}

.sb-toc li:last-child a {
    border-bottom: none;
}

.sb-toc li a:hover,
.sb-link:hover {
    color: var(--nv-blue);
}

.sb-toc-num {
    font-size: 0.625rem;
    color: var(--nv-blue);
}

.sb-link {
    font-size: 0.8125rem;
    color: var(--nv-blue);
    font-weight: 500;
    display: block;
    margin-bottom: 0.5rem;
}

.sb-facts,
.sb-tier-sum {
    display: flex;
    flex-direction: column;
    gap: 0.5625rem;
}

.sb-fact,
.sb-tier-row {
    font-size: 0.78125rem;
    color: #475569;
    line-height: 1.5;
}

.sb-fact::before {
    content: 'OK';
    color: var(--nv-blue);
    font-weight: 700;
    font-size: 0.6875rem;
    padding-right: 0.5rem;
}

.sb-tier-row {
    padding: 0.5rem 0;
    border-bottom: 1px solid var(--nv-border);
}

.sb-tier-row:last-child {
    border-bottom: none;
}

.license-tiers {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1rem;
    margin: 1.25rem 0;
}

.tier-card {
    border: 1px solid var(--nv-border);
    border-radius: 6px;
    padding: 1.375rem;
    background: #fff;
}

.tier-card.hl {
    border-color: var(--nv-blue);
    background: #f5f8ff;
}

.tier-label {
    font-family: 'IBM Plex Mono', monospace;
    font-size: 0.625rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--nv-blue);
    margin-bottom: 0.375rem;
}

.tier-name {
    font-weight: 700;
    font-size: 0.875rem;
    color: var(--nv-navy);
    margin-bottom: 0.25rem;
}

.tier-price {
    font-family: 'Playfair Display', serif;
    font-size: 1.375rem;
    color: var(--nv-navy);
    margin-bottom: 0.5rem;
}

.tier-desc,
.om-detail {
    font-size: 0.78125rem;
    color: var(--nv-muted);
    line-height: 1.6;
}

.order-methods {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    margin: 1rem 0;
}

.om-row {
    display: grid;
    grid-template-columns: 100px 1fr;
    gap: 1rem;
    padding: 0.875rem;
    border: 1px solid var(--nv-border);
    border-radius: 4px;
}

.om-label {
    font-family: 'IBM Plex Mono', monospace;
    font-size: 0.6875rem;
    font-weight: 600;
    color: var(--nv-blue);
}

.legal-table {
    width: 100%;
    border-collapse: collapse;
    margin: 1.25rem 0;
    font-size: 0.8125rem;
}

.legal-table thead tr {
    background: var(--nv-navy);
    color: #fff;
}

.legal-table th {
    font-family: 'IBM Plex Mono', monospace;
    font-size: 0.625rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    padding: 0.5625rem 0.875rem;
    text-align: left;
    font-weight: 500;
}

.legal-table td {
    padding: 0.6875rem 0.875rem;
    border-bottom: 1px solid var(--nv-border);
    color: #475569;
    vertical-align: top;
}

.legal-table tr:last-child td {
    border-bottom: none;
}

.td-yes,
.td-no {
    font-family: 'IBM Plex Mono', monospace;
    font-size: 0.75rem;
    font-weight: 600;
}

.td-yes {
    color: #1a7a1a;
}

.td-no {
    color: #c0392b;
}

.sb-restrict {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.sb-restrict-item {
    display: flex;
    align-items: flex-start;
    gap: 0.5rem;
    font-size: 0.78125rem;
    color: #475569;
    line-height: 1.5;
}

.sb-restrict-item::before {
    content: 'X';
    color: #c0392b;
    font-weight: 700;
    font-size: 0.6875rem;
    padding-top: 0.125rem;
    flex-shrink: 0;
}

@media (max-width: 1100px) {
    .legal-body,
    .license-tiers {
        grid-template-columns: 1fr;
    }

    .legal-sidebar {
        position: static;
    }
}

@media (max-width: 768px) {
    .lh-meta,
    .om-row {
        grid-template-columns: 1fr;
        display: grid;
    }
}

.page-body {
    max-width: 1280px;
    margin: 0 auto;
    padding: 3rem 1.5rem;
}

.type-tabs {
    display: flex;
    flex-wrap: wrap;
    gap: 0;
    border-bottom: 2px solid var(--nv-border);
    margin-bottom: 2.25rem;
}

.ttab {
    font-size: 0.84375rem;
    font-weight: 500;
    padding: 0.75rem 1.375rem;
    color: var(--nv-muted);
    cursor: pointer;
    border-bottom: 2px solid transparent;
    margin-bottom: -2px;
    transition: all 0.2s ease;
}

.ttab.active,
.ttab:hover {
    color: var(--nv-blue);
    border-bottom-color: var(--nv-blue);
}

.featured-strip {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1.5rem;
    margin-bottom: 2.5rem;
}

.feat-card {
    background: var(--nv-navy);
    border-radius: 6px;
    padding: 2.25rem;
    position: relative;
    overflow: hidden;
}

.feat-card::before {
    content: '';
    position: absolute;
    right: -40px;
    top: -40px;
    width: 200px;
    height: 200px;
    background: radial-gradient(circle, rgba(0, 180, 216, 0.1) 0%, transparent 70%);
}

.fc-type,
.fc-date,
.ic-type-badge,
.ic-date,
.ic-sector {
    font-family: 'IBM Plex Mono', monospace;
}

.fc-type {
    font-size: 0.625rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    background: rgba(0, 87, 184, 0.3);
    color: #7fb3ff;
    padding: 0.25rem 0.75rem;
    border-radius: 2px;
    display: inline-block;
    margin-bottom: 1rem;
}

.fc-title {
    font-family: 'Playfair Display', serif;
    font-size: 1.375rem;
    color: #fff;
    line-height: 1.3;
    margin-bottom: 0.75rem;
}

.fc-excerpt {
    font-size: 0.84375rem;
    color: rgba(255, 255, 255, 0.55);
    line-height: 1.7;
    margin-bottom: 1.25rem;
}

.fc-meta {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    border-top: 1px solid rgba(255, 255, 255, 0.08);
    padding-top: 1rem;
}

.fc-date {
    font-size: 0.6875rem;
    color: rgba(255, 255, 255, 0.35);
}

.fc-read {
    font-size: 0.8125rem;
    color: var(--nv-cyan);
    font-weight: 500;
}

.insights-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1.5rem;
    margin-bottom: 2.5rem;
}

.ic {
    border: 1px solid var(--nv-border);
    border-radius: 6px;
    overflow: hidden;
    transition: box-shadow 0.2s ease, border-color 0.2s ease;
    cursor: pointer;
    background: #fff;
}

.ic:hover {
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.08);
    border-color: var(--nv-blue);
}

.ic-img {
    height: 120px;
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
}

.ic-img-icon {
    font-size: 2rem;
    opacity: 0.6;
    color: rgba(255, 255, 255, 0.9);
}

.ic-type-badge {
    position: absolute;
    top: 12px;
    left: 12px;
    font-size: 0.625rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: #fff;
    padding: 0.25rem 0.625rem;
    border-radius: 2px;
}

.ic-body {
    padding: 1.25rem;
}

.ic-title {
    font-family: 'Playfair Display', serif;
    font-size: 0.9375rem;
    color: var(--nv-navy);
    line-height: 1.4;
    margin-bottom: 0.625rem;
}

.ic-excerpt {
    font-size: 0.8125rem;
    color: var(--nv-muted);
    line-height: 1.65;
    margin-bottom: 0.875rem;
}

.ic-footer {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    border-top: 1px solid var(--nv-border);
    padding-top: 0.75rem;
}

.ic-date {
    font-size: 0.6875rem;
    color: #c8d6e5;
}

.ic-sector {
    font-size: 0.625rem;
    background: #e8f0fb;
    color: var(--nv-blue);
    padding: 0.125rem 0.5625rem;
    border-radius: 2px;
}

.load-more {
    display: block;
    text-align: center;
    border: 1px solid var(--nv-border);
    padding: 0.8125rem;
    border-radius: 4px;
    font-size: 0.84375rem;
    color: #475569;
    transition: all 0.2s ease;
}

.load-more:hover {
    border-color: var(--nv-blue);
    color: var(--nv-blue);
}

@media (max-width: 1100px) {
    .featured-strip,
    .insights-grid {
        grid-template-columns: 1fr;
    }
}

.progress-bar {
    position: fixed;
    top: 0;
    left: 0;
    height: 3px;
    width: 0;
    background: var(--nv-cyan);
    z-index: 200;
    transition: width 0.1s linear;
}

.article-hero {
    background: var(--nv-navy-2);
    padding: 4rem 0;
    position: relative;
    overflow: hidden;
}

.article-hero::after {
    content: '';
    position: absolute;
    inset: 0;
    background-image: linear-gradient(rgba(0, 87, 184, 0.05) 1px, transparent 1px),
        linear-gradient(90deg, rgba(0, 87, 184, 0.05) 1px, transparent 1px);
    background-size: 40px 40px;
    pointer-events: none;
}

.ah-inner {
    max-width: 1280px;
    margin: 0 auto;
    padding: 0 1.5rem;
    display: grid;
    grid-template-columns: minmax(0, 1fr) 360px;
    gap: 4rem;
    align-items: start;
    position: relative;
    z-index: 1;
}

.ah-type,
.ah-meta-item,
.toc-label,
.toc-num,
.wp-source-label {
    font-family: 'IBM Plex Mono', monospace;
}

.ah-type {
    font-size: 0.65625rem;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    background: rgba(0, 87, 184, 0.3);
    color: #7fb3ff;
    padding: 0.25rem 0.75rem;
    border-radius: 2px;
    display: inline-block;
    margin-bottom: 1.25rem;
}

.ah-h1 {
    font-family: 'Playfair Display', serif;
    font-size: 2.25rem;
    color: #fff;
    line-height: 1.2;
    margin-bottom: 1rem;
}

.ah-deck {
    font-size: 0.9375rem;
    color: rgba(255, 255, 255, 0.6);
    line-height: 1.72;
    margin-bottom: 1.75rem;
    max-width: 680px;
}

.ah-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 2rem;
    border-top: 1px solid rgba(255, 255, 255, 0.1);
    padding-top: 1.25rem;
}

.ah-meta-item {
    font-size: 0.6875rem;
    color: rgba(255, 255, 255, 0.4);
}

.ah-meta-val {
    color: rgba(255, 255, 255, 0.7);
    display: block;
    margin-top: 0.25rem;
}

.article-review-meta {
    margin-top: 1rem;
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem 1.25rem;
    color: rgba(255, 255, 255, 0.56);
    font-size: 0.75rem;
    line-height: 1.5;
}

.toc-card {
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 6px;
    padding: 1.5rem;
}

.toc-label {
    font-size: 0.625rem;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: rgba(255, 255, 255, 0.35);
    margin-bottom: 1rem;
}

.toc-items {
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
}

.toc-items li a {
    font-size: 0.8125rem;
    color: rgba(255, 255, 255, 0.55);
    display: block;
    padding: 0.3125rem 0;
    border-bottom: 1px solid rgba(255, 255, 255, 0.05);
    transition: color 0.2s ease;
}

.toc-items li a:hover {
    color: var(--nv-cyan);
}

.toc-items li:last-child a {
    border-bottom: none;
}

.toc-num {
    font-size: 0.625rem;
    color: rgba(255, 255, 255, 0.25);
    margin-right: 0.5rem;
}

.article-body {
    max-width: 1280px;
    margin: 0 auto;
    padding: 3.5rem 1.5rem;
    display: grid;
    grid-template-columns: minmax(0, 1fr) 300px;
    gap: 3.5rem;
}

.article-content h2 {
    font-family: 'Playfair Display', serif;
    font-size: 1.5rem;
    color: var(--nv-navy);
    margin: 2.5rem 0 1rem;
    padding-top: 0.5rem;
}

.article-content p {
    font-size: 0.90625rem;
    color: #475569;
    line-height: 1.82;
    margin-bottom: 1.125rem;
}

.pullquote {
    border-left: 4px solid var(--nv-cyan);
    background: #e0f4f8;
    padding: 1.25rem 1.5rem;
    margin: 2rem 0;
    border-radius: 0 4px 4px 0;
}

.pullquote p {
    font-family: 'Playfair Display', serif;
    font-size: 1.0625rem;
    color: var(--nv-navy-2);
    line-height: 1.55;
    font-style: italic;
    margin-bottom: 0;
}

.article-content .pull-quote {
    border-left: 3px solid var(--nv-cyan);
    padding: 1.125rem 0 1.125rem 1.75rem;
    margin: 2rem 0;
    font-family: 'Playfair Display', serif;
    font-size: 1.5rem;
    color: var(--nv-navy);
    line-height: 1.45;
    font-style: italic;
}

.article-content .callout-box {
    background: var(--nv-mist);
    border: 1px solid var(--nv-border);
    border-radius: 6px;
    padding: 1.5rem 1.75rem;
    margin: 2rem 0;
}

.article-content .callout-box p:last-child {
    margin-bottom: 0;
}

.article-content .callout-label,
.article-content .data-lbl,
.article-content .bar-sub,
.article-content .timeline-date {
    font-family: 'IBM Plex Mono', monospace;
}

.article-content .callout-label {
    font-size: 0.625rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--nv-blue);
    margin-bottom: 0.625rem;
}

.article-content .data-strip {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0;
    background: #fff;
    border: 1px solid var(--nv-border);
    border-radius: 6px;
    overflow: hidden;
    margin: 2rem 0;
    padding: 0;
}

.article-content .data-cell {
    padding: 1.375rem 1.5rem;
    border-right: 1px solid var(--nv-border);
}

.article-content .data-cell:last-child {
    border-right: none;
}

.article-content .data-lbl {
    font-size: 0.625rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--nv-muted);
    margin-bottom: 0.5rem;
}

.article-content .data-val {
    font-family: 'Playfair Display', serif;
    font-size: 1.625rem;
    color: var(--nv-navy);
    font-weight: 600;
    margin-bottom: 0.25rem;
}

.article-content .data-val.cyan {
    color: var(--nv-cyan);
}

.article-content .data-sub {
    font-size: 0.75rem;
    color: var(--nv-muted);
    line-height: 1.5;
}

.article-content .bar-block {
    margin: 2rem 0;
}

.article-content .bar-title {
    font-size: 0.8125rem;
    font-weight: 600;
    color: var(--nv-navy);
    margin-bottom: 0.375rem;
}

.article-content .bar-sub {
    font-size: 0.75rem;
    color: var(--nv-muted);
    margin-bottom: 1rem;
    line-height: 1.6;
}

.article-content .bar-row {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    margin-bottom: 0.625rem;
}

.article-content .bar-label {
    width: 170px;
    flex-shrink: 0;
    text-align: right;
    font-size: 0.75rem;
    color: #475569;
}

.article-content .bar-track {
    flex: 1;
    height: 22px;
    background: var(--nv-mist);
    border-radius: 3px;
    overflow: hidden;
}

.article-content .bar-fill {
    height: 100%;
    display: flex;
    align-items: center;
    padding-left: 0.625rem;
}

.article-content .bar-fill span {
    font-family: 'IBM Plex Mono', monospace;
    font-size: 0.6875rem;
    color: #fff;
    font-weight: 500;
}

.article-content .comparison-table {
    margin: 2rem 0;
    border: 1px solid var(--nv-border);
    border-radius: 6px;
    overflow: hidden;
}

.article-content .ct-row {
    display: grid;
    grid-template-columns: 200px repeat(3, minmax(0, 1fr));
    border-bottom: 1px solid var(--nv-border);
}

.article-content .ct-row:last-child {
    border-bottom: none;
}

.article-content .ct-row.header {
    background: var(--nv-mist);
}

.article-content .ct-cell {
    padding: 0.875rem 1.125rem;
    border-right: 1px solid var(--nv-border);
    font-size: 0.8125rem;
    color: #475569;
}

.article-content .ct-cell:last-child {
    border-right: none;
}

.article-content .ct-cell.label {
    font-weight: 600;
    color: var(--nv-navy);
}

.article-content .ct-cell.header-cell {
    font-family: 'IBM Plex Mono', monospace;
    font-size: 0.625rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--nv-blue);
    font-weight: 600;
}

.article-content .timeline {
    margin: 2rem 0;
    padding-left: 1.25rem;
    border-left: 1px solid #bfd2ee;
}

.article-content .timeline-item {
    position: relative;
    padding: 0 0 1.5rem 1.5rem;
}

.article-content .timeline-item::before {
    content: '';
    position: absolute;
    left: -1.75rem;
    top: 0.25rem;
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: var(--nv-blue);
    box-shadow: 0 0 0 4px #eaf2fb;
}

.article-content .timeline-item:last-child {
    padding-bottom: 0;
}

.article-content .timeline-date {
    font-size: 0.6875rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--nv-blue);
    margin-bottom: 0.375rem;
}

.article-content .timeline-text {
    font-size: 0.90625rem;
    line-height: 1.75;
    color: #475569;
}

.chart-box {
    border: 1px solid var(--nv-border);
    border-radius: 6px;
    padding: 1.5rem;
    margin: 1.75rem 0;
}

.chart-title {
    font-size: 0.8125rem;
    font-weight: 600;
    color: var(--nv-navy);
    margin-bottom: 0.375rem;
}

.chart-sub,
.wp-side-copy,
.wp-source-copy,
.wp-sub {
    font-size: 0.75rem;
    color: var(--nv-muted);
    line-height: 1.65;
}

.chart-sub {
    margin-bottom: 1.25rem;
}

.rd-chart-image-wrap {
    margin-top: 1rem;
    position: relative;
}

.rd-chart-image {
    display: block;
    width: 100%;
    height: auto;
    border: 1px solid #d1dde8;
    border-radius: 6px;
    background: #fff;
}

.rd-chart-lightbox-trigger {
    position: absolute;
    top: 0.85rem;
    right: 0.85rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.35rem;
    height: 2.35rem;
    border: 1px solid rgba(17, 40, 69, 0.14);
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.92);
    color: #12345a;
    box-shadow: 0 8px 18px rgba(15, 33, 56, 0.12);
    transition: transform 0.15s ease, background-color 0.15s ease, color 0.15s ease;
}

.rd-chart-lightbox-trigger:hover {
    transform: translateY(-1px);
    background: #12345a;
    color: #fff;
}

.rd-chart-lightbox-trigger svg {
    width: 1rem;
    height: 1rem;
}

.rd-chart-lightbox[hidden] {
    display: none;
}

.rd-chart-lightbox {
    position: fixed;
    inset: 0;
    z-index: 95;
}

.rd-chart-lightbox-backdrop {
    position: absolute;
    inset: 0;
    background: rgba(7, 17, 30, 0.74);
    backdrop-filter: blur(4px);
}

.rd-chart-lightbox-dialog {
    position: relative;
    z-index: 1;
    width: min(92vw, 1120px);
    max-height: calc(100vh - 3rem);
    margin: 1.5rem auto;
    padding: 1rem;
    border-radius: 16px;
    background: #f8fbff;
    box-shadow: 0 24px 80px rgba(5, 16, 28, 0.3);
}

.rd-chart-lightbox-head {
    padding: 0.25rem 2.75rem 0.9rem 0.25rem;
}

.rd-chart-lightbox-title {
    font-family: 'Inter', sans-serif;
    font-size: 1rem;
    font-weight: 700;
    line-height: 1.4;
    color: #10233d;
}

.rd-chart-lightbox-body {
    max-height: calc(100vh - 8rem);
    overflow: auto;
    border-radius: 12px;
    background: #fff;
}

.rd-chart-lightbox-image {
    display: block;
    width: 100%;
    height: auto;
}

.rd-chart-lightbox-close {
    position: absolute;
    top: 0.9rem;
    right: 0.9rem;
    width: 2.25rem;
    height: 2.25rem;
    border: 0;
    border-radius: 999px;
    background: rgba(16, 35, 61, 0.08);
    color: #10233d;
    font-size: 1.35rem;
    line-height: 1;
    cursor: pointer;
}

.bar-chart {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

.bar-row {
    display: grid;
    grid-template-columns: minmax(180px, 220px) minmax(0, 1fr);
    align-items: center;
    gap: 0.875rem;
}

.bar-lbl {
    font-size: 0.78125rem;
    color: #475569;
    width: 160px;
    flex-shrink: 0;
    text-align: right;
}

.bar-track {
    flex: 1;
    height: 22px;
    background: var(--nv-mist);
    border-radius: 3px;
    overflow: hidden;
}

.bar-fill {
    height: 100%;
    border-radius: 3px;
    display: flex;
    align-items: center;
    padding-left: 0.5rem;
}

.bar-fill span {
    font-family: 'IBM Plex Mono', monospace;
    font-size: 0.6875rem;
    color: #fff;
    font-weight: 500;
}

.data-table {
    width: 100%;
    border-collapse: collapse;
    margin: 1.25rem 0;
    font-size: 0.8125rem;
}

.data-table thead tr {
    background: var(--nv-navy);
    color: #fff;
}

.data-table th {
    font-family: 'IBM Plex Mono', monospace;
    font-size: 0.625rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    padding: 0.5625rem 0.875rem;
    text-align: left;
    font-weight: 500;
}

.data-table td {
    padding: 0.6875rem 0.875rem;
    border-bottom: 1px solid var(--nv-border);
    color: #475569;
    vertical-align: top;
}

.data-table tr:hover td {
    background: var(--nv-mist);
}

.td-highlight {
    font-family: 'IBM Plex Mono', monospace;
    font-size: 0.75rem;
    color: var(--nv-blue);
    font-weight: 500;
}

.article-sidebar {
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
}

.wp-metric {
    font-family: 'IBM Plex Mono', monospace;
    font-size: 1.375rem;
    color: var(--nv-navy);
    font-weight: 600;
    margin: 0.75rem 0 0.25rem;
}

.wp-sub {
    margin-bottom: 1rem;
}

.wp-source-card {
    background: var(--nv-mist);
}

.wp-source-label {
    font-size: 0.625rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--nv-blue);
    margin-bottom: 0.625rem;
}

@media (max-width: 1100px) {
    .ah-inner,
    .article-body {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 900px) {
    .article-content .data-strip,
    .article-content .ct-row {
        grid-template-columns: 1fr;
    }

    .article-content .data-cell,
    .article-content .ct-cell {
        border-right: none;
        border-bottom: 1px solid var(--nv-border);
    }

    .article-content .data-cell:last-child,
    .article-content .ct-row .ct-cell:last-child {
        border-bottom: none;
    }

    .article-content .bar-row {
        flex-direction: column;
        align-items: stretch;
    }

    .article-content .bar-label {
        width: auto;
        text-align: left;
    }
}

.sector-hero {
    position: relative;
    overflow: hidden;
    background: var(--nv-navy-2);
    padding: 3.5rem 0;
}

.sector-hero::before {
    content: '';
    position: absolute;
    inset: 0;
    background: radial-gradient(ellipse at 60% 50%, rgba(0, 180, 216, 0.07) 0%, transparent 60%);
}

.sector-hero::after {
    content: '';
    position: absolute;
    inset: 0;
    background-image: linear-gradient(rgba(0, 87, 184, 0.05) 1px, transparent 1px), linear-gradient(90deg, rgba(0, 87, 184, 0.05) 1px, transparent 1px);
    background-size: 40px 40px;
    pointer-events: none;
}

.sector-inner,
.sector-page-inner {
    max-width: 1280px;
    margin: 0 auto;
    padding: 0 2.5rem;
}

.sector-inner {
    position: relative;
    z-index: 1;
}

.sector-breadcrumb,
.sector-kicker,
.sector-cagr,
.sector-meta,
.sector-development-date,
.sector-report-cagr,
.sb-val {
    font-family: 'IBM Plex Mono', monospace;
}

.sector-breadcrumb {
    font-size: 0.6875rem;
    color: rgba(255, 255, 255, 0.45);
    margin-bottom: 1rem;
}

.sector-breadcrumb span {
    color: rgba(255, 255, 255, 0.28);
    margin: 0 0.35rem;
}

.sector-kicker {
    font-size: 0.6875rem;
    text-transform: uppercase;
    letter-spacing: 0.14em;
    color: var(--nv-cyan);
    margin-bottom: 0.875rem;
}

.sector-title {
    font-family: 'Playfair Display', serif;
    font-size: 2.375rem;
    color: #fff;
    line-height: 1.18;
    margin-bottom: 0.875rem;
}

.sector-hook {
    max-width: 720px;
    font-size: 0.95rem;
    line-height: 1.75;
    color: rgba(255, 255, 255, 0.6);
    font-style: italic;
    margin-bottom: 1.75rem;
}

.sector-stats {
    display: flex;
    flex-wrap: wrap;
    gap: 2.5rem;
}

.sector-stat-value {
    font-family: 'Playfair Display', serif;
    font-size: 1.5rem;
    color: #fff;
    font-weight: 600;
}

.sector-stat-label {
    font-size: 0.75rem;
    color: rgba(255, 255, 255, 0.48);
    margin-top: 0.125rem;
}

.sector-page {
    padding: 3rem 0 4rem;
}

.sector-page-inner {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 320px;
    gap: 3rem;
}

.sector-pills {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    margin-bottom: 2rem;
}

.sector-pill {
    font-size: 0.78125rem;
    padding: 0.4375rem 1rem;
    border: 1px solid var(--nv-border);
    border-radius: 999px;
    cursor: pointer;
    transition: all 0.2s ease;
    color: #475569;
    background: #fff;
}

.sector-pill:hover,
.sector-pill.is-active {
    background: var(--nv-blue);
    border-color: var(--nv-blue);
    color: #fff;
}

.sector-section-title {
    font-family: 'Playfair Display', serif;
    font-size: 1.25rem;
    color: var(--nv-navy);
    margin-bottom: 1.125rem;
    padding-bottom: 0.625rem;
    border-bottom: 1px solid var(--nv-border);
}

.sector-synopsis {
    border-left: 3px solid var(--nv-blue);
    padding-left: 1.5rem;
    margin-bottom: 2.25rem;
}

.sector-synopsis p,
.sector-development-text,
.sector-sidebar-copy {
    font-size: 0.875rem;
    line-height: 1.78;
    color: #475569;
}

.sector-synopsis p {
    margin-bottom: 0.875rem;
}

.sector-synopsis p:last-child {
    margin-bottom: 0;
}

.sector-synopsis .art-tbl,
.sector-development-text .art-tbl {
    width: 100%;
    border-collapse: collapse;
    margin: 1rem 0;
    font-size: 0.8125rem;
}

.sector-synopsis .art-tbl th,
.sector-synopsis .art-tbl td,
.sector-development-text .art-tbl th,
.sector-development-text .art-tbl td {
    border: 1px solid var(--nv-border);
    padding: 0.625rem;
    text-align: left;
}

.sector-synopsis .art-tbl th,
.sector-development-text .art-tbl th {
    background: var(--nv-mist);
    color: var(--nv-navy);
    font-weight: 600;
}

.sector-cagr {
    font-size: 0.75rem;
    color: var(--nv-blue);
    font-weight: 500;
}

.sector-developments {
    display: flex;
    flex-direction: column;
    gap: 0.875rem;
    margin-bottom: 2.25rem;
}

.sector-development {
    display: flex;
    gap: 1rem;
    padding: 0.875rem 1.125rem;
    border: 1px solid var(--nv-border);
    border-radius: 4px;
}

.sector-development-date {
    min-width: 76px;
    white-space: nowrap;
    padding-top: 0.125rem;
    font-size: 0.6875rem;
    color: var(--nv-blue);
}

.sector-controls {
    display: flex;
    gap: 0.75rem;
    margin-bottom: 1rem;
}

.sector-search,
.sector-sort {
    padding: 0.625rem 0.875rem;
    border: 1px solid var(--nv-border);
    border-radius: 4px;
    font-size: 0.8125rem;
    font-family: 'Inter', sans-serif;
}

.sector-search {
    flex: 1;
}

.sector-search:focus,
.sector-sort:focus {
    outline: none;
    border-color: var(--nv-blue);
}

.sector-meta {
    font-size: 0.6875rem;
    color: var(--nv-muted);
    margin-bottom: 1rem;
}

.sector-report-list,
.sector-sidebar {
    display: flex;
    flex-direction: column;
}

.sector-report-list {
    gap: 0.75rem;
}

.sector-report-row {
    border: 1px solid var(--nv-border);
    border-radius: 4px;
    padding: 0.9375rem 1.125rem;
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 1rem;
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.sector-report-row:hover {
    border-color: var(--nv-blue);
    box-shadow: 0 2px 10px rgba(0, 87, 184, 0.08);
}

.sector-report-sub {
    display: inline-flex;
    align-items: center;
    gap: 0.375rem;
    margin-bottom: 0.5rem;
    padding: 0.25rem 0.5rem;
    border-radius: 999px;
    background: #eef5fb;
    color: var(--nv-blue);
    font-size: 0.6875rem;
    font-weight: 600;
}

.sector-report-title {
    font-size: 0.84375rem;
    color: var(--nv-navy);
    line-height: 1.45;
}

.sector-report-right {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 0.375rem;
    min-width: 112px;
    flex-shrink: 0;
}

.sector-report-cagr {
    font-size: 0.75rem;
    color: var(--nv-blue);
    font-weight: 500;
}

.sector-report-price {
    font-size: 0.71875rem;
    color: var(--nv-muted);
}

.sector-report-btn {
    font-size: 0.75rem;
    color: var(--nv-blue);
    border: 1px solid var(--nv-blue);
    padding: 0.25rem 0.75rem;
    border-radius: 3px;
    white-space: nowrap;
}

.sector-pagination {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    margin-top: 1.25rem;
}

.sector-page-btn {
    padding: 0.4375rem 0.8125rem;
    border: 1px solid var(--nv-border);
    border-radius: 3px;
    font-size: 0.8125rem;
    cursor: pointer;
    color: #475569;
    background: #fff;
}

.sector-page-btn.is-active {
    background: var(--nv-blue);
    border-color: var(--nv-blue);
    color: #fff;
}

.sector-sidebar {
    gap: 1.25rem;
}

.sector-sidebar-copy {
    margin-bottom: 0.875rem;
}

@media (max-width: 1100px) {
    .sector-page-inner {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 768px) {
    .sector-inner,
    .sector-page-inner {
        padding: 0 1.25rem;
    }

    .sector-title {
        font-size: 2rem;
    }

    .sector-controls,
    .sector-report-row,
    .sector-development {
        flex-direction: column;
    }

    .sector-report-right {
        align-items: flex-start;
        min-width: 0;
    }
}

.rd-hero {
    position: relative;
    overflow: hidden;
    background: var(--nv-navy-2);
    padding: 3.25rem 0 2.75rem;
}

.rd-hero::after {
    content: '';
    position: absolute;
    inset: 0;
    background-image: linear-gradient(rgba(0, 87, 184, 0.05) 1px, transparent 1px), linear-gradient(90deg, rgba(0, 87, 184, 0.05) 1px, transparent 1px);
    background-size: 40px 40px;
    pointer-events: none;
}

.rh-inner,
.rd-body {
    max-width: 1280px;
    margin: 0 auto;
    padding: 0 2.5rem;
}

.rh-inner {
    position: relative;
    z-index: 1;
}

.rh-breadcrumb,
.rh-size-lbl,
.rh-tag,
.toc-ch-num,
.toc-pg,
.sb-meta-val,
.sb-meta-lbl {
    font-family: 'IBM Plex Mono', monospace;
}

.rh-breadcrumb {
    font-size: 0.6875rem;
    color: rgba(255, 255, 255, 0.4);
    margin-bottom: 1rem;
    letter-spacing: 0.06em;
}

.rh-breadcrumb a {
    color: inherit;
    text-decoration: none;
}

.rh-breadcrumb a:hover {
    color: rgba(255, 255, 255, 0.72);
}

.rh-breadcrumb span {
    color: rgba(255, 255, 255, 0.6);
    margin: 0 0.35rem;
}

.rh-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    margin-bottom: 1rem;
}

.rh-tag {
    font-size: 0.65625rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    padding: 0.25rem 0.75rem;
    border-radius: 2px;
}

.rh-tag.sec {
    background: rgba(0, 87, 184, 0.3);
    color: #7fb3ff;
}

.rh-tag.new {
    background: rgba(192, 57, 43, 0.3);
    color: #ff9999;
}

.rh-h1 {
    font-family: 'Playfair Display', serif;
    font-size: 2.125rem;
    color: #fff;
    line-height: 1.25;
    margin-bottom: 0.75rem;
}

.rh-hook {
    max-width: 760px;
    font-size: 0.90625rem;
    color: rgba(255, 255, 255, 0.58);
    font-style: italic;
    line-height: 1.72;
    margin-bottom: 1.75rem;
}

.rh-size-strip {
    display: flex;
    gap: 0;
    border: 1px solid rgba(255, 255, 255, 0.12);
    border-radius: 4px;
    overflow: hidden;
}

.rh-size-item {
    flex: 1;
    padding: 1rem 1.25rem;
    border-right: 1px solid rgba(255, 255, 255, 0.1);
}

.rh-size-item:last-child {
    border-right: none;
}

.rh-size-lbl {
    font-size: 0.625rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: rgba(255, 255, 255, 0.4);
    margin-bottom: 0.375rem;
}

.rh-size-val {
    font-family: 'Playfair Display', serif;
    font-size: 1.375rem;
    color: #fff;
    font-weight: 600;
}

.rh-size-val.cyan {
    color: var(--nv-cyan);
}

.rd-body {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 300px;
    align-items: start;
    gap: 3rem;
    padding-top: 3rem;
    padding-bottom: 3rem;
}

.section-sep {
    height: 2rem;
}

.section-title {
    font-family: 'Playfair Display', serif;
    font-size: 1.35rem;
    font-weight: 700;
    color: var(--nv-navy);
    line-height: 1.25;
    margin-bottom: 1.125rem;
    padding-bottom: 0.625rem;
    border-bottom: 1px solid var(--nv-border);
}

.synopsis p {
    font-size: 0.84375rem;
    color: #475569;
    line-height: 1.75;
    margin-bottom: 10px;
}

.rd-chart-box .chart-title {
    margin-bottom: 1rem;
}

.charts-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(360px, 1fr));
    gap: 1.25rem;
    align-items: start;
}

.charts-grid .chart-box {
    margin: 0;
    height: 100%;
}

.bar-label {
    min-width: 0;
    text-align: left;
    font-size: 0.78125rem;
    line-height: 1.45;
    color: #475569;
    word-break: normal;
    overflow-wrap: anywhere;
}

.bar-track {
    min-width: 0;
}

.segment-block {
    border-left: 3px solid var(--nv-blue);
    padding-left: 1.25rem;
    margin-bottom: 1.5rem;
}

.seg-head,
.region-head {
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--nv-navy);
    font-style: italic;
    margin-bottom: 0.625rem;
}

.seg-body,
.region-text,
.analyst-quote,
.kq-a,
.rd-side-copy {
    font-size: 0.84375rem;
    color: #475569;
    line-height: 1.75;
}

.rd-body .art-tbl {
    width: 100%;
    border-collapse: collapse;
    margin: 1rem 0;
    font-size: 0.8125rem;
}

.rd-body .art-tbl th,
.rd-body .art-tbl td {
    border: 1px solid var(--nv-border);
    padding: 0.625rem;
    text-align: left;
}

.rd-body .art-tbl th {
    background: var(--nv-mist);
    color: var(--nv-navy);
    font-weight: 600;
}

.regional-grid,
.analyst-grid,
.kq-grid,
.toc-grid.rd-toc-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1.25rem;
}

.region-card,
.analyst-card,
.kq-item,
.rd-toc-chapter {
    border: 1px solid var(--nv-border);
    border-radius: 4px;
    padding: 1.125rem;
}

.analyst-quote {
    font-style: italic;
    margin-bottom: 0.75rem;
}

.analyst-attr {
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--nv-navy);
    display: none;
}

.analyst-role,
.sb-price-sub,
.rd-side-copy {
    font-size: 0.75rem;
    color: var(--nv-muted);
}

.nodvolt-box {
    background: #e0f4f8;
    border-left: 3px solid var(--nv-cyan);
    padding: 0.625rem 0.875rem;
    margin-top: 0.75rem;
    font-size: 0.75rem;
    color: #005f7a;
    line-height: 1.65;
    display: none;
}

.strat-devs {
    display: grid;
    gap: 1rem;
}

.strat-dev {
    padding-left: 1rem;
    border-left: 3px solid var(--nv-blue);
}

.sd-date {
    font-size: 0.875rem;
    font-weight: 700;
    color: var(--nv-navy);
    margin-bottom: 0.35rem;
}

.sd-text {
    font-size: 0.84375rem;
    color: #475569;
    line-height: 1.75;
}

.companies-list {
    display: flex;
    flex-wrap: wrap;
    gap: 0.625rem;
}

.company-tag {
    font-size: 0.8125rem;
    padding: 0.4375rem 1rem;
    border: 1px solid var(--nv-border);
    border-radius: 3px;
    color: #475569;
}

.kq-q,
.toc-ch-title {
    font-size: 0.875rem;
    font-weight: 700;
    color: var(--nv-navy);
    margin-bottom: 0;
}

.scope-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1rem;
}

.scope-card {
    background: var(--nv-mist);
    border-radius: 4px;
    padding: 1.125rem;
}

.scope-head {
    font-family: 'IBM Plex Mono', monospace;
    font-size: 0.625rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--nv-blue);
    margin-bottom: 0.625rem;
}

.scope-items {
    display: flex;
    flex-direction: column;
    gap: 0.3125rem;
}

.scope-item {
    font-size: 0.75rem;
    color: #475569;
}

.rd-inline-cta {
    margin: 2rem 0 0;
    padding: 2rem 1.5rem;
    border: 1px solid var(--nv-border);
    background: #fff;
    text-align: center;
    overflow: hidden;
    position: relative;
}

.rd-inline-cta-teaser {
    max-width: 92%;
    margin: 0 auto 1.25rem;
    font-family: 'Playfair Display', serif;
    font-size: 1.2rem;
    line-height: 1.55;
    color: rgba(12, 26, 46, 0.28);
    filter: blur(5px);
    user-select: none;
    pointer-events: none;
}

.rd-inline-cta-kicker {
    font-family: 'IBM Plex Mono', monospace;
    font-size: 0.8125rem;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--nv-navy);
    margin-bottom: 1.25rem;
}

.rd-inline-cta-actions {
    display: flex;
    justify-content: center;
    gap: 0.75rem;
    flex-wrap: wrap;
}

.rd-inline-cta-btn {
    min-width: 220px;
    padding: 0.9rem 1.25rem;
    border: 1px solid var(--nv-navy);
    border-radius: 0;
    font-family: 'IBM Plex Mono', monospace;
    font-size: 0.9375rem;
    font-weight: 500;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    text-align: center;
    transition: background 0.15s ease, color 0.15s ease, border-color 0.15s ease;
}

.rd-inline-cta-btn-primary {
    background: #0c1a2e;
    border-color: #0c1a2e;
    color: #fff;
}

.rd-inline-cta-btn-primary:hover {
    background: #16365d;
    border-color: #16365d;
}

.rd-inline-cta-btn-secondary {
    background: #fff;
    color: #0c1a2e;
}

.rd-inline-cta-btn-secondary:hover {
    background: #f8fafc;
}

.rd-market-cta {
    margin: 1.4rem 0 0;
    padding: 1.5rem 1.75rem 1.6rem;
    border-radius: 10px;
    background: linear-gradient(180deg, #15345a, #122b48);
    color: #fff;
}

.rd-market-cta-kicker {
    font-family: 'IBM Plex Mono', monospace;
    font-size: 0.72rem;
    font-weight: 600;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--nv-cyan);
}

.rd-market-cta-title {
    margin-top: 0.55rem;
    font-family: 'Playfair Display', serif;
    font-size: 2rem;
    line-height: 1.08;
    color: #fff;
}

.rd-market-cta-copy {
    margin-top: 0.5rem;
    color: rgba(255, 255, 255, 0.72);
    font-size: 1rem;
    line-height: 1.65;
}

.rd-market-cta-actions {
    display: flex;
    gap: 0.75rem;
    flex-wrap: wrap;
    margin-top: 1.35rem;
}

.rd-market-cta-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 42px;
    padding: 0 1.2rem;
    border-radius: 6px;
    border: 1px solid rgba(255, 255, 255, 0.24);
    font-size: 0.92rem;
    font-weight: 600;
    transition: background-color 0.18s ease, border-color 0.18s ease, color 0.18s ease;
}

.rd-market-cta-btn-primary {
    background: linear-gradient(135deg, #02a9d6, #0ec8e8);
    border-color: transparent;
    color: #062036 !important;
}

.rd-market-cta-btn-primary:hover {
    background: linear-gradient(135deg, #18b9e2, #2ad9f0);
}

.rd-market-cta-btn-secondary {
    background: transparent;
    color: #fff !important;
}

.rd-market-cta-btn-secondary:hover {
    background: rgba(255, 255, 255, 0.08);
    border-color: rgba(255, 255, 255, 0.38);
}

.pi-panel {
    margin: 2rem 0 0;
    border: 1px solid #cfe0f1;
    border-radius: 12px;
    background: transparent;
    overflow: hidden;
    box-shadow: 0 10px 24px rgba(10, 32, 58, 0.05);
}

.pi-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    flex-wrap: wrap;
    padding: 1.35rem 1.5rem;
    background: linear-gradient(180deg, #112845, #0d223d);
}

.pi-header-link {
    text-decoration: none;
    transition: transform 0.15s ease, box-shadow 0.15s ease;
}

.pi-header-link:hover {
    transform: translateY(-1px);
    box-shadow: inset 0 0 0 1px rgba(37, 198, 223, 0.18);
}

.pi-eyebrow {
    font-family: 'IBM Plex Mono', monospace;
    font-size: 0.65rem;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: #25c6df;
}

.pi-title {
    margin-top: 0.35rem;
    font-family: 'Playfair Display', serif;
    font-size: 1.65rem;
    line-height: 1.08;
    color: #fff;
}

.pi-badge {
    display: inline-flex;
    align-items: center;
    min-height: 32px;
    padding: 0 0.9rem;
    border-radius: 999px;
    background: rgba(17, 201, 229, 0.16);
    border: 1px solid rgba(17, 201, 229, 0.24);
    font-family: 'IBM Plex Mono', monospace;
    font-size: 0.68rem;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: #dffcff;
}

.pi-body {
    padding: 1.45rem 1.5rem 1.6rem;
}

.pi-success {
    margin-bottom: 1rem;
    padding: 0.95rem 1rem;
    border: 1px solid #b9ead8;
    background: #f2fbf8;
    border-radius: 10px;
}

.pi-success-title {
    font-size: 0.95rem;
    font-weight: 700;
    color: #0f5132;
}

.pi-success-copy {
    margin-top: 0.25rem;
    font-size: 0.875rem;
    line-height: 1.6;
    color: #3f5f52;
}

.pi-lead {
    max-width: 50rem;
    font-size: 0.95rem;
    line-height: 1.75;
    color: #475569;
}

.pi-pillars {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.85rem;
    margin-top: 1.25rem;
}

.pi-pillar {
    padding: 1rem;
    border: 1px solid #dbe8f5;
    border-radius: 10px;
    background: linear-gradient(180deg, #fbfdff, #f4f8fc);
}

.pi-pillar-title {
    font-size: 0.82rem;
    font-weight: 700;
    color: #0c1a2e;
}

.pi-pillar-copy {
    margin-top: 0.35rem;
    font-size: 0.8rem;
    line-height: 1.6;
    color: #5f6f82;
}

.pi-form {
    margin-top: 1.35rem;
}

.pi-form-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0.9rem;
    margin-top: 0.9rem;
}

.pi-field {
    margin-top: 0.9rem;
}

.pi-field label {
    display: block;
    margin-bottom: 0.45rem;
    font-family: 'IBM Plex Mono', monospace;
    font-size: 0.68rem;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: #4b6078;
}

.pi-field input,
.pi-field select,
.pi-field textarea {
    width: 100%;
    border: 1px solid #cfddeb;
    border-radius: 8px;
    background: #fff;
    padding: 0.8rem 0.9rem;
    font-size: 0.92rem;
    color: #0c1a2e;
    transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.pi-field textarea {
    min-height: 110px;
    resize: vertical;
}

.pi-field input:focus,
.pi-field select:focus,
.pi-field textarea:focus {
    outline: none;
    border-color: #0fb7d7;
    box-shadow: 0 0 0 3px rgba(15, 183, 215, 0.12);
}

.pi-chip-group {
    display: flex;
    gap: 0.55rem;
    flex-wrap: wrap;
}

.pi-chip-input {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

.pi-chip {
    display: inline-flex;
    align-items: center;
    min-height: 36px;
    padding: 0 0.9rem;
    border: 1px solid #d5e1ec;
    border-radius: 999px;
    background: #fff;
    font-size: 0.82rem;
    color: #486078;
    cursor: pointer;
    transition: border-color 0.15s ease, background-color 0.15s ease, color 0.15s ease;
}

.pi-chip-input:checked + .pi-chip {
    border-color: #0fb7d7;
    background: rgba(15, 183, 215, 0.08);
    color: #0a5070;
}

.pi-submit-row {
    margin-top: 1.2rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    flex-wrap: wrap;
}

.pi-submit-note {
    max-width: 30rem;
    font-size: 0.82rem;
    line-height: 1.65;
    color: #607084;
}

.pi-submit-note span {
    color: #0a9bb9;
    font-weight: 700;
}

.pi-submit-btn {
    min-height: 44px;
    padding: 0 1.2rem;
    border: 0;
    border-radius: 8px;
    background: linear-gradient(135deg, #1260cf, #10b5d9);
    color: #fff;
    font-family: 'IBM Plex Mono', monospace;
    font-size: 0.82rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    cursor: pointer;
    transition: transform 0.15s ease, box-shadow 0.15s ease;
}

.pi-submit-btn:hover {
    transform: translateY(-1px);
    box-shadow: 0 10px 20px rgba(16, 112, 182, 0.18);
}

.toc-grid.rd-toc-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
    margin-bottom: 32px;
}

.rd-toc-chapter {
    background: #fff;
    border: 1px solid #d1dde8;
    border-radius: 4px;
    padding: 16px;
}

.toc-ch-hdr {
    display: flex;
    gap: 10px;
    align-items: baseline;
    margin-bottom: 10px;
}

.rd-toc-chapter .toc-ch-num {
    font-family: 'IBM Plex Mono', monospace !important;
    font-size: 10px;
    font-weight: 400;
    color: #0057b8;
    letter-spacing: 0;
    white-space: nowrap;
}

.rd-toc-chapter .toc-ch-title {
    font-family: 'Inter', sans-serif !important;
    font-size: 13px;
    font-weight: 600;
    line-height: 1.2;
    color: #0c1a2e;
    margin: 0;
}

.rd-toc-items {
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: 5px;
}

.rd-toc-items li {
    display: block;
    font-family: 'Inter', sans-serif !important;
    font-size: 12px;
    line-height: 1.6;
    color: #64748b;
}

.rd-toc-items li span:first-child {
    padding-right: 0;
    display: block;
}

.rd-toc-items .toc-pg {
    font-family: 'IBM Plex Mono', monospace !important;
    font-size: 11px;
    font-weight: 400;
    color: #64748b;
    white-space: nowrap;
    flex-shrink: 0;
}

.sb-price {
    font-family: 'Playfair Display', serif;
    font-size: 1.75rem;
    color: var(--nv-navy);
    font-weight: 700;
    margin-bottom: 0.25rem;
}

.sidebar {
    position: relative;
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
    align-self: start;
}

.sidebar-sticky {
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
}

.sidebar-sticky.is-fixed {
    position: fixed;
    top: 80px;
    width: var(--sidebar-width, 300px);
    z-index: 20;
}

.sidebar-sticky.is-bottom {
    position: absolute;
    top: var(--sidebar-stop-top, 0);
    width: 100%;
}

.sidebar-card {
    border: 1px solid var(--nv-border);
    border-radius: 6px;
    padding: 1.375rem;
    background: #fff;
}

.sb-widget {
    background: #fff;
    border: 1px solid var(--nv-border);
    border-radius: 8px;
    padding: 1.25rem;
}

.sb-widget-title {
    font-size: 0.75rem;
    font-weight: 700;
    letter-spacing: 0.07em;
    color: var(--nv-navy);
    text-transform: uppercase;
    margin-bottom: 0.875rem;
    padding-bottom: 0.625rem;
    border-bottom: 1px solid var(--nv-border);
}

.sb-jump-nav {
    display: flex;
    flex-direction: column;
    gap: 1px;
}

.sb-jump-link {
    font-size: 0.78125rem;
    color: #475569;
    padding: 0.375rem 0.5rem;
    border-radius: 4px;
    display: block;
    transition: background 0.15s ease, color 0.15s ease;
}

.sb-jump-link.is-active {
    background: #eef5ff;
    color: var(--nv-blue);
    font-weight: 600;
}

.sb-jump-link:hover {
    background: #f0f7ff;
    color: var(--nv-blue);
}

.sb-sample-widget {
    background: linear-gradient(135deg, #0c1a2e, #0d3a6b);
    border: none;
}

.sb-sample-tag {
    font-size: 0.5625rem;
    font-weight: 700;
    letter-spacing: 0.1em;
    color: var(--nv-cyan);
    text-transform: uppercase;
    margin-bottom: 0.5rem;
}

.sb-sample-title {
    font-family: 'Playfair Display', serif;
    font-size: 0.9375rem;
    color: #fff;
    font-weight: 700;
    margin-bottom: 0.5rem;
}

.sb-sample-desc {
    font-size: 0.71875rem;
    color: rgba(255, 255, 255, 0.65);
    line-height: 1.55;
    margin-bottom: 1rem;
}

.sb-sample-btn {
    display: block;
    width: 100%;
    padding: 0.6875rem;
    background: var(--nv-cyan);
    color: var(--nv-navy);
    border: none;
    border-radius: 4px;
    font-size: 0.78125rem;
    font-weight: 700;
    text-align: center;
}

.sb-sample-note {
    font-size: 0.65625rem;
    color: rgba(255, 255, 255, 0.45);
    text-align: center;
    margin-top: 0.5rem;
}

.sb-buy-widget {
    border: 2px solid var(--nv-blue);
}

.sb-buy-label {
    font-size: 0.6875rem;
    color: var(--nv-muted);
    margin-bottom: 0.25rem;
}

.sb-buy-price {
    font-family: 'IBM Plex Mono', monospace;
    font-size: 0.8125rem;
    color: #475569;
    margin-bottom: 0.875rem;
}

.sb-buy-price span {
    font-size: 1.375rem;
    color: var(--nv-navy);
    font-weight: 700;
}

.sb-buy-btn {
    display: block;
    width: 100%;
    padding: 0.75rem;
    background: var(--nv-blue);
    color: #fff;
    border: none;
    border-radius: 4px;
    font-size: 0.8125rem;
    font-weight: 700;
    text-align: center;
}

.sb-buy-btn:hover,
.sb-sample-btn:hover,
.sb-custom-btn:hover {
    opacity: 0.9;
}

.sb-buy-features {
    margin-top: 0.75rem;
    display: flex;
    flex-direction: column;
    gap: 0.3125rem;
}

.sb-buy-feat {
    font-size: 0.71875rem;
    color: #475569;
}

.sb-custom-widget {
    background: #f8fafc;
}

.sb-custom-title {
    font-size: 0.875rem;
    font-weight: 700;
    color: var(--nv-navy);
    margin-bottom: 0.375rem;
}

.sb-custom-desc {
    font-size: 0.75rem;
    color: var(--nv-muted);
    line-height: 1.5;
    margin-bottom: 0.875rem;
}

.sb-custom-btn {
    display: block;
    width: 100%;
    padding: 0.625rem;
    background: var(--nv-navy);
    color: #fff;
    border-radius: 4px;
    font-size: 0.78125rem;
    font-weight: 600;
    text-align: center;
}

.sc-head {
    font-family: 'Playfair Display', serif;
    font-size: 0.9375rem;
    color: var(--nv-navy);
    margin-bottom: 0.875rem;
}

.sb-meta-rows {
    display: flex;
    flex-direction: column;
    gap: 0;
    margin-top: 0.25rem;
}

.sb-meta-row {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    font-size: 0.78125rem;
    padding: 0.5rem 0;
    border-bottom: 1px solid var(--nv-border);
}

.sb-meta-row:last-child {
    border-bottom: none;
}

.sb-meta-lbl {
    color: var(--nv-muted);
}

.sb-meta-val {
    color: var(--nv-navy);
    font-weight: 500;
}

.sb-btn-main,
.sb-btn-sec {
    display: block;
    width: 100%;
    text-align: center;
    border-radius: 4px;
    font-size: 0.8125rem;
    transition: all 0.2s ease;
}

.sb-btn-main {
    background: var(--nv-blue);
    color: #fff;
    font-weight: 600;
    padding: 0.75rem 1rem;
    margin-top: 0.875rem;
}

.sb-btn-main:hover {
    background: var(--nv-blue-light);
}

.sb-btn-sec {
    border: 1px solid var(--nv-border);
    color: #475569;
    padding: 0.6875rem 1rem;
    margin-top: 0.625rem;
}

.sb-btn-sec:hover {
    border-color: var(--nv-blue);
    color: var(--nv-blue);
}

.rd-related-links {
    display: flex;
    flex-direction: column;
    gap: 0;
}

.rd-related-link {
    font-size: 0.8125rem;
    color: var(--nv-navy);
    line-height: 1.45;
    padding-bottom: 0.625rem;
    margin-bottom: 0.625rem;
    border-bottom: 1px solid var(--nv-border);
}

.rd-related-link.is-last {
    border-bottom: none;
    margin-bottom: 0;
    padding-bottom: 0;
}

.rd-side-copy {
    margin-bottom: 0.875rem;
}

@media (max-width: 1100px) {
    .rd-body {
        grid-template-columns: 1fr;
    }

    .sidebar {
        position: static;
        min-height: 0 !important;
    }

    .sidebar-sticky,
    .sidebar-sticky.is-fixed,
    .sidebar-sticky.is-bottom {
        position: static;
        top: auto;
        width: auto;
    }

    .scope-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 768px) {
    .rh-inner,
    .rd-body {
        padding-left: 1.25rem;
        padding-right: 1.25rem;
    }

    .rh-h1 {
        font-size: 1.75rem;
    }

    .rh-size-strip,
    .regional-grid,
    .analyst-grid,
    .kq-grid,
    .toc-grid.rd-toc-grid,
    .charts-grid,
    .scope-grid {
        grid-template-columns: 1fr;
    }

    .rh-size-strip {
        display: grid;
    }

    .bar-row {
        align-items: flex-start;
        grid-template-columns: 1fr;
        gap: 0.375rem;
    }

    .bar-label {
        width: auto;
        text-align: left;
    }

    .rd-inline-cta-btn {
        width: 100%;
        min-width: 0;
    }

    .rd-inline-cta-teaser {
        font-size: 0.95rem;
        max-width: 100%;
    }

    .pi-pillars,
    .pi-form-row {
        grid-template-columns: 1fr;
    }

    .pi-title {
        font-size: 1.35rem;
    }

    .pi-submit-btn {
        width: 100%;
    }
}

.lic-hero {
    background: var(--nv-navy-2);
    padding: 3.25rem 0 3rem;
    position: relative;
    overflow: hidden;
}

.lic-hero::after {
    content: '';
    position: absolute;
    inset: 0;
    background-image: linear-gradient(rgba(0, 87, 184, 0.05) 1px, transparent 1px),
        linear-gradient(90deg, rgba(0, 87, 184, 0.05) 1px, transparent 1px);
    background-size: 40px 40px;
    pointer-events: none;
}

.lh-title {
    font-family: 'Playfair Display', serif;
    font-size: clamp(2rem, 4vw, 2.75rem);
    color: #fff;
    font-weight: 700;
    line-height: 1.08;
    margin-bottom: 0.75rem;
    letter-spacing: -0.02em;
}

.lh-report-strip {
    display: flex;
    align-items: center;
    gap: 1rem;
    background: rgba(255, 255, 255, 0.05);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 6px;
    padding: 0.875rem 1.125rem;
    max-width: 42rem;
}

.lrs-icon {
    width: 2.375rem;
    height: 2.375rem;
    background: rgba(0, 87, 184, 0.35);
    border-radius: 4px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.lrs-label,
.lic-section-label,
.card-tier-label,
.card-feat-head {
    font-family: 'IBM Plex Mono', monospace;
    text-transform: uppercase;
    letter-spacing: 0.14em;
}

.lrs-label {
    font-size: 0.59375rem;
    color: rgba(255, 255, 255, 0.35);
    margin-bottom: 0.1875rem;
}

.lrs-name {
    font-size: 0.875rem;
    font-weight: 600;
    color: #fff;
    line-height: 1.35;
}

.lrs-meta {
    font-family: 'IBM Plex Mono', monospace;
    font-size: 0.625rem;
    color: rgba(255, 255, 255, 0.35);
    margin-top: 0.1875rem;
}

.step-bar {
    background: var(--nv-mist);
    border-bottom: 1px solid var(--nv-border);
}

.step-inner {
    max-width: 1280px;
    margin: 0 auto;
    padding: 0 1.5rem;
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    min-height: 3.25rem;
    gap: 0;
}

.step {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.78125rem;
    font-weight: 500;
    color: var(--nv-muted);
    padding: 0.5rem 1rem 0.5rem 0;
}

.step-num {
    width: 1.375rem;
    height: 1.375rem;
    border-radius: 999px;
    background: var(--nv-mist);
    border: 1.5px solid var(--nv-border);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-family: 'IBM Plex Mono', monospace;
    font-size: 0.625rem;
    font-weight: 600;
    color: var(--nv-muted);
    flex-shrink: 0;
}

.step.active {
    color: var(--nv-navy);
}

.step.active .step-num {
    background: var(--nv-blue);
    border-color: var(--nv-blue);
    color: #fff;
}

.step.done .step-num {
    background: var(--nv-cyan);
    border-color: var(--nv-cyan);
    color: var(--nv-navy);
}

.step-arrow {
    color: var(--nv-border);
    font-size: 0.875rem;
    padding-right: 1rem;
}

.lic-body {
    max-width: 1280px;
    margin: 0 auto;
    padding: 3.25rem 1.5rem 5rem;
}

.lic-section-label {
    font-size: 0.65625rem;
    color: var(--nv-blue);
    margin-bottom: 0.5rem;
}

.lic-section-title,
.faq-section-title {
    font-family: 'Playfair Display', serif;
    font-size: 1.375rem;
    color: var(--nv-navy);
    font-weight: 700;
}

.lic-section-title {
    margin-bottom: 0.375rem;
}

.lic-section-sub {
    font-size: 0.875rem;
    color: var(--nv-muted);
    margin-bottom: 2.25rem;
    max-width: 40rem;
    line-height: 1.7;
}

.pricing-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1.5rem;
    margin-bottom: 3rem;
}

.pricing-card {
    border: 1.5px solid var(--nv-border);
    border-radius: 8px;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    position: relative;
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
    background: #fff;
}

.pricing-card:hover,
.pricing-card.selected {
    border-color: var(--nv-blue);
    box-shadow: 0 8px 32px rgba(0, 87, 184, 0.12);
}

.pricing-card.featured {
    border-color: var(--nv-cyan);
    box-shadow: 0 8px 32px rgba(0, 180, 216, 0.12);
}

.pricing-card.featured.selected,
.pricing-card.featured:hover {
    border-color: var(--nv-blue);
}

.card-badge {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    background: var(--nv-cyan);
    padding: 0.375rem 0;
    text-align: center;
    font-family: 'IBM Plex Mono', monospace;
    font-size: 0.59375rem;
    font-weight: 600;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--nv-navy);
}

.card-header {
    padding: 1.75rem 1.75rem 1.25rem;
}

.pricing-card.featured .card-header {
    padding-top: 2.75rem;
}

.card-tier-label {
    font-size: 0.625rem;
    color: var(--nv-blue);
    margin-bottom: 0.625rem;
}

.card-name {
    font-family: 'Playfair Display', serif;
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--nv-navy);
    margin-bottom: 0.5rem;
    line-height: 1.12;
}

.card-desc {
    font-size: 0.8125rem;
    color: var(--nv-muted);
    line-height: 1.65;
    margin-bottom: 1.25rem;
}

.card-price-row {
    display: flex;
    align-items: baseline;
    gap: 0.25rem;
    margin-bottom: 0.25rem;
}

.card-currency {
    font-family: 'IBM Plex Mono', monospace;
    font-size: 1rem;
    color: var(--nv-navy);
    font-weight: 600;
}

.card-price {
    font-family: 'Playfair Display', serif;
    font-size: clamp(2.25rem, 4vw, 3rem);
    color: var(--nv-navy);
    font-weight: 700;
    line-height: 1;
    letter-spacing: -0.02em;
}

.card-price-type,
.card-users {
    font-size: 0.75rem;
    color: var(--nv-muted);
}

.card-users {
    margin-top: 0.5rem;
    font-family: 'IBM Plex Mono', monospace;
    color: var(--nv-cyan);
    letter-spacing: 0.04em;
}

.card-divider {
    height: 1px;
    background: var(--nv-border);
    margin: 0 1.75rem;
}

.card-features {
    padding: 1.25rem 1.75rem 1.5rem;
    flex: 1;
}

.card-feat-head {
    font-size: 0.59375rem;
    color: var(--nv-muted);
    margin-bottom: 0.875rem;
}

.feat-list {
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: 0.625rem;
}

.feat-item {
    display: flex;
    align-items: flex-start;
    gap: 0.625rem;
    font-size: 0.8125rem;
    color: var(--nv-slate);
    line-height: 1.55;
}

.feat-item.muted-feat {
    opacity: 0.7;
}

.feat-check {
    width: 1rem;
    flex-shrink: 0;
    font-family: 'IBM Plex Mono', monospace;
    font-weight: 700;
    text-align: center;
    margin-top: 0.0625rem;
}

.feat-check.yes {
    color: var(--nv-cyan);
}

.feat-check.no {
    color: var(--nv-border);
}

.card-action {
    padding: 1.25rem 1.75rem;
    border-top: 1px solid var(--nv-border);
    background: #fcfcfc;
}

.pricing-card.featured .card-action {
    background: var(--nv-mist);
}

.select-btn {
    width: 100%;
    padding: 0.875rem 1rem;
    border-radius: 4px;
    font-size: 0.875rem;
    font-weight: 700;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: opacity 0.15s ease, background 0.15s ease, color 0.15s ease;
}

.select-btn.btn-outline {
    background: #fff;
    color: var(--nv-blue);
    border: 1.5px solid var(--nv-blue);
}

.select-btn.btn-outline:hover {
    background: #f0f7ff;
}

.select-btn.btn-cyan {
    background: var(--nv-cyan);
    color: var(--nv-navy);
}

.select-btn.btn-cyan:hover {
    opacity: 0.92;
}

.select-licence-card {
    cursor: default;
}

.select-licence-card .selected-indicator {
    display: none;
    align-items: center;
    justify-content: center;
    margin-top: 0.55rem;
    font-size: 0.75rem;
    font-weight: 700;
    color: var(--nv-blue);
}

.select-licence-card.selected .selected-indicator {
    display: flex;
}

.sl-order-section {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 380px;
    gap: 2.5rem;
    align-items: start;
    margin-top: 3rem;
}

.sl-order-details {
    min-width: 0;
}

.sl-selected-licence {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    background: var(--nv-mist);
    border: 1.5px solid var(--nv-cyan);
    border-radius: 6px;
    padding: 1rem 1.25rem;
    margin-bottom: 1.25rem;
}

.osl-tier {
    font-family: 'IBM Plex Mono', monospace;
    font-size: 0.625rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--nv-cyan);
    margin-bottom: 0.25rem;
}

.osl-name {
    font-size: 0.95rem;
    font-weight: 700;
    color: var(--nv-navy);
}

.osl-price {
    font-family: 'Playfair Display', serif;
    font-size: 1.65rem;
    line-height: 1;
    color: var(--nv-blue);
    font-weight: 700;
    text-align: right;
}

.osl-users {
    font-size: 0.72rem;
    color: var(--nv-muted);
    text-align: right;
    margin-top: 0.25rem;
}

.sl-form-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
}

.sl-field {
    display: grid;
    gap: 0.35rem;
    font-family: 'IBM Plex Mono', monospace;
    font-size: 0.625rem;
    letter-spacing: 0.09em;
    text-transform: uppercase;
    color: var(--nv-navy);
    font-weight: 700;
}

.sl-field span {
    color: var(--nv-cyan);
}

.sl-field input,
.sl-field select {
    width: 100%;
    min-height: 2.8rem;
    border: 1.5px solid var(--nv-border);
    border-radius: 4px;
    background: #fff;
    color: var(--nv-text);
    font-family: 'Inter', sans-serif;
    font-size: 0.86rem;
    letter-spacing: 0;
    text-transform: none;
    font-weight: 400;
    padding: 0 0.8rem;
    outline: none;
    transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.sl-field input:focus,
.sl-field select:focus {
    border-color: var(--nv-blue);
    box-shadow: 0 0 0 3px rgba(0, 87, 184, 0.07);
}

.sl-field-full {
    grid-column: 1 / -1;
}

.sl-summary-card {
    border: 1.5px solid var(--nv-border);
    border-radius: 8px;
    overflow: hidden;
    background: #fff;
    position: sticky;
    top: 5rem;
}

.sl-summary-rows {
    display: grid;
}

.sl-summary-rows div {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    padding: 0.85rem 1.25rem;
    border-bottom: 1px solid var(--nv-border);
    font-size: 0.82rem;
}

.sl-summary-rows span {
    color: var(--nv-muted);
}

.sl-summary-rows strong {
    color: var(--nv-navy);
    text-align: right;
}

.sl-total-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    background: var(--nv-mist);
    border-top: 2px solid var(--nv-navy);
    padding: 1rem 1.25rem;
}

.sl-total-row span {
    font-family: 'IBM Plex Mono', monospace;
    font-size: 0.64rem;
    color: var(--nv-muted);
    letter-spacing: 0.1em;
    text-transform: uppercase;
}

.sl-total-row strong {
    font-family: 'Playfair Display', serif;
    font-size: 1.85rem;
    color: var(--nv-blue);
}

.sl-summary-action {
    display: grid;
    gap: 0.75rem;
    padding: 1.1rem 1.25rem;
    border-top: 1px solid var(--nv-border);
}

.proceed-btn {
    width: 100%;
    min-height: 2.9rem;
    border: 0;
    border-radius: 4px;
    background: var(--nv-blue);
    color: #fff;
    font-size: 0.9rem;
    font-weight: 800;
    cursor: pointer;
}

.proceed-btn:hover {
    background: var(--nv-blue-light);
}

.sl-help-link {
    text-align: center;
    color: var(--nv-blue);
    font-size: 0.82rem;
    font-weight: 700;
}

.sl-trust-row {
    display: grid;
    gap: 0.4rem;
    padding: 0.9rem 1.25rem;
    border-top: 1px solid var(--nv-border);
    background: #fcfcfc;
}

.sl-trust-row span {
    color: var(--nv-muted);
    font-size: 0.74rem;
}

.compare-section {
    margin-bottom: 3rem;
}

.compare-toggle {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    cursor: pointer;
    font-size: 0.8125rem;
    color: var(--nv-blue);
    font-weight: 600;
    margin-bottom: 1.25rem;
    background: none;
    border: none;
    padding: 0;
    font-family: 'Inter', sans-serif;
}

.compare-toggle svg {
    transition: transform 0.25s ease;
}

.compare-toggle.open svg {
    transform: rotate(180deg);
}

.compare-wrap {
    display: none;
}

.compare-wrap.open {
    display: block;
}

.compare-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.8125rem;
}

.compare-table thead th {
    padding: 0.8125rem 1.25rem;
    text-align: left;
    font-size: 0.625rem;
    font-weight: 600;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--nv-muted);
    border-bottom: 2px solid var(--nv-navy);
    background: var(--nv-mist);
}

.compare-table thead th:first-child {
    color: var(--nv-navy);
}

.compare-table thead th.featured-col {
    color: var(--nv-cyan);
}

.compare-table tbody tr {
    border-bottom: 1px solid var(--nv-border);
}

.compare-table tbody tr:hover {
    background: #f8fafc;
}

.compare-table tbody td {
    padding: 0.8125rem 1.25rem;
    color: var(--nv-slate);
    vertical-align: middle;
}

.compare-table tbody td:first-child {
    font-weight: 500;
    color: var(--nv-navy);
}

.compare-table .group-row td {
    background: var(--nv-mist);
    font-family: 'IBM Plex Mono', monospace;
    font-size: 0.625rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--nv-blue);
    padding: 0.625rem 1.25rem;
    font-weight: 600;
}

.compare-table .feat-yes {
    color: var(--nv-cyan);
    font-family: 'IBM Plex Mono', monospace;
    font-weight: 700;
}

.compare-table .feat-no {
    color: #b7c4d1;
    font-family: 'IBM Plex Mono', monospace;
    font-weight: 700;
}

.faq-section {
    margin-top: 4rem;
}

.faq-section-title {
    margin-bottom: 1.5rem;
    padding-bottom: 0.75rem;
    border-bottom: 1px solid var(--nv-border);
}

.faq-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1.25rem;
}

.faq-item {
    border: 1px solid var(--nv-border);
    border-radius: 6px;
    padding: 1.25rem 1.375rem;
    background: #fff;
}

.faq-q {
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--nv-navy);
    margin-bottom: 0.5rem;
    line-height: 1.4;
}

.faq-a {
    font-size: 0.8125rem;
    color: var(--nv-muted);
    line-height: 1.65;
}

.faq-a a {
    color: var(--nv-blue);
}

@media (max-width: 1100px) {
    .pricing-grid,
    .faq-grid {
        grid-template-columns: 1fr;
    }

    .sl-order-section {
        grid-template-columns: 1fr;
    }

    .sl-summary-card {
        position: static;
    }
}

@media (max-width: 768px) {
    .lic-body,
    .step-inner {
        padding-left: 1rem;
        padding-right: 1rem;
    }

    .lh-report-strip {
        align-items: flex-start;
    }

    .compare-table {
        display: block;
        overflow-x: auto;
        white-space: nowrap;
    }

    .sl-form-grid {
        grid-template-columns: 1fr;
    }

    .sl-selected-licence {
        align-items: flex-start;
        flex-direction: column;
    }

    .osl-price,
    .osl-users {
        text-align: left;
    }
}

.rft-body {
    max-width: 1280px;
    margin: 0 auto;
    padding: 3.25rem 1.5rem 5rem;
}

.rft-card {
    max-width: 42rem;
    margin: 0 auto;
    background: #fff;
    border: 1.5px solid var(--nv-border);
    border-radius: 10px;
    padding: 2rem;
    box-shadow: 0 18px 48px rgba(12, 26, 46, 0.06);
}

.rft-kicker {
    font-family: 'IBM Plex Mono', monospace;
    font-size: 0.66rem;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--nv-blue);
    margin-bottom: 0.6rem;
}

.rft-title {
    font-family: 'Playfair Display', serif;
    font-size: 2rem;
    color: var(--nv-navy);
    line-height: 1.1;
}

.rft-copy {
    margin-top: 0.85rem;
    color: var(--nv-muted);
    font-size: 0.95rem;
    line-height: 1.75;
}

.rft-points {
    margin-top: 1.5rem;
    display: grid;
    gap: 0.75rem;
}

.rft-point {
    padding: 0.85rem 1rem;
    border: 1px solid var(--nv-border);
    border-radius: 6px;
    background: var(--nv-mist);
    color: var(--nv-slate);
    font-size: 0.85rem;
    line-height: 1.6;
}

.rft-actions {
    margin-top: 1.75rem;
    display: flex;
    flex-wrap: wrap;
    gap: 0.85rem;
}

.rft-btn {
    min-width: 12rem;
    min-height: 2.9rem;
    padding: 0.75rem 1.1rem;
    border-radius: 4px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 0.88rem;
    font-weight: 700;
}

.rft-btn-primary {
    background: var(--nv-blue);
    color: #fff;
}

.rft-btn-secondary {
    background: #fff;
    color: var(--nv-blue);
    border: 1.5px solid var(--nv-blue);
}

.sector-hub-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1rem;
}

.sector-hub-card {
    display: block;
    background: #fff;
    border: 1px solid var(--nv-border);
    border-radius: 6px;
    padding: 1.25rem;
    color: inherit;
    text-decoration: none;
    transition: border-color 0.18s ease, box-shadow 0.18s ease;
}

.sector-hub-card:hover {
    border-color: var(--nv-blue);
    box-shadow: 0 4px 20px rgba(0, 87, 184, 0.1);
}

.sector-hub-title {
    font-family: 'Playfair Display', serif;
    color: var(--nv-navy);
    font-size: 1rem;
    line-height: 1.35;
    margin-bottom: 0.4rem;
}

.sector-hub-meta {
    font-family: 'IBM Plex Mono', monospace;
    color: var(--nv-blue);
    font-size: 0.66rem;
    letter-spacing: 0.05em;
    text-transform: uppercase;
}

.sector-hub-children {
    margin-top: 0.85rem;
    display: flex;
    flex-wrap: wrap;
    gap: 0.4rem;
}

.sector-hub-children span {
    border: 1px solid var(--nv-border);
    border-radius: 3px;
    padding: 0.25rem 0.45rem;
    color: var(--nv-muted);
    font-size: 0.72rem;
    line-height: 1.3;
}

.legal-layout {
    max-width: 1280px;
    margin: 0 auto;
    padding: 3.5rem 1.5rem 5rem;
    display: grid;
    grid-template-columns: minmax(0, 1fr) 320px;
    gap: 2rem;
}

.legal-main {
    display: grid;
    gap: 1rem;
}

.legal-section,
.legal-side-card {
    background: #fff;
    border: 1px solid var(--nv-border);
    border-radius: 6px;
    padding: 1.5rem;
}

.legal-num {
    font-family: 'IBM Plex Mono', monospace;
    font-size: 0.65rem;
    color: var(--nv-blue);
    letter-spacing: 0.12em;
    text-transform: uppercase;
    margin-bottom: 0.45rem;
}

.legal-section h2,
.legal-side-title {
    font-family: 'Playfair Display', serif;
    color: var(--nv-navy);
    font-size: 1.25rem;
    margin-bottom: 0.75rem;
}

.legal-section p,
.legal-section li {
    color: var(--nv-muted);
    font-size: 0.9rem;
    line-height: 1.72;
}

.legal-section ul {
    margin-left: 1.1rem;
    display: grid;
    gap: 0.35rem;
}

.legal-methods {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.75rem;
    margin-top: 1rem;
}

.legal-methods div,
.legal-callout,
.legal-side-row {
    border: 1px solid var(--nv-border);
    background: #f8fafc;
    border-radius: 4px;
    padding: 0.8rem;
}

.legal-methods strong,
.legal-callout strong {
    display: block;
    color: var(--nv-navy);
    font-size: 0.85rem;
    margin-bottom: 0.25rem;
}

.legal-methods span,
.legal-callout span,
.legal-side-row {
    color: var(--nv-muted);
    font-size: 0.82rem;
    line-height: 1.6;
}

.legal-callout {
    margin-top: 1rem;
    border-left: 3px solid var(--nv-blue);
}

.legal-callout.warn {
    border-left-color: #b45309;
}

.legal-side {
    align-self: start;
    position: sticky;
    top: 5rem;
}

.legal-side-card {
    display: grid;
    gap: 0.6rem;
}

@media (max-width: 1100px) {
    .sector-hub-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .legal-layout {
        grid-template-columns: 1fr;
    }

    .legal-side {
        position: static;
    }
}

@media (max-width: 640px) {
    .sector-hub-grid,
    .legal-methods {
        grid-template-columns: 1fr;
    }
}

.about-hero {
    position: relative;
    overflow: hidden;
    background: var(--nv-navy-2);
    padding: 4.5rem 0 3.75rem;
}

.about-hero-grid {
    position: absolute;
    inset: 0;
    background-image: linear-gradient(rgba(0, 87, 184, 0.055) 1px, transparent 1px),
        linear-gradient(90deg, rgba(0, 87, 184, 0.055) 1px, transparent 1px);
    background-size: 42px 42px;
    pointer-events: none;
}

.about-hero-inner {
    position: relative;
    z-index: 1;
    max-width: 1280px;
    margin: 0 auto;
    padding: 0 1.5rem;
    display: grid;
    grid-template-columns: minmax(0, 1fr) 380px;
    gap: 4rem;
    align-items: center;
}

.about-kicker,
.about-stat span,
.about-tags span,
.about-mission-label,
.about-method-num,
.about-tier-label,
.about-spec-head span {
    font-family: 'IBM Plex Mono', monospace;
}

.about-kicker {
    font-size: 0.6875rem;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--nv-cyan);
    margin-bottom: 0.9rem;
}

.about-title {
    max-width: 680px;
    font-family: 'Playfair Display', serif;
    font-size: clamp(2.35rem, 5vw, 3.35rem);
    line-height: 1.08;
    color: #fff;
    font-weight: 700;
    margin-bottom: 1rem;
}

.about-lede {
    max-width: 640px;
    font-size: 1rem;
    line-height: 1.78;
    color: rgba(255, 255, 255, 0.62);
    margin-bottom: 1.6rem;
}

.about-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}

.about-tags span {
    font-size: 0.625rem;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: #8fdcff;
    background: rgba(0, 87, 184, 0.28);
    border: 1px solid rgba(0, 180, 216, 0.16);
    border-radius: 2px;
    padding: 0.32rem 0.7rem;
}

.about-stat-panel {
    border: 1px solid rgba(255, 255, 255, 0.1);
    background: rgba(255, 255, 255, 0.035);
    border-radius: 6px;
    overflow: hidden;
}

.about-stat {
    padding: 1.2rem 1.4rem;
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

.about-stat:last-child {
    border-bottom: 0;
}

.about-stat strong {
    display: block;
    font-family: 'Playfair Display', serif;
    font-size: 2.05rem;
    line-height: 1;
    color: #fff;
    margin-bottom: 0.35rem;
}

.about-stat span {
    display: block;
    color: rgba(255, 255, 255, 0.42);
    font-size: 0.66rem;
    text-transform: uppercase;
    letter-spacing: 0.09em;
}

.about-intro-sec {
    background: #fff;
}

.about-two-col,
.about-report-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 410px;
    gap: 3.25rem;
    align-items: start;
}

.about-copy {
    max-width: 760px;
}

.about-copy p {
    color: #475569;
    font-size: 0.925rem;
    line-height: 1.82;
    margin-bottom: 1rem;
}

.about-copy p:last-child {
    margin-bottom: 0;
}

.about-mission {
    background: linear-gradient(135deg, var(--nv-navy), #0d3a6b);
    border-left: 3px solid var(--nv-cyan);
    border-radius: 6px;
    padding: 1.75rem;
}

.about-mission-label {
    color: var(--nv-cyan);
    font-size: 0.62rem;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    margin-bottom: 0.65rem;
}

.about-mission blockquote {
    font-family: 'Playfair Display', serif;
    font-size: 1.1rem;
    font-style: italic;
    line-height: 1.55;
    color: #fff;
    margin-bottom: 1rem;
}

.about-mission p {
    color: rgba(255, 255, 255, 0.52);
    font-size: 0.82rem;
    line-height: 1.7;
}

.about-sector-grid,
.about-method-grid,
.about-why-grid,
.about-tier-grid {
    display: grid;
    gap: 1rem;
}

.about-sector-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.about-sector-card,
.about-method-card,
.about-why-card,
.about-tier-card,
.about-spec-card {
    background: #fff;
    border: 1px solid var(--nv-border);
    border-radius: 6px;
}

.about-sector-card {
    padding: 1.15rem;
    transition: border-color 0.18s ease, box-shadow 0.18s ease;
}

.about-sector-card:hover,
.about-method-card:hover,
.about-why-card:hover {
    border-color: var(--nv-blue);
    box-shadow: 0 4px 18px rgba(0, 87, 184, 0.08);
}

.about-sector-mark {
    width: 2rem;
    height: 2rem;
    border: 1px solid rgba(0, 87, 184, 0.18);
    background:
        linear-gradient(90deg, transparent 47%, rgba(0, 180, 216, 0.48) 47%, rgba(0, 180, 216, 0.48) 53%, transparent 53%),
        linear-gradient(transparent 47%, rgba(0, 87, 184, 0.36) 47%, rgba(0, 87, 184, 0.36) 53%, transparent 53%),
        #eef7ff;
    border-radius: 4px;
    margin-bottom: 0.85rem;
}

.about-sector-name,
.about-method-title,
.about-deliverable-title,
.about-why-title {
    color: var(--nv-navy);
    font-weight: 700;
    line-height: 1.35;
}

.about-sector-name {
    font-size: 0.9rem;
    margin-bottom: 0.35rem;
}

.about-sector-desc,
.about-method-body,
.about-deliverable-body,
.about-why-body,
.about-tier-body {
    color: var(--nv-muted);
    font-size: 0.8rem;
    line-height: 1.65;
}

.about-method-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    margin-top: 2rem;
}

.about-method-card {
    padding: 1.25rem;
    border-top: 3px solid var(--nv-blue);
}

.about-method-num {
    font-size: 0.67rem;
    color: var(--nv-blue);
    letter-spacing: 0.1em;
    text-transform: uppercase;
    margin-bottom: 0.65rem;
}

.about-method-title {
    font-size: 0.92rem;
    margin-bottom: 0.45rem;
}

.about-deliverables {
    display: grid;
    gap: 0.75rem;
    margin-top: 1.8rem;
}

.about-deliverable {
    display: grid;
    grid-template-columns: 2rem minmax(0, 1fr);
    gap: 0.8rem;
    align-items: start;
    border: 1px solid var(--nv-border);
    background: #fff;
    border-radius: 6px;
    padding: 0.85rem 1rem;
}

.about-check {
    width: 2rem;
    height: 2rem;
    border-radius: 4px;
    background: #e7f8fc;
    color: var(--nv-blue);
    font-family: 'IBM Plex Mono', monospace;
    font-size: 0.58rem;
    font-weight: 700;
    display: flex;
    align-items: center;
    justify-content: center;
}

.about-deliverable-title {
    font-size: 0.86rem;
    margin-bottom: 0.15rem;
}

.about-spec-card {
    overflow: hidden;
}

.about-spec-head {
    background: var(--nv-navy);
    padding: 1rem 1.25rem;
}

.about-spec-head span {
    display: block;
    color: rgba(255, 255, 255, 0.42);
    font-size: 0.59rem;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    margin-bottom: 0.25rem;
}

.about-spec-head strong {
    color: #fff;
    font-size: 0.9rem;
}

.about-spec-row {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    padding: 0.72rem 1.15rem;
    border-bottom: 1px solid var(--nv-border);
    font-size: 0.82rem;
}

.about-spec-row span {
    color: var(--nv-muted);
}

.about-spec-row strong {
    color: var(--nv-navy);
    text-align: right;
}

.about-spec-actions {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0.65rem;
    padding: 1rem 1.15rem;
    background: #f8fafc;
}

.about-spec-actions .btn-ol,
.about-spec-actions .btn-prim {
    text-align: center;
    padding: 0.72rem 0.9rem;
    font-weight: 700;
}

.about-tier-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
    margin-top: 1.75rem;
}

.about-tier-card {
    padding: 1.15rem;
    border-left: 3px solid var(--nv-border);
}

.about-tier-card.tier-a1 {
    border-left-color: #ef4444;
}

.about-tier-card.tier-a2 {
    border-left-color: #b45309;
}

.about-tier-card.tier-b {
    border-left-color: var(--nv-blue);
}

.about-tier-label {
    font-size: 0.62rem;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--nv-blue);
    margin-bottom: 0.55rem;
}

.about-tier-count {
    font-family: 'Playfair Display', serif;
    font-size: 2.25rem;
    font-weight: 700;
    color: var(--nv-navy);
    line-height: 1;
    margin-bottom: 0.55rem;
}

.about-why-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    margin-top: 1.75rem;
}

.about-why-card {
    padding: 1.25rem;
}

.about-why-title {
    font-size: 0.95rem;
    margin-bottom: 0.45rem;
}

.about-dynamic-grid {
    align-items: stretch;
}

.about-empty-card {
    grid-column: 1 / -1;
    border: 1px dashed var(--nv-border);
    background: #fff;
    border-radius: 6px;
    padding: 1.35rem;
    color: var(--nv-muted);
    font-size: 0.9rem;
    line-height: 1.65;
}

@media (max-width: 1100px) {
    .about-hero-inner,
    .about-two-col,
    .about-report-grid {
        grid-template-columns: 1fr;
    }

    .about-stat-panel {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .about-stat:nth-child(2) {
        border-right: 0;
    }

    .about-sector-grid,
    .about-tier-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .about-method-grid,
    .about-why-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 700px) {
    .about-hero {
        padding: 3.3rem 0 2.7rem;
    }

    .about-hero-inner {
        gap: 2rem;
    }

    .about-stat-panel,
    .about-sector-grid,
    .about-method-grid,
    .about-why-grid,
    .about-tier-grid,
    .about-spec-actions {
        grid-template-columns: 1fr;
    }

    .about-title {
        font-size: 2.25rem;
    }
}

@media (max-width: 640px) {
    body {
        padding-bottom: 4.15rem;
    }

    .nv-header {
        background: #fff;
        box-shadow: 0 1px 0 rgba(12, 26, 46, 0.08);
    }

    .nv-nav-shell {
        display: none;
    }

    .nv-mobile-topbar {
        display: grid;
        grid-template-columns: 2.5rem minmax(0, 1fr) auto;
        align-items: center;
        gap: 0.75rem;
        min-height: 3.8rem;
        padding: 0.65rem 1rem;
        background: #fff;
    }

    .nv-mobile-logo {
        display: flex;
        align-items: center;
        min-width: 0;
    }

    .nv-mobile-logo-lockup {
        width: 126px;
        max-width: 100%;
        height: auto;
        display: block;
    }

    .nv-mobile-actions {
        display: flex;
        align-items: center;
        gap: 0.4rem;
    }

    .nv-mobile-icon-btn {
        width: 2rem;
        height: 2rem;
        border: 1px solid var(--nv-border);
        border-radius: 8px;
        background: #fff;
        color: var(--nv-navy);
        display: inline-flex;
        align-items: center;
        justify-content: center;
        position: relative;
        flex: 0 0 auto;
        cursor: pointer;
    }

    .nv-mobile-menu-toggle {
        border: 0;
        border-radius: 0;
    }

    .nv-mobile-menu-toggle span {
        position: absolute;
        left: 0.45rem;
        right: 0.45rem;
        height: 2px;
        background: var(--nv-navy);
        border-radius: 999px;
    }

    .nv-mobile-menu-toggle span:nth-child(1) {
        top: 0.65rem;
    }

    .nv-mobile-menu-toggle span:nth-child(2) {
        top: 0.98rem;
    }

    .nv-mobile-menu-toggle span:nth-child(3) {
        top: 1.31rem;
    }

    .nv-icon,
    .nv-bottom-icon {
        position: relative;
        display: inline-block;
        width: 1rem;
        height: 1rem;
        color: currentColor;
    }

    .nv-icon-search::before {
        content: '';
        position: absolute;
        width: 0.58rem;
        height: 0.58rem;
        border: 2px solid currentColor;
        border-radius: 999px;
        left: 0.08rem;
        top: 0.08rem;
    }

    .nv-icon-search::after {
        content: '';
        position: absolute;
        width: 0.38rem;
        height: 2px;
        background: currentColor;
        transform: rotate(45deg);
        right: 0.06rem;
        bottom: 0.18rem;
        border-radius: 999px;
    }

    .nv-icon-report::before,
    .nv-icon-doc::before {
        content: '';
        position: absolute;
        inset: 0.1rem 0.18rem;
        border: 1.8px solid currentColor;
        border-radius: 2px;
    }

    .nv-icon-report::after,
    .nv-icon-doc::after {
        content: '';
        position: absolute;
        left: 0.36rem;
        right: 0.36rem;
        top: 0.42rem;
        height: 2px;
        background: currentColor;
        box-shadow: 0 0.25rem 0 currentColor;
    }

    .nv-mobile-search-panel {
        position: absolute;
        left: 1rem;
        right: 1rem;
        top: calc(100% + 0.55rem);
        z-index: 115;
        display: block;
        opacity: 0;
        transform: translateY(-0.45rem);
        pointer-events: none;
        transition: opacity 0.18s ease, transform 0.18s ease;
    }

    .nv-mobile-search-panel.is-open {
        opacity: 1;
        transform: translateY(0);
        pointer-events: auto;
    }

    .nv-mobile-search-form {
        display: grid;
        gap: 0.7rem;
        background: #fff;
        border-radius: 10px;
        padding: 0.75rem;
        border: 1px solid var(--nv-border);
        box-shadow: 0 16px 38px rgba(12, 26, 46, 0.2);
    }

    .nv-mobile-search-form input {
        width: 100%;
        min-height: 3rem;
        border: 1.5px solid var(--nv-cyan);
        border-radius: 7px;
        padding: 0 0.75rem;
        color: var(--nv-navy);
        font-size: 0.9rem;
        outline: 2px solid rgba(0, 180, 216, 0.16);
    }

    .nv-mobile-search-help {
        min-height: 2.75rem;
        display: flex;
        align-items: center;
        border-radius: 6px;
        background: #f3f6fa;
        color: var(--nv-muted);
        font-size: 0.76rem;
        padding: 0 0.75rem;
    }

    .nv-mobile-search-results {
        display: grid;
        gap: 0.45rem;
    }

    .nv-mobile-search-result,
    .nv-mobile-search-all {
        display: grid;
        gap: 0.2rem;
        border: 1px solid var(--nv-border);
        border-radius: 7px;
        background: #fff;
        padding: 0.65rem 0.75rem;
        color: var(--nv-navy);
    }

    .nv-mobile-search-result strong {
        font-size: 0.78rem;
        line-height: 1.35;
    }

    .nv-mobile-search-result span {
        color: var(--nv-muted);
        font-family: 'IBM Plex Mono', monospace;
        font-size: 0.58rem;
        letter-spacing: 0.08em;
        text-transform: uppercase;
    }

    .nv-mobile-search-all {
        display: flex;
        align-items: center;
        justify-content: center;
        min-height: 2.4rem;
        background: var(--nv-cyan);
        border-color: var(--nv-cyan);
        color: var(--nv-navy);
        font-family: 'IBM Plex Mono', monospace;
        font-size: 0.66rem;
        font-weight: 900;
        letter-spacing: 0.08em;
        text-transform: uppercase;
    }

    .nv-mobile-modal-backdrop {
        position: fixed;
        inset: 0;
        z-index: 112;
        display: block;
        background: rgba(12, 26, 46, 0.58);
        opacity: 0;
        pointer-events: none;
        transition: opacity 0.2s ease;
    }

    .nv-mobile-modal-backdrop.is-open {
        opacity: 1;
        pointer-events: auto;
    }

    .nv-mobile-sample-modal {
        position: fixed;
        left: 1.25rem;
        right: 1.25rem;
        top: 5.8rem;
        z-index: 125;
        display: block;
        background: #fff;
        border-radius: 10px;
        padding: 1rem;
        box-shadow: 0 18px 48px rgba(12, 26, 46, 0.24);
        opacity: 0;
        transform: translateY(-0.55rem);
        pointer-events: none;
        transition: opacity 0.2s ease, transform 0.2s ease;
    }

    .nv-mobile-sample-modal.is-open {
        opacity: 1;
        transform: translateY(0);
        pointer-events: auto;
    }

    .nv-mobile-sample-head {
        display: flex;
        justify-content: space-between;
        gap: 1rem;
        padding-bottom: 0.9rem;
    }

    .nv-mobile-sample-head h2 {
        margin: 0;
        color: var(--nv-navy);
        font-family: 'Playfair Display', serif;
        font-size: 1.35rem;
        line-height: 1;
    }

    .nv-mobile-sample-head p {
        margin: 0.35rem 0 0;
        color: var(--nv-muted);
        font-size: 0.76rem;
        line-height: 1.35;
    }

    .nv-mobile-sample-close {
        width: 2rem;
        height: 2rem;
        border: 0;
        background: transparent;
        color: var(--nv-navy);
        font-size: 1.1rem;
        cursor: pointer;
    }

    .nv-mobile-sample-form {
        display: grid;
        gap: 0.65rem;
    }

    .nv-mobile-sample-form input,
    .nv-mobile-sample-form select {
        width: 100%;
        min-height: 2.9rem;
        border: 1px solid var(--nv-border);
        border-radius: 7px;
        background: #fff;
        color: var(--nv-navy);
        padding: 0 0.8rem;
        font-size: 0.82rem;
        font-weight: 600;
    }

    .nv-mobile-sample-form button {
        min-height: 2.85rem;
        border: 0;
        border-radius: 7px;
        background: var(--nv-cyan);
        color: var(--nv-navy);
        font-family: 'IBM Plex Mono', monospace;
        font-size: 0.7rem;
        font-weight: 900;
        letter-spacing: 0.1em;
        text-transform: uppercase;
    }

    .nv-mobile-menu {
        position: fixed;
        top: 0;
        left: 0;
        bottom: 0;
        z-index: 120;
        width: min(86vw, 320px);
        display: block;
        background: #fff;
        padding: 1rem 1rem 1.25rem;
        transform: translateX(-105%);
        transition: transform 0.22s ease;
        box-shadow: 18px 0 42px rgba(12, 26, 46, 0.18);
    }

    .nv-mobile-menu.is-open {
        transform: translateX(0);
    }

    .nv-mobile-menu-backdrop {
        position: fixed;
        inset: 0;
        z-index: 110;
        display: block;
        background: rgba(12, 26, 46, 0.5);
        opacity: 0;
        pointer-events: none;
        transition: opacity 0.22s ease;
    }

    .nv-mobile-menu-backdrop.is-open {
        opacity: 1;
        pointer-events: auto;
    }

    .nv-mobile-menu-head {
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 1rem;
        padding: 0.1rem 0 1rem;
        border-bottom: 1px solid var(--nv-border);
    }

    .nv-mobile-menu-close {
        width: 2rem;
        height: 2rem;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        border: 0;
        background: transparent;
        color: var(--nv-navy);
        font-size: 1.6rem;
        line-height: 1;
        cursor: pointer;
    }

    .nv-mobile-menu-list {
        display: grid;
        margin-top: 0.6rem;
    }

    .nv-mobile-menu-list a {
        display: flex;
        align-items: center;
        min-height: 3.35rem;
        border-bottom: 1px solid var(--nv-border);
        color: var(--nv-navy);
        font-size: 0.9rem;
        font-weight: 600;
    }

    .nv-mobile-menu-cta {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        margin-top: 1rem;
        min-height: 2.65rem;
        padding: 0 1rem;
        border-radius: 4px;
        background: var(--nv-cyan);
        color: var(--nv-navy);
        font-family: 'IBM Plex Mono', monospace;
        font-size: 0.68rem;
        font-weight: 800;
        letter-spacing: 0.12em;
        text-transform: uppercase;
        box-shadow: 0 12px 24px rgba(0, 180, 216, 0.18);
    }

    .nv-mobile-bottom-nav {
        position: fixed;
        left: 0.65rem;
        right: 0.65rem;
        bottom: 0;
        z-index: 90;
        height: 3.6rem;
        display: grid;
        grid-template-columns: repeat(4, minmax(0, 1fr));
        align-items: center;
        background: #fff;
        border: 1px solid var(--nv-border);
        box-shadow: 0 -8px 28px rgba(12, 26, 46, 0.14);
    }

    .nv-mobile-bottom-nav a {
        display: grid;
        justify-items: center;
        gap: 0.22rem;
        color: var(--nv-muted);
        font-size: 0.66rem;
        font-weight: 600;
        line-height: 1;
    }

    .nv-mobile-bottom-nav a.is-active {
        color: var(--nv-blue);
    }

    .nv-bottom-home::before {
        content: '';
        position: absolute;
        width: 0.72rem;
        height: 0.58rem;
        left: 0.14rem;
        bottom: 0.08rem;
        border: 1.6px solid currentColor;
        border-top: 0;
    }

    .nv-bottom-home::after {
        content: '';
        position: absolute;
        width: 0.62rem;
        height: 0.62rem;
        left: 0.19rem;
        top: 0.04rem;
        border-left: 1.6px solid currentColor;
        border-top: 1.6px solid currentColor;
        transform: rotate(45deg);
    }

    .nv-bottom-reports::before,
    .nv-bottom-form::before {
        content: '';
        position: absolute;
        inset: 0.1rem 0.22rem;
        border: 1.6px solid currentColor;
        border-radius: 2px;
    }

    .nv-bottom-reports::after,
    .nv-bottom-form::after {
        content: '';
        position: absolute;
        left: 0.38rem;
        right: 0.38rem;
        top: 0.4rem;
        height: 1.5px;
        background: currentColor;
        box-shadow: 0 0.22rem 0 currentColor;
    }

    .nv-bottom-insights::before {
        content: '';
        position: absolute;
        left: 0.46rem;
        top: 0.15rem;
        width: 1.5px;
        height: 0.7rem;
        background: currentColor;
    }

    .nv-bottom-insights::after {
        content: '';
        position: absolute;
        left: 0.27rem;
        top: 0.17rem;
        width: 0.42rem;
        height: 0.42rem;
        border-top: 1.6px solid currentColor;
        border-left: 1.6px solid currentColor;
        transform: rotate(45deg);
    }
}

@media (max-width: 640px) {
    .rf-hero {
        padding: 2rem 0 1.8rem;
    }

    .rf-hero-inner,
    .rf-step-inner,
    .rf-body {
        max-width: none;
        width: 100%;
        padding-left: 1rem;
        padding-right: 1rem;
    }

    .rf-title {
        font-size: 2rem;
        line-height: 1.08;
    }

    .rf-sub {
        font-size: 0.9rem;
        line-height: 1.6;
    }

    .rf-report-strip {
        align-items: flex-start;
        max-width: none;
        padding: 0.85rem;
    }

    .rf-report-meta {
        overflow-wrap: anywhere;
    }

    .rf-step-inner {
        min-height: auto;
        padding-top: 0.6rem;
        padding-bottom: 0.6rem;
        overflow-x: auto;
    }

    .rf-step {
        flex: 0 0 auto;
        padding-right: 0.75rem;
        font-size: 0.72rem;
    }

    .rf-step-arrow {
        padding-right: 0.75rem;
    }

    .rf-body {
        display: block;
        padding-top: 1.25rem;
        padding-bottom: 5rem;
    }

    .rf-left {
        display: none;
    }

    .rf-form-card {
        position: static;
        width: 100%;
        max-width: none;
        border-radius: 8px;
        overflow: hidden;
    }

    .rf-form-head {
        padding: 1rem;
    }

    .rf-form-title {
        font-size: 1.25rem;
    }

    .rf-form-sub {
        font-size: 0.78rem;
    }

    .rf-form-delivery {
        padding: 0.65rem 1rem;
        font-size: 0.62rem;
        line-height: 1.45;
    }

    .rf-form-body {
        padding: 1rem;
    }

    .rf-row,
    .rf-row-full {
        grid-template-columns: 1fr;
        gap: 0.75rem;
        margin-bottom: 0.75rem;
    }

    .rf-field input,
    .rf-field select,
    .rf-field textarea {
        min-width: 0;
        font-size: 0.84rem;
    }

    .rf-field textarea {
        min-height: 7rem;
    }

    .rf-success {
        margin: 0 1rem 0.8rem;
    }
}
