.ps-lms2-logo-img {
    width: 82px;
    height: 82px;
    object-fit: contain;
    border-radius: 1.45rem;
    background: #071827;
    box-shadow: 0 14px 38px rgba(8, 24, 39, .14);
}

.ps-lms2-hero-card .ps-lms2-logo-img {
    width: 72px;
    height: 72px;
    border-radius: 1.2rem;
    background: #071827;
}

.ps-lms2-hero {
    position: relative;
}

.ps-lms2-hero::before {
    content: "";
    position: absolute;
    inset: 0;
    background:
        linear-gradient(90deg, rgba(4, 16, 29, .96) 0%, rgba(4, 16, 29, .82) 46%, rgba(4, 16, 29, .46) 100%),
        url('/branding/official/psops-fire-scene-hero-wide.webp') center / cover no-repeat;
    opacity: .92;
    pointer-events: none;
}

.ps-lms2-hero > * {
    position: relative;
    z-index: 1;
}

.ps-lms2-browser-screen--brand {
    height: 370px;
    background: #071827;
}

.ps-lms2-browser-screen--brand img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.psops-official-strip {
    background: #04101d;
    color: #ffffff;
    border-top: 1px solid rgba(98, 201, 243, .16);
    border-bottom: 1px solid rgba(98, 201, 243, .16);
}

.psops-official-strip__inner {
    width: min(1540px, calc(100% - 72px));
    margin: 0 auto;
    display: grid;
    grid-template-columns: 180px 1fr 180px;
    gap: 2rem;
    align-items: center;
    padding: 2.4rem 0;
}

.psops-official-strip img {
    max-width: 100%;
    height: auto;
    display: block;
}

.psops-official-strip h2 {
    margin: 0 0 .55rem;
    color: #ffffff;
    font-size: clamp(2rem, 3vw, 3.4rem);
    line-height: .96;
    letter-spacing: -.055em;
}

.psops-official-strip p {
    margin: 0;
    color: rgba(232, 241, 250, .78);
    line-height: 1.65;
    font-size: 1.05rem;
}

.psops-search-depth {
    background: #ffffff;
    color: #0b1726;
    padding: clamp(3.5rem, 7vw, 6.5rem) 0;
}

.psops-search-depth__inner {
    width: min(1540px, calc(100% - 72px));
    margin: 0 auto;
}

.psops-search-depth__head {
    max-width: 1050px;
    margin-bottom: 2rem;
}

.psops-search-depth__head span {
    display: block;
    color: #2f8edb;
    font-weight: 1000;
    letter-spacing: .26em;
    text-transform: uppercase;
    font-size: .9rem;
}

.psops-search-depth__head h2 {
    margin: .7rem 0 .8rem;
    color: #0b1726;
    font-size: clamp(2.7rem, 5vw, 5.7rem);
    line-height: .92;
    letter-spacing: -.07em;
}

.psops-search-depth__head p {
    max-width: 960px;
    color: #617083;
    font-size: 1.1rem;
    line-height: 1.7;
}

.psops-search-depth__grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1.2rem;
}

.psops-search-depth__card {
    border: 1px solid #dce7f0;
    border-radius: 1.35rem;
    background: #f8fbfe;
    padding: 1.4rem;
    box-shadow: 0 18px 55px rgba(8, 24, 39, .06);
}

.psops-search-depth__card h3 {
    margin: 0 0 .55rem;
    color: #0b1726;
    font-size: 1.35rem;
    line-height: 1.12;
}

.psops-search-depth__card p {
    margin: 0;
    color: #617083;
    line-height: 1.62;
}

.psops-search-depth__links {
    display: flex;
    flex-wrap: wrap;
    gap: .7rem;
    margin-top: 1.8rem;
}

.psops-search-depth__links a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 48px;
    border-radius: 999px;
    padding: .8rem 1.05rem;
    text-decoration: none;
    font-weight: 1000;
    color: #ffffff;
    background: linear-gradient(120deg, #f05a28, #f46c31 55%, #2f8edb);
}

.psops-neris-official {
    background:
        linear-gradient(90deg, rgba(4, 16, 29, .96), rgba(7, 24, 39, .94)),
        url('/branding/official/psops-public-safety-vehicles-hero-wide.webp') center / cover no-repeat;
    color: #ffffff;
    padding: clamp(3.5rem, 7vw, 6.5rem) 0;
}

.psops-neris-official__inner {
    width: min(1540px, calc(100% - 72px));
    margin: 0 auto;
    display: grid;
    grid-template-columns: 260px 1fr;
    gap: 2.5rem;
    align-items: center;
}

.psops-neris-official img {
    width: 100%;
    max-width: 260px;
    height: auto;
    display: block;
    filter: drop-shadow(0 24px 50px rgba(0,0,0,.35));
}

.psops-neris-official span {
    display: block;
    color: #62c9f3;
    font-weight: 1000;
    letter-spacing: .25em;
    text-transform: uppercase;
    font-size: .9rem;
}

.psops-neris-official h2 {
    margin: .7rem 0 .8rem;
    color: #ffffff;
    font-size: clamp(2.5rem, 5vw, 5rem);
    line-height: .92;
    letter-spacing: -.07em;
}

.psops-neris-official p {
    max-width: 980px;
    color: rgba(232, 241, 250, .78);
    font-size: 1.1rem;
    line-height: 1.7;
}

@media (max-width: 900px) {
    .psops-official-strip__inner,
    .psops-neris-official__inner {
        width: min(100% - 32px, 1540px);
        grid-template-columns: 1fr;
    }

    .psops-official-strip img,
    .psops-neris-official img {
        max-width: 180px;
    }

    .psops-search-depth__inner {
        width: min(100% - 32px, 1540px);
    }

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

/* Public header logo */
.psops-header-brand-logo {
    width: 64px;
    height: 64px;
    object-fit: contain;
    display: block;
    flex: 0 0 auto;
    border-radius: 1rem;
    background: transparent;
}

.psops-public-brand,
.ps-public-brand,
.marketing-brand {
    display: inline-flex;
    align-items: center;
    gap: .95rem;
}

.psops-public-brand strong,
.ps-public-brand strong,
.marketing-brand strong {
    display: block;
    line-height: 1.02;
}

.psops-public-brand span,
.ps-public-brand span,
.marketing-brand span {
    display: block;
}


/* Fixed public marketing header + official brand lockup */
body:has(.psops-global-brand) {
    padding-top: 74px;
}

body:has(.psops-global-brand) header:has(.psops-global-brand) {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    z-index: 9999 !important;
    background: rgba(6, 18, 30, .92) !important;
    border-bottom: 1px solid rgba(98, 201, 243, .14) !important;
    box-shadow: 0 16px 45px rgba(0, 0, 0, .22) !important;
    backdrop-filter: blur(18px);
}

.psops-global-brand {
    display: inline-flex !important;
    align-items: center !important;
    gap: .82rem !important;
    color: #ffffff !important;
    text-decoration: none !important;
}

.psops-global-brand__logo {
    width: 54px !important;
    height: 54px !important;
    object-fit: contain !important;
    display: block !important;
    flex: 0 0 auto !important;
    border-radius: .85rem !important;
    background: transparent !important;
}

.psops-global-brand__text strong {
    display: block !important;
    color: #ffffff !important;
    font-size: 1.05rem !important;
    line-height: 1 !important;
    letter-spacing: .01em !important;
}

.psops-global-brand__text small {
    display: block !important;
    margin-top: .18rem !important;
    color: rgba(226, 238, 250, .74) !important;
    font-size: .66rem !important;
    font-weight: 900 !important;
    letter-spacing: .22em !important;
    text-transform: uppercase !important;
}

@media (max-width: 720px) {
    body:has(.psops-global-brand) {
        padding-top: 68px;
    }

    .psops-global-brand__logo {
        width: 46px !important;
        height: 46px !important;
    }

    .psops-global-brand__text small {
        display: none !important;
    }
}
