:root {
    --bs-primary: #0d6efd;
    --corporate-ink: #172033;
    --corporate-soft: #f5f8fc;
    --deep-navy: #0f1726;
    --navy-2: #18243a;
    --platinum: #f7f8fb;
    --line-soft: #e4eaf4;
    --muted-ink: #657188;
    --lux-gold: #c8a45d;
    --gold-soft: #fff7e6;
    --emerald: #1d8b6a;
}

.software-page {
    display: grid;
    gap: 72px;
}

.software-kicker {
    display: inline-flex;
    align-items: center;
    max-width: 100%;
    min-height: 46px;
    margin-bottom: 16px;
    padding: 10px 18px;
    border: 2px solid #93c5fd;
    border-radius: 16px;
    color: #0b4fd9;
    background: linear-gradient(135deg, #fff 0%, #eff6ff 100%);
    box-shadow: 0 14px 30px rgba(37, 99, 235, .12);
    font-size: clamp(1rem, 1.8vw, 1.45rem);
    font-weight: 850;
    letter-spacing: .02em;
    line-height: 1.2;
    text-transform: uppercase;
}

.software-hero,
.software-license-panel,
.software-consult-box {
    display: grid;
    grid-template-columns: minmax(0, 1.08fr) minmax(320px, .92fr);
    align-items: center;
    gap: 34px;
}

.software-hero {
    padding: 34px;
    border: 1px solid #dbe8fb;
    border-radius: 8px;
    background:
        radial-gradient(circle at top right, rgba(37, 99, 235, .12), transparent 34%),
        linear-gradient(135deg, #f8fbff 0%, #eef6ff 52%, #fff 100%);
    box-shadow: 0 24px 60px rgba(16, 24, 40, .08);
}

.software-hero h2,
.software-section h2,
.software-license-panel h2,
.software-consult-box h2,
.software-sources h2 {
    margin-top: 0;
    color: #07172d;
    font-size: 2rem;
    line-height: 1.22;
}

.software-hero p,
.software-section p,
.software-license-panel p,
.software-consult-box p,
.software-sources p {
    color: #51627a;
    line-height: 1.82;
}

.software-hero figure {
    margin: 0;
}

.software-hero img,
.software-category-card img,
.software-product-card img {
    display: block;
    width: 100%;
    object-fit: contain;
}

.software-hero-points {
    display: grid;
    gap: 10px;
    margin-top: 24px;
}

.software-hero-points span {
    display: block;
    padding: 12px 14px;
    border: 1px solid #dbe8fb;
    border-radius: 8px;
    color: #34445c;
    background: rgba(255, 255, 255, .78);
}

.software-hero-points strong {
    display: inline-block;
    min-width: 96px;
    color: #0f53c7;
}

.software-section {
    display: grid;
    gap: 18px;
}

.software-category-grid,
.software-insight-grid,
.software-product-grid {
    display: grid;
    gap: 22px;
}

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

.software-insight-grid,
.software-product-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.software-category-card,
.software-product-card,
.software-insight-grid article {
    min-height: 100%;
    padding: 24px;
    border: 1px solid #dfe8f5;
    border-radius: 8px;
    background: #fff;
    box-shadow: 0 18px 42px rgba(16, 24, 40, .06);
}

.software-category-card,
.software-product-card {
    color: #172033;
    transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}

.software-category-card:hover,
.software-product-card:hover {
    border-color: #93c5fd;
    color: #0f53c7;
    transform: translateY(-3px);
    box-shadow: 0 24px 50px rgba(37, 99, 235, .12);
}

.software-category-card img {
    max-width: 220px;
    height: 150px;
    margin-bottom: 18px;
}

.software-product-card img {
    max-width: 150px;
    height: 112px;
    margin-bottom: 16px;
}

.software-category-card strong,
.software-product-card strong {
    display: block;
    margin-bottom: 8px;
    color: #07172d;
    font-size: 1.16rem;
}

.software-product-card span {
    display: inline-flex;
    margin-bottom: 10px;
    padding: 4px 9px;
    border: 1px solid #bfdbfe;
    border-radius: 999px;
    color: #2563eb;
    background: #eff6ff;
    font-size: .72rem;
    font-weight: 800;
    letter-spacing: .06em;
    text-transform: uppercase;
}

.software-product-card p,
.software-category-card span {
    color: #51627a;
}

.software-copy {
    max-width: 920px;
}

.software-license-panel {
    align-items: start;
    padding: 34px;
    border-radius: 8px;
    color: #fff;
    background:
        radial-gradient(circle at top right, rgba(37, 99, 235, .34), transparent 32%),
        linear-gradient(135deg, #07172d 0%, #123063 100%);
}

.software-license-panel h2,
.software-license-panel p,
.software-license-panel li {
    color: #fff;
}

.content-body .software-license-panel h2,
.content-body .software-license-panel p,
.content-body .software-license-panel li {
    color: #fff;
}

.content-body .software-license-panel h2 {
    border-bottom-color: rgba(255, 255, 255, .38);
}

.software-license-panel .software-kicker {
    border-color: rgba(147, 197, 253, .62);
    color: #dff7ff;
    background: linear-gradient(135deg, rgba(14, 116, 144, .38), rgba(37, 99, 235, .22));
    box-shadow: 0 18px 36px rgba(0, 0, 0, .18);
}

.software-license-panel ul,
.software-sources ul {
    margin: 0;
    padding: 0;
    list-style: none;
}

.software-license-panel li,
.software-sources li {
    position: relative;
    padding-left: 24px;
    line-height: 1.72;
}

.software-license-panel li + li,
.software-sources li + li {
    margin-top: 10px;
}

.software-license-panel li::before,
.software-sources li::before {
    content: "\2713";
    position: absolute;
    left: 0;
    color: #38bdf8;
    font-weight: 900;
}

.software-note {
    margin-top: 18px;
    padding: 14px 16px;
    border: 1px solid rgba(191, 219, 254, .22);
    border-radius: 8px;
    background: rgba(255, 255, 255, .08);
}

.software-consult-box {
    align-items: stretch;
    padding: 30px;
    border: 1px solid #bfdbfe;
    border-radius: 8px;
    background: #f8fbff;
    box-shadow: 0 24px 60px rgba(16, 24, 40, .08);
}

.software-contact-links {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 18px;
}

.software-contact-links a {
    display: inline-flex;
    align-items: center;
    min-height: 38px;
    padding: 8px 12px;
    border: 1px solid #bfdbfe;
    border-radius: 999px;
    color: #0f53c7;
    background: #fff;
    font-weight: 650;
}

.software-contact-iframe {
    width: 100%;
    min-height: 560px;
    border: 1px solid #dbe8fb;
    border-radius: 8px;
    background: #fff;
}

.software-sources {
    padding: 24px;
    border: 1px solid #dfe8f5;
    border-radius: 8px;
    background: #fff;
}

.software-sources a {
    color: #0f53c7;
    font-weight: 650;
}

.contact-embed-body {
    margin: 0;
    color: #172033;
    background: #f8fbff;
    font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

.contact-embed {
    padding: 18px;
}

.contact-embed-body-form-only {
    background: #fff;
}

.contact-embed-form-only {
    padding: 0;
}

.contact-embed-form-only .contact-embed-form {
    min-height: 100%;
    border: 0;
    border-radius: 0;
    box-shadow: none;
}

.contact-embed-heading span {
    display: inline-flex;
    margin-bottom: 8px;
    color: #0f53c7;
    font-size: .76rem;
    font-weight: 800;
    letter-spacing: .08em;
    text-transform: uppercase;
}

.contact-embed-heading h1 {
    margin: 0 0 8px;
    color: #07172d;
    font-size: 1.35rem;
    line-height: 1.25;
}

.contact-embed-heading p {
    margin-bottom: 16px;
    color: #51627a;
}

.contact-embed-grid {
    display: grid;
    gap: 16px;
}

.contact-embed-info {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.contact-embed-info a {
    padding: 7px 10px;
    border: 1px solid #bfdbfe;
    border-radius: 999px;
    color: #0f53c7;
    background: #fff;
    font-size: .9rem;
    font-weight: 650;
}

.contact-embed-form {
    padding: 16px;
    border: 1px solid #dbe8fb;
    border-radius: 8px;
    background: #fff;
}

@media (max-width: 991.98px) {
    .software-hero,
    .software-license-panel,
    .software-consult-box,
    .software-category-grid,
    .software-insight-grid,
    .software-product-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 767.98px) {
    .software-page {
        gap: 46px;
    }

    .software-kicker {
        width: 100%;
        min-height: 44px;
        padding: 9px 13px;
        border-radius: 14px;
        font-size: 1rem;
    }

    .software-hero,
    .software-license-panel,
    .software-consult-box,
    .software-category-card,
    .software-product-card,
    .software-insight-grid article,
    .software-sources {
        padding: 20px;
    }

    .software-hero h2,
    .software-section h2,
    .software-license-panel h2,
    .software-consult-box h2,
    .software-sources h2 {
        font-size: 1.55rem;
    }

    .software-hero-points strong {
        display: block;
        min-width: 0;
        margin-bottom: 2px;
    }

    .software-contact-iframe {
        min-height: 620px;
    }
}

body {
    color: var(--corporate-ink);
    background: #fff;
    font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    font-weight: 400;
    line-height: 1.65;
    text-rendering: optimizeLegibility;
    overflow-x: hidden;
}

a {
    text-decoration: none;
}

h1,
h2,
h3,
h4,
h5,
h6,
.fw-bold {
    font-weight: 650 !important;
}

p,
li,
.lead {
    line-height: 1.78;
}

.btn-primary {
    border: 1px solid rgba(15, 23, 38, .12);
    border-radius: 999px;
    background: linear-gradient(135deg, #15243d, #0d6efd);
    box-shadow: 0 16px 32px rgba(13, 110, 253, .20);
    font-weight: 650;
}

.btn-primary:hover,
.btn-primary:focus {
    border-color: rgba(15, 23, 38, .14);
    background: linear-gradient(135deg, #0f1726, #0b5ed7);
    box-shadow: 0 20px 40px rgba(13, 110, 253, .26);
}

.btn-outline-primary {
    border-color: rgba(200, 164, 93, .52);
    border-radius: 999px;
    color: var(--deep-navy);
    font-weight: 650;
}

.btn-outline-primary:hover,
.btn-outline-primary:focus {
    border-color: var(--lux-gold);
    color: var(--deep-navy);
    background: var(--gold-soft);
}

.site-header {
    z-index: 1040;
    box-shadow: 0 18px 44px rgba(16, 24, 40, .08);
}

.nav-topbar {
    color: #dce8f8;
    background: #111b2c;
    border-bottom: 1px solid rgba(255, 255, 255, .08);
    font-size: .84rem;
}

.nav-topbar .container {
    min-height: 38px;
}

.topbar-left,
.topbar-links,
.topbar-links a {
    display: inline-flex;
    align-items: center;
    gap: 10px;
}

.topbar-left i,
.topbar-links i {
    color: #75aaff;
}

.topbar-links {
    gap: 22px;
}

.topbar-links a {
    color: #dce8f8;
    transition: color .18s ease;
}

.topbar-links a:hover {
    color: #fff;
}

.premium-navbar {
    min-height: 76px;
    background: rgba(255, 255, 255, .92);
    border-bottom: 1px solid rgba(216, 230, 251, .86);
    backdrop-filter: blur(16px);
}

.premium-navbar .container {
    position: relative;
}

.premium-brand {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    min-width: 0;
    color: var(--corporate-ink);
}

.premium-brand:hover {
    color: var(--corporate-ink);
}

.brand-mark {
    width: 46px;
    height: 46px;
    display: inline-grid;
    place-items: center;
    flex: 0 0 auto;
    border-radius: 10px;
    color: #fff;
    background:
        linear-gradient(145deg, #0d6efd, #064fb7);
    box-shadow: 0 12px 24px rgba(13, 110, 253, .28), inset 0 1px 0 rgba(255, 255, 255, .35);
}

.brand-copy {
    display: grid;
    line-height: 1.1;
}

.brand-name {
    font-weight: 700;
    letter-spacing: 0;
    font-size: 1.06rem;
}

.brand-subtitle {
    margin-top: 4px;
    color: #617189;
    font-size: .72rem;
    font-weight: 500;
    letter-spacing: .08em;
    text-transform: uppercase;
}

.premium-nav-list {
    gap: 2px;
}

.premium-nav-link {
    position: relative;
    margin: 0 2px;
    padding: 10px 12px !important;
    border-radius: 8px;
    color: #34435b;
    font-size: .94rem;
    font-weight: 550;
    transition: color .18s ease, background-color .18s ease, transform .18s ease;
}

.premium-nav-link::after {
    content: "";
    position: absolute;
    left: 12px;
    right: 12px;
    bottom: 5px;
    height: 2px;
    border-radius: 999px;
    background: #0d6efd;
    transform: scaleX(0);
    transform-origin: center;
    transition: transform .18s ease;
}

.premium-nav-link:hover,
.premium-nav-link.active {
    color: #0d6efd !important;
    background: #eef5ff;
}

.premium-nav-link:hover::after,
.premium-nav-link.active::after {
    transform: scaleX(1);
}

.premium-dropdown {
    border: 1px solid #dce8f8;
    border-radius: 8px;
    padding: 8px;
    box-shadow: 0 24px 48px rgba(16, 24, 40, .14);
}

.premium-dropdown .dropdown-item {
    border-radius: 6px;
    padding: 9px 12px;
    font-weight: 500;
    color: #34435b;
}

.premium-dropdown .dropdown-item:hover {
    color: #0d6efd;
    background: #eef5ff;
}

.premium-dropdown .dropdown-item.active {
    color: #0d6efd;
    background: #eef5ff;
}

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

.nav-item.dropdown > .premium-dropdown {
    top: 100%;
    left: 0;
}

.dropdown-submenu {
    position: relative;
}

.dropdown-submenu > .dropdown-menu {
    top: 0;
    left: 100%;
    margin-left: 0;
}

.dropdown-submenu > .dropdown-toggle {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
}

.dropdown-submenu > .dropdown-toggle::after {
    margin-left: auto;
    transform: rotate(-90deg);
}

@media (min-width: 992px) {
    .nav-item.dropdown:hover > .dropdown-menu,
    .nav-item.dropdown:focus-within > .dropdown-menu,
    .dropdown-submenu:hover > .dropdown-menu,
    .dropdown-submenu:focus-within > .dropdown-menu {
        display: block;
    }

    .nav-item.dropdown:hover > .dropdown-toggle,
    .nav-item.dropdown:focus-within > .dropdown-toggle,
    .dropdown-submenu:hover > .dropdown-toggle,
    .dropdown-submenu:focus-within > .dropdown-toggle {
        color: #0d6efd !important;
        background: #eef5ff;
    }

    .premium-dropdown .dropdown-submenu > .premium-dropdown {
        min-width: 13rem;
    }
}

.nav-cta {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    min-height: 42px;
    padding: 9px 16px;
    border: 0;
    border-radius: 999px;
    color: #fff;
    font-weight: 650;
    background:
        linear-gradient(135deg, #0d6efd, #0849a5);
    box-shadow: 0 14px 28px rgba(13, 110, 253, .26);
}

.nav-cta:hover {
    color: #fff;
    transform: translateY(-1px);
    box-shadow: 0 18px 34px rgba(13, 110, 253, .32);
}

.premium-toggler {
    border: 1px solid #d8e6fb;
    border-radius: 8px;
    padding: 8px 10px;
}

.premium-toggler:focus {
    box-shadow: 0 0 0 .2rem rgba(13, 110, 253, .18);
}

.hero-section {
    padding: 104px 0 84px;
    background:
        linear-gradient(135deg, rgba(15, 23, 38, .06), rgba(255, 255, 255, .94) 48%, rgba(200, 164, 93, .10)),
        repeating-linear-gradient(90deg, rgba(15, 23, 38, .035) 0, rgba(15, 23, 38, .035) 1px, transparent 1px, transparent 80px),
        repeating-linear-gradient(0deg, rgba(15, 23, 38, .025) 0, rgba(15, 23, 38, .025) 1px, transparent 1px, transparent 80px),
        #fff;
}

.eyebrow {
    display: inline-flex;
    align-items: center;
    padding: .45rem .8rem;
    border: 1px solid rgba(13, 110, 253, .22);
    border-radius: 999px;
    color: #0d6efd;
    font-weight: 600;
    background: #fff;
}

.luxury-hero .display-4 {
    max-width: 760px;
    color: var(--deep-navy);
    line-height: 1.12;
    font-weight: 650 !important;
}

.hero-copy {
    max-width: 690px;
    color: #536179;
    line-height: 1.75;
    font-weight: 400;
}

.premium-eyebrow {
    border-color: rgba(200, 164, 93, .35);
    color: var(--deep-navy);
    background: rgba(255, 255, 255, .88);
    box-shadow: 0 12px 30px rgba(16, 24, 40, .06);
}

.premium-eyebrow i {
    color: var(--lux-gold);
}

.btn-lux-primary,
.btn-lux-secondary,
.btn-cta-light {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    font-weight: 650;
    min-height: 48px;
    padding-inline: 22px;
}

.btn-lux-primary {
    color: #fff;
    border: 1px solid rgba(15, 23, 38, .12);
    background:
        linear-gradient(135deg, #15243d, #0d6efd);
    box-shadow: 0 18px 36px rgba(13, 110, 253, .24), inset 0 1px 0 rgba(255, 255, 255, .22);
}

.btn-lux-primary:hover {
    color: #fff;
    transform: translateY(-1px);
    box-shadow: 0 24px 44px rgba(13, 110, 253, .30);
}

.btn-lux-secondary {
    color: var(--deep-navy);
    border: 1px solid rgba(200, 164, 93, .45);
    background: #fff;
    box-shadow: 0 14px 32px rgba(16, 24, 40, .08);
}

.btn-lux-secondary:hover {
    color: var(--deep-navy);
    border-color: var(--lux-gold);
    background: var(--gold-soft);
    transform: translateY(-1px);
}

.hero-proof {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 14px;
    max-width: 720px;
}

.hero-proof div {
    padding: 16px;
    border: 1px solid rgba(228, 234, 244, .95);
    border-radius: 8px;
    background: rgba(255, 255, 255, .74);
    box-shadow: 0 16px 38px rgba(16, 24, 40, .06);
}

.hero-proof strong,
.hero-proof span {
    display: block;
}

.hero-proof strong {
    color: var(--deep-navy);
    font-size: .96rem;
    font-weight: 600;
}

.hero-proof span {
    margin-top: 4px;
    color: var(--muted-ink);
    font-size: .86rem;
}

.security-visual {
    border-radius: 8px;
    background: #fff;
    overflow: hidden;
    border: 1px solid rgba(228, 234, 244, .95);
}

.visual-header {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 15px 18px;
    background:
        linear-gradient(135deg, var(--deep-navy), #1c2b45);
}

.visual-header span {
    display: inline-block;
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: #fff;
    opacity: .6;
    margin-right: 6px;
}

.visual-header strong {
    margin-left: auto;
    color: #e9edf6;
    font-size: .86rem;
}

.visual-body {
    padding: 24px;
}

.executive-panel {
    box-shadow: 0 30px 70px rgba(16, 24, 40, .16) !important;
}

.risk-score {
    display: flex;
    align-items: end;
    justify-content: space-between;
    gap: 16px;
    padding: 18px;
    margin-bottom: 14px;
    border: 1px solid rgba(200, 164, 93, .32);
    border-radius: 8px;
    background:
        linear-gradient(135deg, #fff, var(--gold-soft));
}

.risk-score span {
    color: var(--muted-ink);
    font-size: .86rem;
    font-weight: 500;
}

.risk-score strong {
    color: var(--emerald);
    font-size: 1.2rem;
    font-weight: 600;
}

.scan-line {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 14px;
    border: 1px solid var(--line-soft);
    border-radius: 8px;
    margin-bottom: 12px;
    background: #fbfcff;
    font-weight: 500;
}

.scan-line.success i { color: #198754; }
.scan-line.danger i { color: #dc3545; }
.scan-line.primary i { color: #0d6efd; }

.metric-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 12px;
    margin-top: 18px;
}

.metric-grid div {
    border-radius: 8px;
    border: 1px solid #e6edf7;
    background: #fff;
    padding: 14px;
    text-align: center;
}

.metric-grid strong {
    display: block;
    color: var(--deep-navy);
    font-size: 1.35rem;
    font-weight: 650;
}

.metric-grid small {
    color: #5d6b82;
}

.section-title {
    font-weight: 650;
    letter-spacing: 0;
    color: var(--deep-navy);
    line-height: 1.24;
}

.section-kicker {
    display: inline-block;
    margin-bottom: 10px;
    color: var(--lux-gold);
    font-size: .78rem;
    font-weight: 600;
    letter-spacing: .12em;
    text-transform: uppercase;
}

.section-lead {
    color: var(--muted-ink);
    font-size: 1.04rem;
    line-height: 1.85;
    font-weight: 400;
}

.section-soft {
    background:
        linear-gradient(180deg, #fff, var(--platinum));
}

.feature-card,
.solution-card,
.benefit-item,
.contact-panel,
.contact-form {
    border: 1px solid #e6edf7;
    border-radius: 8px;
    background: #fff;
    padding: 28px;
}

.premium-section {
    padding-top: 72px !important;
    padding-bottom: 72px !important;
}

.premium-feature,
.solution-card {
    position: relative;
    overflow: hidden;
}

.premium-feature::before,
.solution-card::before {
    content: "";
    position: absolute;
    inset: 0 0 auto 0;
    height: 3px;
    background: linear-gradient(90deg, var(--lux-gold), #0d6efd);
}

.feature-card i,
.solution-icon,
.benefit-item i {
    width: 44px;
    height: 44px;
    display: inline-grid;
    place-items: center;
    border-radius: 8px;
    border: 1px solid rgba(200, 164, 93, .22);
    background: linear-gradient(135deg, #fff, var(--gold-soft));
    color: var(--lux-gold);
    font-size: 1.25rem;
    margin-bottom: 16px;
}

.feature-card p,
.solution-card p,
.benefit-item p {
    color: #5d6b82;
    margin-bottom: 0;
}

.premium-feature h5,
.premium-feature h3,
.solution-card h5,
.benefit-item h5,
.benefit-item h3 {
    color: var(--deep-navy);
    font-size: 1.25rem;
    font-weight: 600;
    line-height: 1.35;
    margin-bottom: .5rem;
}

.solution-card {
    min-height: 100%;
    box-shadow: 0 18px 42px rgba(16, 24, 40, .06);
    transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}

.solution-card:hover {
    transform: translateY(-4px);
    border-color: rgba(200, 164, 93, .38);
    box-shadow: 0 26px 58px rgba(16, 24, 40, .12);
}

.solution-card a {
    display: inline-flex;
    align-items: center;
    margin-top: 18px;
    color: #0d6efd;
    font-weight: 600;
}

.featured-solutions-grid > [class*="col-"] {
    display: flex;
}

.solution-showcase-card {
    width: 100%;
    min-height: 100%;
    display: flex;
    flex-direction: column;
    overflow: hidden;
    border: 1px solid #dbe5f2;
    border-radius: 8px;
    background: #fff;
    box-shadow: 0 18px 44px rgba(16, 24, 40, .08);
    transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}

.solution-showcase-card:hover {
    transform: translateY(-4px);
    border-color: rgba(13, 110, 253, .30);
    box-shadow: 0 26px 58px rgba(16, 24, 40, .13);
}

.solution-card-top {
    min-height: 96px;
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 18px;
    padding: 24px;
    border-bottom: 1px solid #dbe5f2;
    background: linear-gradient(180deg, #f7faff 0%, #eef4fb 100%);
}

.solution-brand-icon {
    width: 54px;
    height: 54px;
    display: inline-grid;
    place-items: center;
    flex: 0 0 auto;
    border-radius: 8px;
    color: #fff;
    font-size: 1.42rem;
    box-shadow: 0 16px 26px rgba(16, 24, 40, .12), inset 0 1px 0 rgba(255, 255, 255, .30);
}

.solution-microsoft .solution-brand-icon {
    background: linear-gradient(135deg, #12a7e8, #0877c9);
}

.solution-proxmox .solution-brand-icon {
    background: linear-gradient(135deg, #f47d20, #df4f12);
}

.solution-barracuda .solution-brand-icon {
    background: linear-gradient(135deg, #d71920, #ad1118);
}

.solution-badge-stack {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 7px;
}

.solution-badge-stack span {
    display: inline-flex;
    align-items: center;
    min-height: 22px;
    padding: 3px 9px;
    border-radius: 6px;
    font-size: .68rem;
    font-weight: 650;
    line-height: 1;
    letter-spacing: .08em;
    text-transform: uppercase;
    white-space: nowrap;
}

.solution-microsoft .solution-badge-stack span:first-child {
    color: #2563eb;
    background: #dbeafe;
}

.solution-microsoft .solution-badge-stack span:last-child {
    color: #059669;
    background: #d8f3ea;
}

.solution-proxmox .solution-badge-stack span:first-child {
    color: #ea580c;
    background: #ffedd5;
}

.solution-proxmox .solution-badge-stack span:last-child {
    color: #7c3aed;
    background: #eee6ff;
}

.solution-barracuda .solution-badge-stack span:first-child {
    color: #dc2626;
    background: #fee2e2;
}

.solution-barracuda .solution-badge-stack span:last-child {
    color: #b45309;
    background: #fef3c7;
}

.solution-showcase-body {
    flex: 1 1 auto;
    padding: 24px;
}

.solution-showcase-body h3 {
    margin-bottom: 4px;
    color: #07172d;
    font-size: 1.04rem;
    font-weight: 650;
    line-height: 1.38;
}

.solution-vendor {
    margin-bottom: 12px;
    color: #8391a8;
    font-size: .80rem;
    font-weight: 400;
    letter-spacing: .05em;
}

.solution-description {
    margin-bottom: 18px;
    color: #40516a;
    font-size: .93rem;
    line-height: 1.72;
}

.solution-mini-title {
    display: flex;
    align-items: center;
    gap: 6px;
    margin: 18px 0 10px;
    color: #7b8ba3;
    font-size: .73rem;
    font-weight: 650;
    letter-spacing: .10em;
    line-height: 1.2;
    text-transform: uppercase;
}

.solution-mini-title i {
    color: #8fa0b8;
    font-size: .78rem;
}

.solution-feature-list {
    display: grid;
    gap: 8px;
    margin: 0;
    padding: 0;
    list-style: none;
}

.solution-feature-list li {
    position: relative;
    margin: 0;
    padding-left: 20px;
    color: #33445c;
    font-size: .89rem;
    line-height: 1.55;
}

.solution-feature-list li::before {
    content: "\2713";
    position: absolute;
    left: 0;
    top: .1rem;
    color: #00a76f;
    font-family: Arial, Helvetica, sans-serif;
    font-size: .76rem;
    font-weight: 900;
}

.solution-deploy-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}

.solution-deploy-tags span {
    display: inline-flex;
    align-items: center;
    min-height: 25px;
    padding: 4px 9px;
    border: 1px solid #bfdbfe;
    border-radius: 999px;
    color: #2563eb;
    background: #eff6ff;
    font-size: .76rem;
    font-weight: 500;
    line-height: 1;
}

.solution-fit-box {
    margin-top: 14px;
    padding: 12px 14px;
    border-left: 3px solid #2563eb;
    border-radius: 0 7px 7px 0;
    color: #33445c;
    background: #eef4fc;
    font-size: .87rem;
    line-height: 1.58;
}

.solution-fit-box strong {
    color: #07172d;
    font-weight: 650;
}

.solution-price-box {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    margin-top: 12px;
    padding: 12px 14px;
    border: 1px solid #b9ead8;
    border-radius: 7px;
    color: #00895f;
    background: #effaf5;
    font-size: .87rem;
    line-height: 1.55;
}

.solution-price-box i {
    margin-top: .18rem;
    font-size: .82rem;
}

.solution-price-box strong {
    font-weight: 650;
}

.solution-showcase-footer {
    padding: 16px 24px;
    border-top: 1px solid #dbe5f2;
    background: #fbfdff;
}

.solution-showcase-footer a {
    width: 100%;
    min-height: 48px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    border: 1px solid #2f6dff;
    border-radius: 8px;
    color: #2f6dff;
    font-weight: 650;
    transition: color .18s ease, background .18s ease, transform .18s ease, box-shadow .18s ease;
}

.solution-showcase-footer a:hover,
.solution-showcase-footer a:focus {
    color: #fff;
    background: #2f6dff;
    box-shadow: 0 16px 28px rgba(47, 109, 255, .20);
    transform: translateY(-1px);
}

.comparison-section {
    padding-top: 78px !important;
    padding-bottom: 78px !important;
    background: linear-gradient(180deg, #eef5ff 0%, #e8f0fb 100%);
}

.comparison-heading {
    max-width: 720px;
    margin: 0 auto 48px;
}

.comparison-heading .section-title {
    margin: 14px 0 12px;
    color: #07172d;
    font-size: 2.55rem;
    line-height: 1.14;
}

.comparison-heading .section-lead {
    max-width: 620px;
    color: #263a57;
    font-size: 1rem;
    line-height: 1.8;
}

.comparison-kicker {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    min-height: 28px;
    padding: 5px 13px;
    border: 1px solid #bcd4ff;
    border-radius: 999px;
    color: #3474ff;
    background: #eaf2ff;
    font-size: .76rem;
    font-weight: 650;
    letter-spacing: 0;
    line-height: 1;
    text-transform: uppercase;
}

.comparison-kicker i {
    font-size: .72rem;
}

.comparison-table {
    border: 1px solid var(--line-soft);
    border-radius: 8px;
    overflow: hidden;
    background: #fff;
    box-shadow: 0 22px 52px rgba(16, 24, 40, .10);
}

.comparison-detail-table {
    min-width: 980px;
    margin-bottom: 0;
    color: #263a57;
    font-size: .92rem;
}

.comparison-detail-table th,
.comparison-detail-table td {
    width: 25%;
}

.comparison-table .table thead th {
    padding: 18px 20px;
    border: 0;
    color: #fff;
    background: #123063;
    font-size: .80rem;
    font-weight: 650;
    letter-spacing: 0;
    text-transform: uppercase;
    white-space: nowrap;
}

.comparison-table .table thead th:first-child {
    text-align: left;
    background: #173d7f;
}

.comparison-table .table thead th:nth-child(2) {
    color: #68f0ff;
    background: #194993;
}

.comparison-table .table thead th:nth-child(3) {
    color: #ffb06a;
    background: #1a4a96;
}

.comparison-table .table thead th:nth-child(4) {
    color: #ff8ea0;
    background: #14346d;
}

.comparison-table .table thead i {
    margin-right: 6px;
    font-size: .78rem;
}

.comparison-table .table tbody td {
    padding: 15px 20px;
    border-color: #dce5f2;
    color: #263a57;
    background: #fff;
    font-weight: 400;
    line-height: 1.55;
    text-align: center;
    vertical-align: middle;
}

.comparison-table .table tbody tr td:first-child {
    color: #06172d;
    font-weight: 650;
    text-align: left;
    background: #fff;
}

.comparison-table .table tbody tr:hover td {
    background: #f8fbff;
}

.rating-stars {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 3px;
    color: #ccd8e8;
    font-size: 1rem;
    line-height: 1;
    white-space: nowrap;
}

.rating-stars i {
    color: #ccd8e8;
}

.rating-stars .is-filled,
.rating-stars .is-half {
    color: #f59e0b;
    filter: drop-shadow(0 5px 8px rgba(245, 158, 11, .18));
}

.comparison-status {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    white-space: nowrap;
}

.comparison-status i {
    font-size: .82rem;
}

.comparison-status.status-good i {
    color: #16b978;
}

.comparison-status.status-limited i {
    color: #f59e0b;
}

.comparison-status.status-no i {
    color: #ef4444;
}

.comparison-status.icon-only i {
    margin: 0;
}

.assurance-band {
    padding: 78px 0;
    color: #fff;
    background:
        linear-gradient(135deg, var(--deep-navy), #18243a 58%, #24334f);
}

.assurance-band .section-title {
    color: #fff;
}

.assurance-band .section-lead {
    color: #cfd8e8;
}

.assurance-card {
    height: 100%;
    border-color: rgba(255, 255, 255, .12);
    background: rgba(255, 255, 255, .06);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, .10);
}

.assurance-card h5,
.assurance-card h3 {
    color: #fff;
}

.assurance-card p {
    color: #cfd8e8;
}

.assurance-card i {
    color: #f1d492;
    border-color: rgba(241, 212, 146, .28);
    background: rgba(255, 255, 255, .08);
}

.post-strip {
    display: grid;
    gap: 4px;
    border: 1px solid var(--line-soft);
    border-radius: 8px;
    padding: 18px 20px;
    color: var(--corporate-ink);
    background: #fff;
    box-shadow: 0 14px 34px rgba(16, 24, 40, .05);
    transition: transform .18s ease, border-color .18s ease, box-shadow .18s ease;
}

.post-strip span {
    color: var(--lux-gold);
    font-size: .875rem;
    font-weight: 600;
}

.post-strip:hover {
    color: var(--deep-navy);
    border-color: rgba(200, 164, 93, .36);
    transform: translateY(-2px);
    box-shadow: 0 22px 48px rgba(16, 24, 40, .10);
}

.premium-accordion .accordion-item {
    border: 1px solid var(--line-soft);
    border-radius: 8px;
    overflow: hidden;
    margin-bottom: 12px;
    box-shadow: 0 12px 30px rgba(16, 24, 40, .04);
}

.premium-accordion .accordion-button {
    color: var(--deep-navy);
    font-weight: 600;
    background: #fff;
    line-height: 1.45;
}

.premium-accordion .accordion-button:not(.collapsed) {
    color: var(--deep-navy);
    background: var(--gold-soft);
    box-shadow: none;
}

.premium-accordion .accordion-body {
    color: var(--muted-ink);
    line-height: 1.75;
}

.post-card .card-img-top {
    aspect-ratio: 16 / 9;
    object-fit: cover;
}

.post-card {
    border: 1px solid var(--line-soft) !important;
    border-radius: 8px;
    overflow: hidden;
    box-shadow: 0 18px 44px rgba(16, 24, 40, .07) !important;
    transition: transform .18s ease, box-shadow .18s ease;
}

.post-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 26px 58px rgba(16, 24, 40, .12) !important;
}

.post-card h5 a,
.post-card-title a {
    color: var(--deep-navy);
    font-weight: 600;
    text-decoration: none;
}

.post-card h5 a:hover,
.post-card-title a:hover {
    color: #0d6efd;
}

.post-card-title {
    margin-top: 10px;
    margin-bottom: 12px;
    font-size: 1.15rem;
    line-height: 1.35;
}

.post-card-meta {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px 10px;
    color: #64748b;
    font-size: .9rem;
    font-weight: 600;
}

.post-card-image-link {
    display: block;
}

.blog-index {
    background: #fff;
}

.blog-category-section {
    padding: 34px 0;
    border-bottom: 1px solid var(--line-soft);
}

.blog-category-section:first-child {
    padding-top: 0;
}

.blog-category-section:last-child {
    border-bottom: 0;
    padding-bottom: 0;
}

.blog-section-head {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 18px;
    margin-bottom: 24px;
}

.blog-section-kicker {
    display: inline-flex;
    align-items: center;
    margin-bottom: 8px;
    padding: 6px 13px;
    border: 1px solid #bfdbfe;
    border-radius: 999px;
    color: #0f53c7;
    background: #eff6ff;
    font-size: .78rem;
    font-weight: 800;
    letter-spacing: .08em;
    text-transform: uppercase;
}

.blog-category-title {
    margin-bottom: 0;
    color: var(--deep-navy);
    font-weight: 750;
    line-height: 1.18;
}

.blog-category-title a {
    color: inherit;
    text-decoration: none;
}

.blog-category-title a:hover {
    color: #0d6efd;
}

.blog-category-description {
    max-width: 760px;
    margin: 10px 0 0;
    color: #64748b;
}

.blog-category-more {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    flex: 0 0 auto;
    padding: 10px 16px;
    border: 1px solid #bfdbfe;
    border-radius: 999px;
    color: #0f53c7;
    background: #fff;
    font-weight: 750;
    text-decoration: none;
}

.blog-category-more:hover {
    border-color: #0d6efd;
    color: #0d6efd;
    background: #eff6ff;
}

.post-category-badge {
    display: inline-flex;
    align-items: center;
    width: fit-content;
    padding: 5px 11px;
    border: 1px solid #bfdbfe;
    border-radius: 999px;
    color: #0f53c7;
    background: #eff6ff;
    font-size: .82rem;
    font-weight: 750;
    text-decoration: none;
}

.post-category-badge:hover {
    color: #0d6efd;
    background: #dbeafe;
}

.page-hero {
    padding-top: 68px !important;
    padding-bottom: 68px !important;
    background:
        linear-gradient(135deg, rgba(15, 23, 38, .05), rgba(255, 255, 255, .96)),
        repeating-linear-gradient(90deg, rgba(15, 23, 38, .035) 0, rgba(15, 23, 38, .035) 1px, transparent 1px, transparent 92px),
        #fff;
    border-bottom: 1px solid var(--line-soft);
}

.page-hero .breadcrumb {
    font-weight: 500;
}

.page-hero .breadcrumb a {
    color: var(--lux-gold);
}

.page-hero .display-5 {
    color: var(--deep-navy);
    line-height: 1.18;
    font-weight: 650 !important;
}

.content-body {
    max-width: 920px;
    font-size: 1.06rem;
    line-height: 1.9;
    color: #3f4d63;
}

.content-body h2,
.content-body h3 {
    margin-top: 2rem;
    font-weight: 650;
    color: var(--deep-navy);
}

.content-body h2 {
    padding-bottom: 10px;
    border-bottom: 1px solid var(--line-soft);
}

.content-body ul,
.content-body ol {
    padding-left: 1.2rem;
}

.content-body li {
    margin-bottom: 8px;
}

.content-body img {
    max-width: 100%;
    height: auto;
    border-radius: 8px;
}

.content-body-wide {
    max-width: 1120px;
}

.m365-page {
    display: grid;
    gap: 72px;
}

.m365-kicker {
    display: inline-flex;
    align-items: center;
    max-width: 100%;
    min-height: 46px;
    margin-bottom: 16px;
    padding: 10px 18px;
    border: 2px solid #93c5fd;
    border-radius: 16px;
    color: #0b4fd9;
    background: linear-gradient(135deg, #fff 0%, #eff6ff 100%);
    box-shadow: 0 14px 30px rgba(37, 99, 235, .12);
    font-size: clamp(1rem, 1.8vw, 1.45rem);
    font-weight: 850;
    letter-spacing: .02em;
    line-height: 1.2;
    text-transform: uppercase;
}

.m365-page h2 {
    margin-top: 0;
    padding-bottom: 0;
    border-bottom: 0;
    color: #07172d;
    font-size: 2rem;
    line-height: 1.22;
}

.m365-page h3 {
    margin-top: 0;
    color: #07172d;
}

.m365-hero-panel,
.m365-blueprint,
.m365-outcomes,
.m365-cta-strip {
    display: grid;
    grid-template-columns: minmax(0, 1.08fr) minmax(320px, .92fr);
    align-items: center;
    gap: 36px;
}

.m365-hero-panel {
    padding: 34px;
    border: 1px solid #dbe8fb;
    border-radius: 8px;
    background:
        linear-gradient(135deg, #f8fbff 0%, #eef6ff 54%, #f7fbff 100%);
    box-shadow: 0 24px 60px rgba(16, 24, 40, .08);
}

.m365-hero-copy > p,
.m365-section-lead,
.m365-blueprint p,
.m365-cta-strip p {
    color: #51627a;
    line-height: 1.82;
}

.m365-hero-points {
    display: grid;
    gap: 10px;
    margin-top: 24px;
}

.m365-hero-points span {
    display: flex;
    gap: 10px;
    align-items: flex-start;
    padding: 12px 14px;
    border: 1px solid #dbe8fb;
    border-radius: 8px;
    color: #34445c;
    background: rgba(255, 255, 255, .74);
}

.m365-hero-points strong {
    min-width: 82px;
    color: #0f53c7;
}

.m365-hero-figure,
.m365-outcomes figure {
    margin: 0;
}

.m365-hero-figure img,
.m365-outcomes img,
.m365-service-card img {
    display: block;
    width: 100%;
    object-fit: contain;
}

.m365-hero-figure figcaption {
    margin-top: 12px;
    color: #657188;
    font-size: .88rem;
    line-height: 1.6;
    text-align: center;
}

.m365-section {
    display: grid;
    gap: 18px;
}

.m365-section-lead {
    max-width: 820px;
    margin-bottom: 8px;
}

.m365-service-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 22px;
}

.m365-service-card {
    min-height: 100%;
    padding: 24px;
    border: 1px solid #dfe8f5;
    border-radius: 8px;
    background: #fff;
    box-shadow: 0 18px 42px rgba(16, 24, 40, .06);
}

.m365-service-card img {
    max-width: 150px;
    height: 112px;
    margin-bottom: 18px;
}

.m365-service-card h3 {
    margin-bottom: 10px;
    font-size: 1.18rem;
}

.m365-service-card p {
    margin-bottom: 14px;
    color: #51627a;
    font-size: .98rem;
    line-height: 1.78;
}

.m365-service-card ul,
.m365-outcomes ul {
    margin: 0;
    padding: 0;
    list-style: none;
}

.m365-service-card li,
.m365-outcomes li {
    position: relative;
    padding-left: 24px;
    color: #33445c;
    font-size: .94rem;
    line-height: 1.65;
}

.m365-service-card li + li,
.m365-outcomes li + li {
    margin-top: 8px;
}

.m365-service-card li::before,
.m365-outcomes li::before {
    content: "\2713";
    position: absolute;
    left: 0;
    top: .05rem;
    color: #00a76f;
    font-weight: 900;
}

.m365-blueprint {
    padding: 34px;
    border-radius: 8px;
    color: #fff;
    background:
        radial-gradient(circle at top right, rgba(37, 99, 235, .34), transparent 32%),
        linear-gradient(135deg, #07172d 0%, #123063 100%);
}

.m365-blueprint h2,
.m365-blueprint p {
    color: #fff;
}

.m365-blueprint .m365-kicker {
    border-color: rgba(147, 197, 253, .62);
    color: #dff7ff;
    background:
        linear-gradient(135deg, rgba(14, 116, 144, .38), rgba(37, 99, 235, .22));
    box-shadow: 0 18px 36px rgba(0, 0, 0, .18);
}

.m365-blueprint-list {
    display: grid;
    gap: 12px;
}

.m365-blueprint-list div {
    padding: 16px;
    border: 1px solid rgba(191, 219, 254, .18);
    border-radius: 8px;
    background: rgba(255, 255, 255, .08);
}

.m365-blueprint-list strong,
.m365-blueprint-list span {
    display: block;
}

.m365-blueprint-list strong {
    color: #7dd3fc;
}

.m365-blueprint-list span {
    margin-top: 4px;
    color: #d7e6fa;
    font-size: .92rem;
}

.m365-process {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 16px;
}

.m365-process div {
    padding: 22px;
    border: 1px solid #dfe8f5;
    border-radius: 8px;
    background: #fff;
}

.m365-process strong {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 42px;
    height: 42px;
    margin-bottom: 14px;
    border-radius: 50%;
    color: #fff;
    background: #2563eb;
    font-size: .92rem;
}

.m365-process h3 {
    margin-bottom: 8px;
    font-size: 1.05rem;
}

.m365-process p {
    margin: 0;
    color: #51627a;
    font-size: .93rem;
    line-height: 1.72;
}

.m365-outcomes {
    padding: 30px 34px;
    border: 1px solid #dfe8f5;
    border-radius: 8px;
    background: #f8fbff;
}

.m365-outcomes img {
    max-height: 300px;
}

.m365-cta-strip {
    grid-template-columns: minmax(0, 1fr) auto;
    padding: 28px 32px;
    border-radius: 8px;
    background: linear-gradient(135deg, #eef6ff, #fff);
    border: 1px solid #dbe8fb;
}

.m365-cta-strip h2 {
    margin-bottom: 8px;
    font-size: 1.55rem;
}

.m365-cta-strip p {
    margin-bottom: 0;
}

.gateway-page {
    display: grid;
    gap: 72px;
}

.gateway-kicker {
    display: inline-flex;
    align-items: center;
    max-width: 100%;
    min-height: 46px;
    margin-bottom: 16px;
    padding: 10px 18px;
    border: 2px solid #93c5fd;
    border-radius: 16px;
    color: #0b4fd9;
    background: linear-gradient(135deg, #fff 0%, #eff6ff 100%);
    box-shadow: 0 14px 30px rgba(37, 99, 235, .12);
    font-size: clamp(1rem, 1.8vw, 1.45rem);
    font-weight: 850;
    letter-spacing: .02em;
    line-height: 1.2;
    text-transform: uppercase;
}

.gateway-page h2 {
    margin-top: 0;
    padding-bottom: 0;
    border-bottom: 0;
    color: #07172d;
    font-size: 2rem;
    line-height: 1.22;
}

.gateway-page h3 {
    margin-top: 0;
    color: #07172d;
}

.gateway-hero-panel,
.gateway-blueprint,
.gateway-outcomes,
.gateway-cta-strip {
    display: grid;
    grid-template-columns: minmax(0, 1.08fr) minmax(320px, .92fr);
    align-items: center;
    gap: 36px;
}

.gateway-hero-panel {
    padding: 34px;
    border: 1px solid #dbe8fb;
    border-radius: 8px;
    background: linear-gradient(135deg, #f8fbff 0%, #eef6ff 54%, #f7fbff 100%);
    box-shadow: 0 24px 60px rgba(16, 24, 40, .08);
}

.gateway-barracuda .gateway-hero-panel {
    background: linear-gradient(135deg, #fff7f7 0%, #f8fbff 55%, #fff 100%);
}

.gateway-eop .gateway-hero-panel {
    background: linear-gradient(135deg, #eef6ff 0%, #f8fbff 56%, #fff 100%);
}

.gateway-hero-copy > p,
.gateway-section-lead,
.gateway-blueprint p,
.gateway-cta-strip p {
    color: #51627a;
    line-height: 1.82;
}

.gateway-hero-points {
    display: grid;
    gap: 10px;
    margin-top: 24px;
}

.gateway-hero-points span {
    display: flex;
    gap: 10px;
    align-items: flex-start;
    padding: 12px 14px;
    border: 1px solid #dbe8fb;
    border-radius: 8px;
    color: #34445c;
    background: rgba(255, 255, 255, .74);
}

.gateway-hero-points strong {
    min-width: 122px;
    color: #0f53c7;
}

.gateway-barracuda .gateway-hero-points strong {
    color: #b91c1c;
}

.gateway-eop .gateway-hero-points strong {
    color: #2563eb;
}

.gateway-hero-figure,
.gateway-outcomes figure {
    margin: 0;
}

.gateway-hero-figure img,
.gateway-outcomes img,
.gateway-feature-card img {
    display: block;
    width: 100%;
    object-fit: contain;
}

.gateway-hero-figure figcaption {
    margin-top: 12px;
    color: #657188;
    font-size: .88rem;
    line-height: 1.6;
    text-align: center;
}

.gateway-section {
    display: grid;
    gap: 18px;
}

.gateway-section-lead {
    max-width: 840px;
    margin-bottom: 8px;
}

.gateway-feature-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 22px;
}

.gateway-feature-card {
    min-height: 100%;
    padding: 24px;
    border: 1px solid #dfe8f5;
    border-radius: 8px;
    background: #fff;
    box-shadow: 0 18px 42px rgba(16, 24, 40, .06);
}

.gateway-feature-card img {
    max-width: 150px;
    height: 112px;
    margin-bottom: 18px;
}

.gateway-feature-card h3 {
    margin-bottom: 10px;
    font-size: 1.18rem;
}

.gateway-feature-card p {
    margin-bottom: 14px;
    color: #51627a;
    font-size: .98rem;
    line-height: 1.78;
}

.gateway-feature-card ul,
.gateway-outcomes ul {
    margin: 0;
    padding: 0;
    list-style: none;
}

.gateway-feature-card li,
.gateway-outcomes li {
    position: relative;
    padding-left: 24px;
    color: #33445c;
    font-size: .94rem;
    line-height: 1.65;
}

.gateway-feature-card li + li,
.gateway-outcomes li + li {
    margin-top: 8px;
}

.gateway-feature-card li::before,
.gateway-outcomes li::before {
    content: "\2713";
    position: absolute;
    left: 0;
    top: .05rem;
    color: #00a76f;
    font-weight: 900;
}

.gateway-blueprint {
    padding: 34px;
    border-radius: 8px;
    color: #fff;
    background:
        radial-gradient(circle at top right, rgba(37, 99, 235, .34), transparent 32%),
        linear-gradient(135deg, #07172d 0%, #123063 100%);
}

.gateway-barracuda .gateway-blueprint {
    background:
        radial-gradient(circle at top right, rgba(248, 113, 113, .28), transparent 32%),
        linear-gradient(135deg, #1f2937 0%, #7f1d1d 100%);
}

.gateway-eop .gateway-blueprint {
    background:
        radial-gradient(circle at top right, rgba(96, 165, 250, .30), transparent 32%),
        linear-gradient(135deg, #061936 0%, #164e9d 100%);
}

.gateway-blueprint h2,
.gateway-blueprint p {
    color: #fff;
}

.gateway-blueprint .gateway-kicker {
    border-color: rgba(147, 197, 253, .62);
    color: #dff7ff;
    background: linear-gradient(135deg, rgba(14, 116, 144, .38), rgba(37, 99, 235, .22));
    box-shadow: 0 18px 36px rgba(0, 0, 0, .18);
}

.gateway-barracuda .gateway-blueprint .gateway-kicker {
    border-color: rgba(147, 197, 253, .62);
    color: #dff7ff;
    background: linear-gradient(135deg, rgba(14, 116, 144, .38), rgba(37, 99, 235, .22));
}

.gateway-blueprint-list {
    display: grid;
    gap: 12px;
}

.gateway-blueprint-list div {
    padding: 16px;
    border: 1px solid rgba(191, 219, 254, .18);
    border-radius: 8px;
    background: rgba(255, 255, 255, .08);
}

.gateway-blueprint-list strong,
.gateway-blueprint-list span {
    display: block;
}

.gateway-blueprint-list strong {
    color: #7dd3fc;
}

.gateway-barracuda .gateway-blueprint-list strong {
    color: #fecaca;
}

.gateway-blueprint-list span {
    margin-top: 4px;
    color: #d7e6fa;
    font-size: .92rem;
}

.gateway-process {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 16px;
}

.gateway-process div {
    padding: 22px;
    border: 1px solid #dfe8f5;
    border-radius: 8px;
    background: #fff;
}

.gateway-process strong {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 42px;
    height: 42px;
    margin-bottom: 14px;
    border-radius: 50%;
    color: #fff;
    background: #2563eb;
    font-size: .92rem;
}

.gateway-barracuda .gateway-process strong {
    background: #dc2626;
}

.gateway-eop .gateway-process strong {
    background: #2563eb;
}

.gateway-compare-mini {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 22px;
}

.gateway-compare-mini > div {
    padding: 24px;
    border: 1px solid #dfe8f5;
    border-radius: 8px;
    background: #fff;
    box-shadow: 0 18px 44px rgba(15, 23, 42, .07);
}

.gateway-compare-mini h3 {
    margin-bottom: 14px;
    font-size: 1.08rem;
}

.gateway-compare-mini ul {
    margin: 0;
    padding: 0;
    list-style: none;
}

.gateway-compare-mini li {
    position: relative;
    padding-left: 22px;
    color: #51627a;
    line-height: 1.7;
}

.gateway-compare-mini li + li {
    margin-top: 10px;
}

.gateway-compare-mini li::before {
    content: "";
    position: absolute;
    top: .78em;
    left: 0;
    width: 8px;
    height: 8px;
    border-radius: 999px;
    background: #2563eb;
    box-shadow: 0 0 0 4px rgba(37, 99, 235, .10);
}

.gateway-process h3 {
    margin-bottom: 8px;
    font-size: 1.05rem;
}

.gateway-process p {
    margin: 0;
    color: #51627a;
    font-size: .93rem;
    line-height: 1.72;
}

.gateway-outcomes {
    padding: 30px 34px;
    border: 1px solid #dfe8f5;
    border-radius: 8px;
    background: #f8fbff;
}

.gateway-barracuda .gateway-outcomes {
    background: #fff7f7;
}

.gateway-outcomes img {
    max-height: 300px;
}

.gateway-cta-strip {
    grid-template-columns: minmax(0, 1fr) auto;
    padding: 28px 32px;
    border-radius: 8px;
    background: linear-gradient(135deg, #eef6ff, #fff);
    border: 1px solid #dbe8fb;
}

.gateway-barracuda .gateway-cta-strip {
    background: linear-gradient(135deg, #fff7f7, #fff);
    border-color: #fee2e2;
}

.gateway-eop .gateway-cta-strip {
    background: linear-gradient(135deg, #eff6ff, #fff);
    border-color: #dbeafe;
}

.gateway-cta-strip h2 {
    margin-bottom: 8px;
    font-size: 1.55rem;
}

.gateway-cta-strip p {
    margin-bottom: 0;
}

.about-page {
    display: grid;
    gap: 72px;
}

.about-page h2 {
    margin-top: 0;
    padding-bottom: 0;
    border-bottom: 0;
    color: #07172d;
    font-size: clamp(2rem, 3.4vw, 3.35rem);
    line-height: 1.08;
}

.about-page h3 {
    margin-top: 0;
    color: #07172d;
}

.about-kicker {
    display: inline-flex;
    align-items: center;
    width: fit-content;
    margin-bottom: 14px;
    padding: 7px 12px;
    border: 1px solid #a7f3d0;
    border-radius: 999px;
    color: #047857;
    background: #ecfdf5;
    font-size: .76rem;
    font-weight: 800;
    letter-spacing: .08em;
    text-transform: uppercase;
}

.about-hero-panel,
.about-blueprint,
.about-compliance,
.about-outcomes,
.about-cta-strip {
    display: grid;
    grid-template-columns: minmax(0, 1.08fr) minmax(320px, .92fr);
    align-items: center;
    gap: 36px;
}

.about-hero-panel {
    padding: 34px;
    border: 1px solid #dbe8fb;
    border-radius: 8px;
    background: linear-gradient(135deg, #f8fbff 0%, #ecfdf5 52%, #fff 100%);
    box-shadow: 0 24px 60px rgba(16, 24, 40, .08);
}

.about-hero-copy > p,
.about-section-lead,
.about-blueprint p,
.about-compliance p,
.about-cta-strip p {
    color: #51627a;
    line-height: 1.82;
}

.about-hero-points {
    display: grid;
    gap: 10px;
    margin-top: 24px;
}

.about-hero-points span {
    display: flex;
    gap: 10px;
    align-items: flex-start;
    padding: 12px 14px;
    border: 1px solid #dbe8fb;
    border-radius: 8px;
    color: #34445c;
    background: rgba(255, 255, 255, .78);
}

.about-hero-points strong {
    min-width: 136px;
    color: #047857;
}

.about-hero-figure,
.about-compliance figure {
    margin: 0;
}

.about-hero-figure img,
.about-compliance img,
.about-focus-card img {
    display: block;
    width: 100%;
    object-fit: contain;
}

.about-hero-figure figcaption {
    margin-top: 12px;
    color: #657188;
    font-size: .88rem;
    line-height: 1.6;
    text-align: center;
}

.software-hero > div,
.m365-hero-copy,
.gateway-hero-copy,
.about-hero-copy,
.backup-hero-copy {
    display: contents;
}

.software-hero > div > .software-kicker,
.software-hero > div > h2,
.m365-hero-copy > .m365-kicker,
.m365-hero-copy > h2,
.gateway-hero-copy > .gateway-kicker,
.gateway-hero-copy > h2,
.about-hero-copy > .about-kicker,
.about-hero-copy > h2,
.backup-hero-copy > .backup-kicker,
.backup-hero-copy > h2 {
    grid-column: 1 / -1;
}

.software-hero > div > p,
.software-hero-points,
.m365-hero-copy > p,
.m365-hero-points,
.gateway-hero-copy > p,
.gateway-hero-points,
.about-hero-copy > p,
.about-hero-points,
.backup-hero-copy > p,
.backup-hero-points {
    grid-column: 1;
}

.software-hero > figure,
.m365-hero-figure,
.gateway-hero-figure,
.about-hero-figure,
.backup-hero-figure {
    grid-column: 2;
    grid-row: 3 / span 2;
    align-self: center;
}

.about-section {
    display: grid;
    gap: 12px;
}

.about-section > h2 {
    margin-bottom: 0;
}

.about-section-lead {
    width: 100%;
    max-width: none;
    margin: 0 0 10px;
}

.about-focus-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 22px;
}

.about-focus-card {
    min-height: 100%;
    padding: 24px;
    border: 1px solid #dfe8f5;
    border-radius: 8px;
    background: #fff;
    box-shadow: 0 18px 42px rgba(16, 24, 40, .06);
}

.about-focus-card img {
    max-width: 150px;
    height: 112px;
    margin-bottom: 18px;
}

.about-focus-card h3 {
    margin-bottom: 10px;
    font-size: 1.18rem;
}

.about-focus-card p {
    margin-bottom: 14px;
    color: #51627a;
    font-size: .98rem;
    line-height: 1.78;
}

.about-focus-card ul,
.about-compliance ul,
.about-outcomes ul {
    margin: 0;
    padding: 0;
    list-style: none;
}

.about-focus-card li,
.about-compliance li,
.about-outcomes li {
    position: relative;
    padding-left: 24px;
    color: #33445c;
    font-size: .94rem;
    line-height: 1.65;
}

.about-focus-card li + li,
.about-compliance li + li,
.about-outcomes li + li {
    margin-top: 8px;
}

.about-focus-card li::before,
.about-compliance li::before,
.about-outcomes li::before {
    content: "\2713";
    position: absolute;
    left: 0;
    top: .05rem;
    color: #00a76f;
    font-weight: 900;
}

.about-blueprint {
    padding: 34px;
    border-radius: 8px;
    color: #fff;
    background:
        radial-gradient(circle at top right, rgba(16, 185, 129, .28), transparent 34%),
        linear-gradient(135deg, #07172d 0%, #064e3b 100%);
}

.about-blueprint h2,
.about-blueprint p {
    color: #fff;
}

.about-blueprint .about-kicker {
    border-color: rgba(167, 243, 208, .34);
    color: #a7f3d0;
    background: rgba(6, 78, 59, .38);
}

.about-blueprint-list {
    display: grid;
    gap: 12px;
}

.about-blueprint-list div {
    padding: 16px;
    border: 1px solid rgba(209, 250, 229, .18);
    border-radius: 8px;
    background: rgba(255, 255, 255, .08);
}

.about-blueprint-list strong,
.about-blueprint-list span {
    display: block;
}

.about-blueprint-list strong {
    color: #a7f3d0;
}

.about-blueprint-list span {
    margin-top: 4px;
    color: #d7f7e8;
    font-size: .92rem;
}

.about-process {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 16px;
}

.about-process div {
    padding: 22px;
    border: 1px solid #dfe8f5;
    border-radius: 8px;
    background: #fff;
}

.about-process strong {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 42px;
    height: 42px;
    margin-bottom: 14px;
    border-radius: 50%;
    color: #fff;
    background: #047857;
    font-size: .92rem;
}

.about-process h3 {
    margin-bottom: 8px;
    font-size: 1.05rem;
}

.about-process p {
    margin: 0;
    color: #51627a;
    font-size: .93rem;
    line-height: 1.72;
}

.about-compliance {
    padding: 30px 34px;
    border: 1px solid #d1fae5;
    border-radius: 8px;
    background: #f0fdf4;
}

.about-compliance img {
    max-height: 300px;
}

.about-outcomes {
    padding: 30px 34px;
    border: 1px solid #dfe8f5;
    border-radius: 8px;
    background: #f8fbff;
}

.about-outcome-metrics {
    display: grid;
    gap: 14px;
}

.about-outcome-metrics span {
    display: block;
    padding: 16px;
    border: 1px solid #dbe8fb;
    border-radius: 8px;
    color: #51627a;
    background: #fff;
}

.about-outcome-metrics strong {
    display: block;
    margin-bottom: 2px;
    color: #047857;
    font-size: 1.9rem;
    line-height: 1;
}

.about-cta-strip {
    grid-template-columns: minmax(0, 1fr) auto;
    padding: 28px 32px;
    border-radius: 8px;
    background: linear-gradient(135deg, #ecfdf5, #fff);
    border: 1px solid #d1fae5;
}

.about-cta-strip h2 {
    margin-bottom: 8px;
    font-size: 1.55rem;
}

.about-cta-strip p {
    margin-bottom: 0;
}

.contact-cta {
    background: var(--deep-navy);
    color: #fff;
}

.luxury-cta {
    position: relative;
    overflow: hidden;
    background:
        linear-gradient(135deg, var(--deep-navy), #1d2b46);
}

.luxury-cta h2 {
    color: #fff;
}

.luxury-cta p {
    color: #d9e2f1;
}

.btn-cta-light {
    color: var(--deep-navy);
    background: #fff;
    border: 1px solid rgba(255, 255, 255, .4);
    box-shadow: 0 18px 38px rgba(0, 0, 0, .22);
}

.btn-cta-light:hover {
    color: var(--deep-navy);
    background: var(--gold-soft);
    transform: translateY(-1px);
}

.contact-panel,
.contact-form {
    border-color: var(--line-soft);
    box-shadow: 0 22px 52px rgba(16, 24, 40, .07);
}

.contact-panel {
    background:
        linear-gradient(180deg, #fff, #fbfcff);
}

.contact-panel h4 {
    color: var(--deep-navy);
}

.contact-form .form-control {
    min-height: 48px;
    border-color: #dce5f1;
    border-radius: 8px;
}

.contact-form textarea.form-control {
    min-height: 160px;
}

.contact-form .form-control:focus {
    border-color: rgba(200, 164, 93, .85);
    box-shadow: 0 0 0 .22rem rgba(200, 164, 93, .15);
}

.site-footer {
    padding: 52px 0 34px;
    color: #dce8f8;
    background:
        radial-gradient(circle at top left, rgba(13, 110, 253, .22), transparent 32%),
        linear-gradient(135deg, #07172d 0%, #111f36 58%, #0b1628 100%);
    border-top: 1px solid rgba(216, 230, 251, .18);
}

.footer-grid {
    display: grid;
    grid-template-columns: minmax(280px, 1.35fr) repeat(3, minmax(0, .8fr));
    gap: 30px;
    align-items: start;
}

.footer-brand-block {
    max-width: 560px;
}

.footer-eyebrow {
    display: inline-flex;
    margin-bottom: 14px;
    padding: 6px 10px;
    border: 1px solid rgba(147, 197, 253, .32);
    border-radius: 999px;
    color: #93c5fd;
    background: rgba(255, 255, 255, .06);
    font-size: .72rem;
    font-weight: 800;
    letter-spacing: .08em;
    text-transform: uppercase;
}

.site-footer h3,
.site-footer h4 {
    color: #fff;
}

.site-footer h3 {
    margin: 0 0 12px;
    font-size: 1.35rem;
    line-height: 1.2;
}

.site-footer h4 {
    margin: 0 0 14px;
    font-size: 1rem;
    line-height: 1.2;
}

.site-footer p {
    margin: 0;
    color: #b9c7da;
    line-height: 1.8;
}

.footer-socials {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 20px;
}

.footer-link-list,
.footer-contact {
    display: grid;
    gap: 10px;
    margin: 0;
    padding: 0;
    list-style: none;
}

.footer-contact li {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    color: #b9c7da;
    line-height: 1.65;
}

.footer-contact i,
.footer-contact .messenger-icon,
.social-link {
    color: #75aaff;
}

.messenger-icon {
    display: inline-block;
    flex: 0 0 auto;
    width: 1.28em;
    height: 1.28em;
}

.footer-contact .messenger-icon {
    margin-top: .18em;
}

.topbar-links .messenger-icon {
    width: 1.05em;
    height: 1.05em;
}

.zalo-icon .messenger-icon-bg,
.zalo-icon .messenger-icon-tail {
    fill: #0068ff;
}

.zalo-wordmark {
    fill: #fff;
    font-family: Arial, Helvetica, sans-serif;
    font-size: 8.4px;
    font-weight: 800;
    letter-spacing: -.2px;
}

.telegram-icon .messenger-icon-bg {
    fill: #229ed9;
}

.telegram-plane {
    fill: #fff;
}

.footer-link-list a,
.footer-contact a,
.footer-legal-links a {
    color: #dce8f8;
    transition: color .18s ease;
}

.footer-link-list a:hover,
.footer-contact a:hover,
.footer-legal-links a:hover {
    color: #fff;
}

.social-link {
    width: 36px;
    height: 36px;
    display: inline-grid;
    place-items: center;
    border: 1px solid rgba(216, 230, 251, .18);
    border-radius: 8px;
    background: rgba(255, 255, 255, .08);
}

.footer-cta {
    display: flex;
    justify-content: space-between;
    gap: 22px;
    align-items: center;
    margin-top: 34px;
    padding: 22px 24px;
    border: 1px solid rgba(147, 197, 253, .22);
    border-radius: 8px;
    background: rgba(255, 255, 255, .07);
}

.footer-cta div,
.footer-cta strong,
.footer-cta span {
    display: block;
}

.footer-cta strong {
    color: #fff;
    font-size: 1.05rem;
}

.footer-cta span {
    margin-top: 4px;
    color: #b9c7da;
}

.footer-bottom {
    display: flex;
    justify-content: space-between;
    gap: 18px;
    align-items: center;
    margin-top: 28px;
    padding-top: 22px;
    border-top: 1px solid rgba(216, 230, 251, .14);
    color: #9fb0c8;
    font-size: .92rem;
}

.footer-legal-links {
    display: flex;
    flex-wrap: wrap;
    gap: 14px;
}

.floating-actions {
    position: fixed;
    right: 18px;
    bottom: 18px;
    display: grid;
    gap: 10px;
    z-index: 1050;
}

.float-btn {
    width: 46px;
    height: 46px;
    border-radius: 50%;
    display: grid;
    place-items: center;
    color: #fff;
    box-shadow: 0 10px 24px rgba(16, 24, 40, .18);
    font-weight: 700;
}

.float-btn .messenger-icon {
    width: 25px;
    height: 25px;
}

.float-btn.zalo .messenger-icon-bg,
.float-btn.zalo .messenger-icon-tail,
.float-btn.telegram .messenger-icon-bg {
    fill: #fff;
}

.float-btn.zalo .zalo-wordmark {
    fill: #0068ff;
}

.float-btn.telegram .telegram-plane {
    fill: #229ed9;
}

.float-btn:hover {
    color: #fff;
    transform: translateY(-2px);
}

.float-btn.call { background: #198754; }
.float-btn.zalo { background: #0068ff; }
.float-btn.telegram { background: #229ed9; }
.float-btn.mail { background: #dc3545; }
.float-btn.top { background: #6c757d; }

@media (max-width: 767.98px) {
    .hero-section {
        padding: 64px 0 48px;
    }

    .hero-proof {
        grid-template-columns: 1fr;
    }

    .metric-grid {
        grid-template-columns: 1fr;
    }

    .solution-card-top,
    .solution-showcase-body,
    .solution-showcase-footer {
        padding-left: 20px;
        padding-right: 20px;
    }

    .solution-showcase-card:hover {
        transform: none;
    }

    .comparison-section {
        padding-top: 58px !important;
        padding-bottom: 58px !important;
    }

    .comparison-heading {
        margin-bottom: 30px;
    }

    .comparison-heading .section-title {
        font-size: 2rem;
    }

    .comparison-detail-table {
        min-width: 940px;
        font-size: .88rem;
    }

    .comparison-table .table thead th,
    .comparison-table .table tbody td {
        padding: 14px 16px;
    }

    .floating-actions {
        right: 12px;
        bottom: 12px;
    }

    .site-footer {
        padding: 38px 0 28px;
    }

    .footer-grid,
    .footer-cta,
    .footer-bottom {
        display: grid;
    }

    .footer-cta .btn {
        width: 100%;
    }
}

@media (max-width: 991.98px) {
    .footer-grid {
        grid-template-columns: repeat(auto-fit, minmax(min(100%, 240px), 1fr));
    }

    .footer-brand-block {
        grid-column: 1 / -1;
    }

    .footer-bottom {
        align-items: flex-start;
        flex-direction: column;
    }

    .premium-navbar {
        min-height: 68px;
    }

    .dropdown-submenu > .dropdown-menu {
        margin: 4px 0 8px 14px;
        border-left: 2px solid #d8e6fb;
    }

    .dropdown-submenu > .dropdown-toggle::after {
        transform: none;
    }

    .hero-section {
        padding-top: 72px;
    }

    .navbar-collapse {
        margin-top: 14px;
        padding: 12px;
        border: 1px solid #dce8f8;
        border-radius: 8px;
        background: #fff;
        box-shadow: 0 20px 42px rgba(16, 24, 40, .10);
    }

    .premium-nav-link {
        margin: 2px 0;
        padding: 12px 14px !important;
    }

    .premium-nav-link::after {
        display: none;
    }

    .nav-cta {
        width: 100%;
        justify-content: center;
        margin-top: 8px;
    }
}

@media (max-width: 420px) {
    .brand-mark {
        width: 40px;
        height: 40px;
    }

    .brand-name {
        max-width: 190px;
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
        font-size: .98rem;
    }

    .brand-subtitle {
        font-size: .66rem;
    }
}

.cyber-hero {
    position: relative;
    min-height: calc(100vh - 114px);
    display: flex;
    align-items: center;
    overflow: hidden;
    color: #fff;
    background:
        repeating-linear-gradient(90deg, rgba(76, 141, 255, .10) 0, rgba(76, 141, 255, .10) 1px, transparent 1px, transparent 72px),
        repeating-linear-gradient(0deg, rgba(76, 141, 255, .08) 0, rgba(76, 141, 255, .08) 1px, transparent 1px, transparent 72px),
        linear-gradient(110deg, rgba(3, 12, 27, .98) 0%, rgba(7, 26, 57, .97) 45%, rgba(17, 56, 118, .98) 100%);
    background-size: 72px 72px, 72px 72px, auto;
    animation: cyberGridDrift 26s linear infinite;
}

.cyber-hero::after {
    content: "";
    position: absolute;
    inset: auto 0 0 0;
    height: 180px;
    background: linear-gradient(0deg, rgba(2, 86, 122, .28), transparent);
    pointer-events: none;
}

.cyber-hero .container {
    position: relative;
    z-index: 1;
}

.home-shell .site-header {
    position: fixed;
    top: 0;
    right: 0;
    left: 0;
    box-shadow: none;
}

.home-shell .nav-topbar {
    display: none !important;
}

.home-shell .premium-navbar {
    min-height: 74px;
    background: rgba(3, 14, 30, .24);
    border-bottom: 1px solid rgba(177, 208, 255, .13);
    backdrop-filter: blur(16px);
}

.home-shell.home-nav-scrolled .premium-navbar {
    background: rgba(4, 16, 34, .92);
    box-shadow: 0 18px 42px rgba(0, 0, 0, .26);
}

.home-shell .premium-brand,
.home-shell .premium-brand:hover,
.home-shell .brand-name,
.home-shell .premium-nav-link {
    color: #fff !important;
}

.home-shell .brand-subtitle {
    color: rgba(211, 228, 255, .72);
}

.home-shell .brand-mark {
    background: linear-gradient(135deg, #155bd5, #13c8ef);
}

.home-shell .premium-nav-link:hover,
.home-shell .premium-nav-link.active {
    color: #58d7ff !important;
    background: rgba(50, 113, 220, .20);
}

.home-shell .premium-toggler {
    border-color: rgba(198, 220, 255, .30);
}

.home-shell .navbar-toggler-icon {
    filter: invert(1) brightness(2);
}

.home-shell .navbar-collapse {
    background: transparent;
    border-color: transparent;
}

.home-shell .cyber-hero {
    min-height: 100vh;
    padding-top: 112px;
}

.cyber-eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    min-height: 32px;
    padding: 7px 15px;
    border: 1px solid rgba(17, 202, 255, .35);
    border-radius: 999px;
    color: #21d4ff;
    background: rgba(6, 84, 126, .34);
    font-size: .78rem;
    font-weight: 700;
    letter-spacing: .12em;
    line-height: 1;
    text-transform: uppercase;
}

.cyber-eyebrow i {
    font-size: .62rem;
}

.home-hero-title {
    max-width: 760px;
    margin: 0;
    color: #fff;
    font-size: 3.35rem;
    font-weight: 800 !important;
    letter-spacing: 0;
    line-height: 1.08;
}

.home-hero-title span {
    display: inline;
}

.hero-gradient {
    color: #38d6ff;
    background: linear-gradient(135deg, #6db4ff 0%, #20d7ff 70%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
}

.home-hero-copy {
    max-width: 620px;
    color: #b8c8df;
    font-size: 1.02rem;
    font-weight: 600;
    line-height: 1.8;
}

.hero-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
}

.btn-hero-primary,
.btn-hero-secondary {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    min-height: 56px;
    padding-inline: 26px;
    border-radius: 8px;
    font-weight: 750;
}

.btn-hero-primary {
    color: #fff;
    border: 1px solid rgba(74, 163, 255, .55);
    background: linear-gradient(135deg, #2e7bea, #2563d9);
    box-shadow: 0 22px 44px rgba(37, 99, 217, .34);
}

.btn-hero-primary:hover,
.btn-hero-primary:focus {
    color: #fff;
    background: linear-gradient(135deg, #3789ff, #1f57c8);
}

.btn-hero-secondary {
    color: #fff;
    border: 1px solid rgba(183, 210, 255, .38);
    background: rgba(9, 28, 60, .58);
}

.btn-hero-secondary:hover,
.btn-hero-secondary:focus {
    color: #fff;
    border-color: rgba(183, 210, 255, .68);
    background: rgba(16, 48, 96, .76);
}

.hero-stats {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 20px;
    max-width: 720px;
    padding-top: 28px;
    border-top: 1px solid rgba(141, 181, 255, .22);
}

.hero-stats strong,
.hero-stats span {
    display: block;
}

.hero-stats strong {
    color: #fff;
    font-size: 1.45rem;
    font-weight: 800;
    line-height: 1.15;
}

.hero-stats strong::first-letter {
    color: #61ddff;
}

.hero-stats span {
    margin-top: 4px;
    color: #94a8c4;
    font-size: .82rem;
    line-height: 1.4;
}

.hero-radar {
    position: relative;
    max-width: 470px;
    aspect-ratio: 1;
    margin-inline: auto;
}

.hero-radar.radar-card-count-5,
.hero-radar.radar-card-count-6 {
    max-width: 500px;
}

.radar-ring {
    position: absolute;
    inset: 50%;
    border: 1px solid rgba(63, 145, 255, .25);
    border-radius: 50%;
    transform: translate(-50%, -50%);
}

.ring-1 {
    width: 78%;
    height: 78%;
    animation: radarPulse 4s ease-in-out infinite;
}

.ring-2 {
    width: 58%;
    height: 58%;
    animation: radarPulse 4s ease-in-out .55s infinite;
}

.ring-3 {
    width: 38%;
    height: 38%;
    animation: radarPulse 4s ease-in-out 1.1s infinite;
}

.radar-shield {
    position: absolute;
    left: 50%;
    top: 50%;
    width: 130px;
    height: 130px;
    display: grid;
    place-items: center;
    border-radius: 50%;
    color: #fff;
    background: #2f70dd;
    box-shadow: 0 24px 60px rgba(32, 105, 220, .38);
    transform: translate(-50%, -50%);
}

.radar-shield i {
    font-size: 3.3rem;
}

.radar-card {
    position: absolute;
    min-width: 168px;
    display: flex;
    align-items: center;
    gap: 11px;
    padding: 12px 14px;
    border: 1px solid rgba(135, 172, 226, .18);
    border-radius: 8px;
    color: #fff;
    background: rgba(8, 19, 38, .86);
    box-shadow: 0 18px 34px rgba(0, 0, 0, .24);
    animation: radarChipFloat 4.5s ease-in-out infinite;
}

.radar-card-1 {
    left: 8%;
    top: 20%;
}

.radar-card-2 {
    left: 11%;
    bottom: 32%;
    animation-delay: 1.2s;
}

.radar-card-3 {
    right: 4%;
    bottom: 20%;
    animation-delay: 2s;
}

.radar-slot-top-left {
    left: 8%;
    top: 18%;
}

.radar-slot-left {
    left: 10%;
    bottom: 32%;
}

.radar-slot-bottom-right {
    right: 4%;
    bottom: 20%;
}

.radar-slot-top-right {
    right: 6%;
    top: 16%;
}

.radar-slot-bottom-left {
    left: 4%;
    bottom: 8%;
}

.radar-slot-bottom-center {
    left: 38%;
    bottom: 3%;
}

.radar-card > i {
    width: 30px;
    height: 30px;
    display: grid;
    place-items: center;
    flex: 0 0 auto;
    border-radius: 7px;
    background: rgba(255, 255, 255, .10);
}

.radar-danger > i {
    color: #ff6b79;
    background: rgba(255, 82, 105, .16);
}

.radar-warning > i {
    color: #ffc247;
    background: rgba(255, 194, 71, .16);
}

.radar-primary > i,
.radar-info > i {
    color: #61ddff;
    background: rgba(34, 211, 238, .16);
}

.radar-success > i {
    color: #2be0a3;
    background: rgba(43, 224, 163, .16);
}

.radar-card strong,
.radar-card span {
    display: block;
    line-height: 1.25;
}

.radar-card strong {
    font-size: .84rem;
    font-weight: 800;
}

.radar-card span {
    margin-top: 3px;
    color: #c9d6ea;
    font-size: .72rem;
    font-weight: 650;
}

.comparison-table {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}

.comparison-detail-table {
    min-width: 860px;
}

.comparison-table .table thead th,
.comparison-table .table tbody td {
    white-space: normal;
}

html.has-home-js .js-reveal {
    opacity: 0;
    transform: translateY(26px);
    transition:
        opacity .65s ease var(--reveal-delay, 0ms),
        transform .65s ease var(--reveal-delay, 0ms);
}

html.has-home-js .js-reveal.is-visible {
    opacity: 1;
    transform: none;
}

.float-btn.top {
    opacity: 0;
    pointer-events: none;
    transform: translateY(8px);
}

.float-btn.top.is-visible,
html:not(.has-home-js) .float-btn.top {
    opacity: 1;
    pointer-events: auto;
    transform: none;
}

@keyframes cyberGridDrift {
    from { background-position: 0 0, 0 0, 0 0; }
    to { background-position: 72px 72px, 72px 72px, 0 0; }
}

@keyframes radarPulse {
    0%, 100% {
        opacity: .62;
        transform: translate(-50%, -50%) scale(1);
    }
    50% {
        opacity: 1;
        transform: translate(-50%, -50%) scale(1.06);
    }
}

@keyframes radarChipFloat {
    0%, 100% { transform: translateY(0); }
    50% { transform: translateY(-10px); }
}

@media (max-width: 991.98px) {
    .cyber-hero {
        min-height: auto;
        padding-top: 72px;
        padding-bottom: 72px;
    }

    .home-shell .cyber-hero {
        min-height: auto;
        padding-top: 104px;
    }

    .home-shell .navbar-collapse {
        background: rgba(5, 18, 39, .96);
        border-color: rgba(177, 208, 255, .16);
    }

    .home-hero-title {
        max-width: 680px;
        font-size: 2.85rem;
    }

    .hero-radar {
        max-width: 420px;
    }

    .radar-card-1 {
        left: 0;
    }

    .radar-card-2 {
        left: 2%;
    }

    .radar-card-3 {
        right: 0;
    }
}

@media (max-width: 767.98px) {
    .home-shell .premium-navbar {
        min-height: 66px;
    }

    .cyber-hero {
        padding-top: 58px;
        padding-bottom: 56px;
    }

    .home-shell .cyber-hero {
        min-height: auto;
        display: block;
        padding-top: 84px;
        padding-bottom: 34px;
    }

    .cyber-hero .row {
        --bs-gutter-y: 1.75rem;
    }

    .cyber-eyebrow {
        min-height: 28px;
        padding: 6px 11px;
        font-size: .66rem;
        letter-spacing: .08em;
    }

    .home-hero-title {
        max-width: 100%;
        font-size: clamp(1.9rem, 8.6vw, 2.28rem);
        line-height: 1.08;
    }

    .home-hero-title.mt-4,
    .home-hero-copy.mt-4,
    .hero-actions.mt-4 {
        margin-top: 1rem !important;
    }

    .home-hero-copy {
        max-width: 100%;
        font-size: .92rem;
        line-height: 1.65;
    }

    .hero-actions {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 10px;
    }

    .hero-actions .btn {
        width: 100%;
        min-height: 48px;
        padding: .68rem .7rem;
        font-size: .9rem;
    }

    .hero-stats.mt-5 {
        margin-top: 1.5rem !important;
    }

    .hero-stats {
        grid-template-columns: repeat(4, minmax(0, 1fr));
        gap: 8px;
        padding-top: 16px;
    }

    .hero-stats strong {
        font-size: 1.08rem;
    }

    .hero-stats span {
        font-size: .66rem;
        line-height: 1.28;
    }

    .hero-radar {
        max-width: 282px;
        min-height: 282px;
        margin-top: 2px;
    }

    .hero-radar.radar-card-count-5,
    .hero-radar.radar-card-count-6 {
        max-width: 302px;
        min-height: 302px;
    }

    .radar-shield {
        width: 88px;
        height: 88px;
    }

    .radar-shield i {
        font-size: 2.2rem;
    }

    .radar-card {
        min-width: 128px;
        max-width: 142px;
        gap: 8px;
        padding: 8px 9px;
    }

    .radar-card > i {
        width: 25px;
        height: 25px;
        font-size: .76rem;
    }

    .radar-card strong {
        font-size: .72rem;
    }

    .radar-card span {
        font-size: .63rem;
    }

    .radar-card-1 {
        left: -2px;
        top: 14%;
    }

    .radar-card-2 {
        left: 0;
        bottom: 28%;
    }

    .radar-card-3 {
        right: -2px;
        bottom: 13%;
    }

    .radar-slot-top-left {
        left: -2px;
        top: 12%;
    }

    .radar-slot-left {
        left: 0;
        bottom: 29%;
    }

    .radar-slot-bottom-right {
        right: -2px;
        bottom: 13%;
    }

    .radar-slot-top-right {
        right: -2px;
        top: 10%;
    }

    .radar-slot-bottom-left {
        left: 6%;
        bottom: 2%;
    }

    .radar-slot-bottom-center {
        right: 12%;
        left: auto;
        bottom: -6%;
    }

    .comparison-detail-table {
        min-width: 760px;
        font-size: .84rem;
    }

    .comparison-table .table thead th:first-child,
    .comparison-table .table tbody td:first-child {
        position: sticky;
        left: 0;
        z-index: 2;
        min-width: 180px;
        box-shadow: 8px 0 16px rgba(16, 24, 40, .08);
    }

    .comparison-table .table thead th:first-child {
        z-index: 3;
    }

    .comparison-table .table thead th,
    .comparison-table .table tbody td {
        min-width: 150px;
        padding: 13px 14px;
    }
}

@media (max-width: 420px) {
    .home-hero-title {
        font-size: clamp(1.78rem, 8.8vw, 2rem);
    }

    .cyber-eyebrow {
        font-size: .68rem;
        letter-spacing: .08em;
    }

    .hero-radar {
        max-width: 260px;
        min-height: 260px;
    }

    .hero-radar.radar-card-count-5,
    .hero-radar.radar-card-count-6 {
        max-width: 282px;
        min-height: 282px;
    }

    .radar-card {
        min-width: 122px;
    }

    .hero-actions .btn {
        font-size: .84rem;
    }

    .hero-stats span {
        font-size: .62rem;
    }
}

@media (max-width: 991.98px) {
    .software-hero > div > .software-kicker,
    .software-hero > div > h2,
    .software-hero > div > p,
    .software-hero-points,
    .m365-hero-copy > .m365-kicker,
    .m365-hero-copy > h2,
    .m365-hero-copy > p,
    .m365-hero-points,
    .gateway-hero-copy > .gateway-kicker,
    .gateway-hero-copy > h2,
    .gateway-hero-copy > p,
    .gateway-hero-points,
    .about-hero-copy > .about-kicker,
    .about-hero-copy > h2,
    .about-hero-copy > p,
    .about-hero-points,
    .backup-hero-copy > .backup-kicker,
    .backup-hero-copy > h2,
    .backup-hero-copy > p,
    .backup-hero-points,
    .software-hero > figure,
    .m365-hero-figure,
    .gateway-hero-figure,
    .about-hero-figure,
    .backup-hero-figure {
        grid-column: 1;
        grid-row: auto;
    }

    .m365-hero-panel,
    .m365-blueprint,
    .m365-outcomes,
    .m365-cta-strip,
    .about-hero-panel,
    .about-blueprint,
    .about-compliance,
    .about-outcomes,
    .about-cta-strip,
    .gateway-hero-panel,
    .gateway-blueprint,
    .gateway-outcomes,
    .gateway-cta-strip {
        grid-template-columns: 1fr;
    }

    .m365-process,
    .about-process,
    .gateway-process {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .m365-cta-strip .btn,
    .about-cta-strip .btn,
    .gateway-cta-strip .btn {
        justify-self: start;
    }
}

@media (max-width: 767.98px) {
    .content-body-wide {
        max-width: 100%;
    }

    .m365-page,
    .about-page,
    .gateway-page {
        gap: 46px;
    }

    .m365-page h2,
    .about-page h2,
    .gateway-page h2 {
        font-size: 1.55rem;
    }

    .m365-kicker,
    .gateway-kicker,
    .backup-kicker {
        width: 100%;
        min-height: 44px;
        padding: 9px 13px;
        border-radius: 14px;
        font-size: 1rem;
        line-height: 1.25;
    }

    .m365-hero-panel,
    .m365-blueprint,
    .m365-outcomes,
    .m365-cta-strip,
    .about-hero-panel,
    .about-blueprint,
    .about-compliance,
    .about-outcomes,
    .about-cta-strip,
    .gateway-hero-panel,
    .gateway-blueprint,
    .gateway-outcomes,
    .gateway-cta-strip {
        padding: 22px;
    }

    .m365-hero-points span,
    .about-hero-points span,
    .gateway-hero-points span {
        display: block;
    }

    .m365-hero-points strong,
    .about-hero-points strong,
    .gateway-hero-points strong {
        display: block;
        min-width: 0;
        margin-bottom: 2px;
    }

    .m365-service-grid,
    .m365-process,
    .about-focus-grid,
    .about-process,
    .gateway-feature-grid,
    .gateway-compare-mini,
    .gateway-process {
        grid-template-columns: 1fr;
    }

    .m365-service-card,
    .about-focus-card,
    .gateway-feature-card {
        padding: 20px;
    }

    .m365-service-card img,
    .about-focus-card img,
    .gateway-feature-card img {
        max-width: 132px;
        height: 96px;
    }

    .m365-cta-strip .btn,
    .about-cta-strip .btn,
    .gateway-cta-strip .btn {
        width: 100%;
    }
}

@media (max-width: 767.98px) {
    html {
        font-size: 17px;
    }

    body {
        font-size: 1rem;
        line-height: 1.72;
    }

    p,
    li,
    .content-body,
    .content-body p,
    .content-body li,
    .content-body td,
    .content-body th,
    .software-hero p,
    .software-section p,
    .software-license-panel li,
    .software-consult-box p,
    .software-sources li,
    .m365-hero-copy > p,
    .m365-service-card p,
    .m365-service-card li,
    .m365-process p,
    .m365-blueprint-list span,
    .gateway-hero-copy > p,
    .gateway-feature-card p,
    .gateway-feature-card li,
    .gateway-process p,
    .gateway-blueprint-list span,
    .about-hero-copy > p,
    .about-focus-card p,
    .about-focus-card li,
    .about-process p,
    .about-blueprint-list span,
    .premium-accordion .accordion-body,
    .site-footer,
    .footer-contact li {
        font-size: 1rem;
        line-height: 1.78;
    }

    .lead,
    .page-hero .lead,
    .home-hero-copy,
    .about-section-lead,
    .m365-section-lead,
    .gateway-section-lead {
        font-size: 1.06rem;
        line-height: 1.72;
    }

    .premium-nav-link,
    .dropdown-item,
    .nav-cta,
    .btn,
    .software-contact-links a,
    .contact-form .form-label,
    .contact-form .form-control,
    .contact-form .btn {
        font-size: 1rem;
    }

    .brand-name {
        font-size: 1.04rem;
    }

    .brand-subtitle {
        font-size: .74rem;
    }

    .cyber-eyebrow,
    .software-product-card span,
    .about-kicker {
        font-size: .78rem;
        line-height: 1.25;
    }

    .hero-actions .btn {
        min-height: 50px;
        font-size: .98rem;
    }

    .hero-stats strong {
        font-size: 1.24rem;
    }

    .hero-stats span,
    .gateway-hero-figure figcaption,
    .m365-hero-figure figcaption,
    .about-hero-figure figcaption {
        font-size: .82rem;
        line-height: 1.55;
    }

    .radar-card strong,
    .solution-showcase-body h3,
    .software-category-card strong,
    .software-product-card strong {
        font-size: 1rem;
    }

    .radar-card span,
    .solution-showcase-body p,
    .solution-showcase-body li,
    .solution-showcase-meta,
    .solution-tag,
    .comparison-detail-table,
    .comparison-table .table thead th,
    .comparison-table .table tbody td {
        font-size: .96rem;
        line-height: 1.6;
    }

    .premium-accordion .accordion-button {
        font-size: 1rem;
        line-height: 1.45;
    }
}

@media (max-width: 420px) {
    html {
        font-size: 16.5px;
    }

    .hero-stats span,
    .radar-card span {
        font-size: .78rem;
    }

    .hero-actions .btn {
        font-size: .95rem;
    }
}

.tool-hero,
.tool-detail-hero {
    background:
        linear-gradient(135deg, #f8fbff 0%, #eef6ff 52%, #fff 100%);
}

.tool-hero-panel,
.tool-note-panel {
    display: grid;
    grid-template-columns: minmax(0, 1.06fr) minmax(320px, .94fr);
    gap: 34px;
    align-items: center;
    padding: 34px;
    border: 1px solid #dbe8fb;
    border-radius: 8px;
    background:
        radial-gradient(circle at top right, rgba(13, 110, 253, .10), transparent 34%),
        #fff;
    box-shadow: 0 24px 60px rgba(16, 24, 40, .08);
}

.tool-kicker {
    display: inline-flex;
    align-items: center;
    width: fit-content;
    max-width: 100%;
    margin-bottom: 14px;
    padding: 7px 12px;
    border: 1px solid #93c5fd;
    border-radius: 999px;
    color: #0f53c7;
    background: #eff6ff;
    font-size: .76rem;
    font-weight: 800;
    letter-spacing: .08em;
    line-height: 1.25;
    text-transform: uppercase;
}

.tool-hero h1,
.tool-detail-heading h1 {
    max-width: 820px;
    margin: 0;
    color: #07172d;
    font-size: clamp(2.25rem, 4.2vw, 4rem);
    line-height: 1.05;
}

.tool-hero p,
.tool-detail-heading p,
.tool-section-heading p,
.tool-group-head p,
.tool-link-grid span,
.tool-note-panel p,
.tool-article p,
.tool-form-head p {
    color: #51627a;
    line-height: 1.78;
}

.tool-hero-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-top: 26px;
}

.tool-hero-visual {
    position: relative;
    min-height: 360px;
}

.tool-orbit,
.tool-radar-core,
.tool-radar-chip {
    position: absolute;
}

.tool-orbit {
    inset: 50%;
    border: 1px solid rgba(37, 99, 235, .18);
    border-radius: 50%;
    transform: translate(-50%, -50%);
}

.tool-orbit-one {
    width: 84%;
    aspect-ratio: 1;
}

.tool-orbit-two {
    width: 58%;
    aspect-ratio: 1;
}

.tool-radar-core {
    left: 50%;
    top: 50%;
    width: 118px;
    height: 118px;
    display: grid;
    place-items: center;
    border-radius: 50%;
    color: #fff;
    background: linear-gradient(135deg, #0f53c7, #38bdf8);
    box-shadow: 0 24px 54px rgba(37, 99, 235, .26);
    transform: translate(-50%, -50%);
}

.tool-radar-core i {
    font-size: 3rem;
}

.tool-radar-chip {
    display: inline-flex;
    align-items: center;
    gap: 9px;
    min-width: 132px;
    padding: 12px 14px;
    border: 1px solid #dbe8fb;
    border-radius: 8px;
    color: #07172d;
    background: rgba(255, 255, 255, .94);
    box-shadow: 0 18px 36px rgba(16, 24, 40, .10);
}

.tool-radar-chip i {
    color: #0f53c7;
}

.tool-radar-chip-one {
    left: 7%;
    top: 21%;
}

.tool-radar-chip-two {
    right: 4%;
    top: 30%;
}

.tool-radar-chip-three {
    left: 22%;
    bottom: 16%;
}

.tool-section-heading,
.tool-detail-heading {
    max-width: 860px;
    margin-bottom: 30px;
}

.tool-section-heading h2,
.tool-note-panel h2,
.tool-article h2 {
    margin: 0 0 10px;
    color: #07172d;
    font-size: clamp(1.65rem, 2.8vw, 2.65rem);
    line-height: 1.14;
}

.tool-group-grid {
    display: grid;
    gap: 24px;
}

.tool-group-card {
    padding: 26px;
    border: 1px solid #dfe8f5;
    border-radius: 8px;
    background: #fff;
    box-shadow: 0 18px 42px rgba(16, 24, 40, .06);
}

.tool-group-head {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: 16px;
    align-items: start;
    margin-bottom: 20px;
}

.tool-group-head > span {
    width: 46px;
    height: 46px;
    display: grid;
    place-items: center;
    border-radius: 10px;
    color: #fff;
    background: linear-gradient(135deg, #0f53c7, #0ea5e9);
}

.tool-group-head h3 {
    margin: 0 0 4px;
    color: #07172d;
}

.tool-link-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 14px;
}

.tool-link-grid a {
    position: relative;
    min-height: 132px;
    padding: 18px 44px 18px 18px;
    border: 1px solid #dbe8fb;
    border-radius: 8px;
    color: #172033;
    background: #f8fbff;
    transition: transform .18s ease, border-color .18s ease, box-shadow .18s ease;
}

.tool-link-grid a:hover {
    border-color: #93c5fd;
    color: #0f53c7;
    transform: translateY(-2px);
    box-shadow: 0 18px 36px rgba(37, 99, 235, .10);
}

.tool-link-grid strong,
.tool-link-grid span {
    display: block;
}

.tool-link-grid strong {
    margin-bottom: 8px;
}

.tool-link-grid i {
    position: absolute;
    right: 18px;
    top: 20px;
    color: #0f53c7;
}

.tool-workspace {
    display: grid;
    grid-template-columns: 280px minmax(0, 1fr);
    gap: 24px;
    align-items: start;
}

.tool-sidebar,
.tool-console,
.tool-article {
    border: 1px solid #dfe8f5;
    border-radius: 8px;
    background: #fff;
    box-shadow: 0 18px 42px rgba(16, 24, 40, .06);
}

.tool-sidebar {
    position: sticky;
    top: 94px;
    padding: 18px;
}

.tool-sidebar h2 {
    margin: 0 0 14px;
    color: #07172d;
    font-size: 1.05rem;
}

.tool-sidebar details {
    border-top: 1px solid #edf2f9;
}

.tool-sidebar summary {
    cursor: pointer;
    padding: 12px 0;
    color: #07172d;
    font-weight: 750;
}

.tool-sidebar a {
    display: block;
    margin-bottom: 6px;
    padding: 9px 10px;
    border-radius: 8px;
    color: #51627a;
    font-size: .94rem;
}

.tool-sidebar a:hover,
.tool-sidebar a.active {
    color: #0f53c7;
    background: #eff6ff;
}

.tool-console {
    overflow: hidden;
}

.tool-form {
    padding: 24px;
    border-bottom: 1px solid #e5eef9;
    background: #f8fbff;
}

.tool-form-head {
    display: flex;
    justify-content: space-between;
    gap: 18px;
    align-items: start;
    margin-bottom: 22px;
}

.tool-form-head h2 {
    margin: 0;
    color: #07172d;
}

.tool-fields {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
}

.tool-field {
    display: grid;
    gap: 8px;
}

.tool-field:has(textarea),
.tool-field:has(input[type="file"]) {
    grid-column: 1 / -1;
}

.tool-field span {
    color: #172033;
    font-weight: 700;
}

.tool-field em {
    color: #dc3545;
    font-style: normal;
}

.tool-field input,
.tool-field select,
.tool-field textarea {
    width: 100%;
    min-height: 48px;
    padding: 10px 12px;
    border: 1px solid #dbe8fb;
    border-radius: 8px;
    color: #172033;
    background: #fff;
}

.tool-field textarea {
    min-height: 180px;
    resize: vertical;
}

.tool-result-shell {
    padding: 24px;
}

.tool-result-empty {
    min-height: 250px;
    display: grid;
    place-items: center;
    align-content: center;
    gap: 8px;
    color: #657188;
    text-align: center;
}

.tool-result-empty i {
    color: #0f53c7;
    font-size: 2rem;
}

.tool-result-summary,
.tool-generated-record,
.tool-result-section {
    margin-bottom: 18px;
    padding: 18px;
    border: 1px solid #dbe8fb;
    border-radius: 8px;
    background: #fff;
}

.tool-result-summary {
    display: grid;
    gap: 6px;
    background: #f8fbff;
}

.tool-result-summary span {
    width: fit-content;
    padding: 4px 9px;
    border-radius: 999px;
    color: #0f53c7;
    background: #eff6ff;
    font-size: .78rem;
    font-weight: 800;
    text-transform: uppercase;
}

.tool-result-summary strong {
    color: #07172d;
    font-size: 1.08rem;
}

.tool-result-section h3,
.tool-generated-record h3 {
    margin: 0 0 12px;
    color: #07172d;
    font-size: 1.05rem;
}

.tool-result-list {
    display: grid;
    gap: 10px;
}

.tool-result-item {
    display: grid;
    grid-template-columns: minmax(130px, .32fr) minmax(0, 1fr);
    gap: 12px;
    padding: 12px;
    border: 1px solid #edf2f9;
    border-left-width: 4px;
    border-radius: 8px;
    background: #fbfdff;
}

.tool-result-item span {
    color: #07172d;
    font-weight: 750;
}

.tool-result-item pre,
.tool-generated-record pre {
    overflow-x: auto;
    margin: 0;
    white-space: pre-wrap;
    word-break: break-word;
    color: #34445c;
    font: inherit;
}

.tool-result-success {
    border-left-color: #16a34a;
}

.tool-result-warning {
    border-left-color: #f59e0b;
}

.tool-result-danger {
    border-left-color: #dc3545;
}

.tool-result-info {
    border-left-color: #0f53c7;
}

.tool-generated-record {
    background: #07172d;
}

.tool-generated-record h3,
.tool-generated-record span,
.tool-generated-record pre {
    color: #fff;
}

.tool-generated-record div {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    align-items: center;
    margin-bottom: 12px;
}

.tool-generated-record button {
    border: 1px solid rgba(255, 255, 255, .34);
    border-radius: 999px;
    color: #07172d;
    background: #fff;
    padding: 6px 12px;
    font-weight: 750;
}

.tool-article {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 24px;
    margin-top: 24px;
    padding: 28px;
}

.tool-note-section {
    background: #f8fbff;
}

.tool-note-panel {
    grid-template-columns: minmax(0, 1fr) auto;
}

@media (max-width: 991.98px) {
    .tool-hero-panel,
    .tool-note-panel,
    .tool-workspace,
    .tool-article {
        grid-template-columns: 1fr;
    }

    .tool-sidebar {
        position: static;
    }

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

    .tool-note-panel .btn {
        justify-self: start;
    }
}

@media (max-width: 767.98px) {
    .tool-hero-panel,
    .tool-group-card,
    .tool-form,
    .tool-result-shell,
    .tool-article,
    .tool-note-panel {
        padding: 20px;
    }

    .tool-hero h1,
    .tool-detail-heading h1 {
        font-size: 2rem;
    }

    .tool-hero-visual {
        min-height: 280px;
    }

    .tool-radar-core {
        width: 96px;
        height: 96px;
    }

    .tool-radar-chip {
        min-width: 112px;
        padding: 9px 10px;
        font-size: .86rem;
    }

    .tool-link-grid,
    .tool-fields {
        grid-template-columns: 1fr;
    }

    .tool-form-head,
    .tool-generated-record div {
        display: grid;
    }

    .tool-form-head .btn,
    .tool-note-panel .btn {
        width: 100%;
    }

    .tool-result-item {
        grid-template-columns: 1fr;
    }
}

.backup-page {
    display: grid;
    gap: 72px;
}

.backup-kicker {
    display: inline-flex;
    align-items: center;
    max-width: 100%;
    min-height: 46px;
    margin-bottom: 16px;
    padding: 10px 18px;
    border: 2px solid #93c5fd;
    border-radius: 16px;
    color: #0b4fd9;
    background: linear-gradient(135deg, #fff 0%, #eff6ff 100%);
    box-shadow: 0 14px 30px rgba(37, 99, 235, .12);
    font-size: clamp(1rem, 1.8vw, 1.45rem);
    font-weight: 850;
    letter-spacing: .02em;
    line-height: 1.2;
    text-transform: uppercase;
}

.backup-hero-panel,
.backup-capability-panel,
.backup-architecture-panel,
.backup-cta-strip {
    display: grid;
    grid-template-columns: minmax(0, 1.08fr) minmax(320px, .92fr);
    gap: 34px;
    align-items: center;
}

.backup-hero-panel {
    padding: 34px;
    border: 1px solid #dbe8fb;
    border-radius: 8px;
    background:
        radial-gradient(circle at top right, rgba(37, 99, 235, .12), transparent 34%),
        linear-gradient(135deg, #f8fbff 0%, #eef6ff 52%, #fff 100%);
    box-shadow: 0 24px 60px rgba(16, 24, 40, .08);
}

.backup-hero-panel h2,
.backup-section h2,
.backup-capability-panel h2,
.backup-architecture-panel h2,
.backup-cta-strip h2,
.backup-sources h2 {
    margin-top: 0;
    color: #07172d;
    font-size: clamp(1.9rem, 3.4vw, 3.2rem);
    line-height: 1.08;
}

.backup-section h2,
.backup-capability-panel h2,
.backup-architecture-panel h2,
.backup-cta-strip h2,
.backup-sources h2 {
    font-size: clamp(1.55rem, 2.6vw, 2.35rem);
}

.backup-hero-panel p,
.backup-section p,
.backup-capability-panel p,
.backup-architecture-panel p,
.backup-cta-strip p,
.backup-sources p {
    color: #51627a;
    line-height: 1.82;
}

.backup-hero-figure {
    margin: 0;
}

.backup-hero-figure img,
.backup-vendor-grid img {
    display: block;
    width: 100%;
    object-fit: contain;
}

.backup-hero-figure figcaption {
    margin-top: 12px;
    color: #657188;
    font-size: .88rem;
    line-height: 1.6;
    text-align: center;
}

.backup-hero-points {
    display: grid;
    gap: 10px;
    margin-top: 24px;
}

.backup-hero-points span {
    display: block;
    padding: 12px 14px;
    border: 1px solid #dbe8fb;
    border-radius: 8px;
    color: #34445c;
    background: rgba(255, 255, 255, .78);
}

.backup-hero-points strong {
    display: inline-block;
    min-width: 112px;
    color: #0f53c7;
}

.software-hero,
.m365-hero-panel,
.gateway-hero-panel,
.about-hero-panel,
.backup-hero-panel {
    align-items: start;
    row-gap: 18px;
}

.software-hero > div > h2,
.m365-hero-copy > h2,
.gateway-hero-copy > h2,
.about-hero-copy > h2,
.backup-hero-copy > h2,
.software-hero > div > p,
.m365-hero-copy > p,
.gateway-hero-copy > p,
.about-hero-copy > p,
.backup-hero-copy > p {
    margin-bottom: 0;
}

.software-hero-points,
.m365-hero-points,
.gateway-hero-points,
.about-hero-points,
.backup-hero-points {
    margin-top: 0;
}

.software-hero > figure,
.m365-hero-figure,
.gateway-hero-figure,
.about-hero-figure,
.backup-hero-figure {
    align-self: start;
}

.backup-section {
    display: grid;
    gap: 18px;
}

.backup-section-lead {
    max-width: 900px;
    margin-bottom: 8px;
}

.backup-pain-grid,
.backup-vendor-grid,
.backup-business-grid,
.backup-case-grid {
    display: grid;
    gap: 22px;
}

.backup-pain-grid,
.backup-business-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.backup-vendor-grid,
.backup-case-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.backup-pain-grid article,
.backup-business-grid article,
.backup-case-grid article,
.backup-vendor-grid a,
.backup-sources {
    min-height: 100%;
    padding: 24px;
    border: 1px solid #dfe8f5;
    border-radius: 8px;
    background: #fff;
    box-shadow: 0 18px 42px rgba(16, 24, 40, .06);
}

.backup-pain-grid i {
    width: 42px;
    height: 42px;
    display: grid;
    place-items: center;
    margin-bottom: 14px;
    border-radius: 10px;
    color: #fff;
    background: linear-gradient(135deg, #0f53c7, #0ea5e9);
}

.backup-pain-grid h3,
.backup-business-grid strong,
.backup-case-grid h3,
.backup-vendor-grid strong {
    display: block;
    margin-bottom: 8px;
    color: #07172d;
    font-size: 1.12rem;
}

.backup-vendor-grid a {
    color: #172033;
    transition: transform .18s ease, border-color .18s ease, box-shadow .18s ease;
}

.backup-vendor-grid a:hover {
    border-color: #93c5fd;
    color: #0f53c7;
    transform: translateY(-3px);
    box-shadow: 0 24px 50px rgba(37, 99, 235, .12);
}

.backup-vendor-grid img {
    max-width: 170px;
    height: 120px;
    margin-bottom: 14px;
}

.backup-vendor-grid span {
    display: block;
    color: #51627a;
}

.backup-capability-panel,
.backup-architecture-panel {
    align-items: start;
    padding: 34px;
    border-radius: 8px;
    color: #fff;
    background:
        radial-gradient(circle at top right, rgba(37, 99, 235, .34), transparent 32%),
        linear-gradient(135deg, #07172d 0%, #123063 100%);
}

.backup-capability-panel h2,
.backup-capability-panel p,
.backup-architecture-panel h2,
.backup-architecture-panel p,
.backup-architecture-panel li {
    color: #fff;
}

.backup-capability-panel .backup-kicker,
.backup-architecture-panel .backup-kicker {
    border-color: rgba(147, 197, 253, .62);
    color: #dff7ff;
    background: linear-gradient(135deg, rgba(14, 116, 144, .38), rgba(37, 99, 235, .22));
    box-shadow: 0 18px 36px rgba(0, 0, 0, .18);
}

.backup-capability-list,
.backup-compare-grid {
    display: grid;
    gap: 14px;
}

.backup-capability-list div,
.backup-compare-grid div {
    padding: 16px;
    border: 1px solid rgba(191, 219, 254, .22);
    border-radius: 8px;
    background: rgba(255, 255, 255, .08);
}

.backup-capability-list strong,
.backup-capability-list span {
    display: block;
}

.backup-capability-list strong {
    color: #93c5fd;
}

.backup-capability-list span {
    margin-top: 4px;
    color: #dce8f8;
    line-height: 1.7;
}

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

.backup-compare-grid h3 {
    color: #dff7ff;
}

.backup-compare-grid ul,
.backup-sources ul {
    margin: 0;
    padding: 0;
    list-style: none;
}

.backup-compare-grid li,
.backup-sources li {
    position: relative;
    padding-left: 24px;
    line-height: 1.72;
}

.backup-compare-grid li + li,
.backup-sources li + li {
    margin-top: 10px;
}

.backup-compare-grid li::before,
.backup-sources li::before {
    content: "\2713";
    position: absolute;
    left: 0;
    color: #38bdf8;
    font-weight: 900;
}

.backup-proof-strip {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.backup-proof-strip span {
    display: inline-flex;
    align-items: center;
    min-height: 40px;
    padding: 8px 13px;
    border: 1px solid #bfdbfe;
    border-radius: 999px;
    color: #0f53c7;
    background: #eff6ff;
    font-weight: 750;
}

.backup-cta-strip {
    grid-template-columns: minmax(0, 1fr) auto;
    padding: 28px 32px;
    border: 1px solid #dbe8fb;
    border-radius: 8px;
    background: linear-gradient(135deg, #eff6ff, #fff);
}

.backup-cta-strip h2 {
    margin-bottom: 8px;
}

.backup-cta-strip p {
    margin-bottom: 0;
}

.backup-sources a {
    color: #0f53c7;
    font-weight: 650;
}

@media (max-width: 991.98px) {
    .backup-hero-panel,
    .backup-capability-panel,
    .backup-architecture-panel,
    .backup-cta-strip,
    .backup-pain-grid,
    .backup-vendor-grid,
    .backup-business-grid,
    .backup-case-grid,
    .backup-compare-grid {
        grid-template-columns: 1fr;
    }

    .backup-cta-strip .btn {
        justify-self: start;
    }
}

@media (max-width: 767.98px) {
    .blog-section-head {
        align-items: stretch;
        flex-direction: column;
        margin-bottom: 18px;
    }

    .blog-category-section {
        padding: 26px 0;
    }

    .blog-category-more {
        justify-content: center;
        width: 100%;
    }

    .post-card-title {
        font-size: 1.2rem;
    }

    .backup-page {
        gap: 46px;
    }

    .backup-hero-panel,
    .backup-capability-panel,
    .backup-architecture-panel,
    .backup-cta-strip,
    .backup-pain-grid article,
    .backup-business-grid article,
    .backup-case-grid article,
    .backup-vendor-grid a,
    .backup-sources {
        padding: 20px;
    }

    .backup-hero-panel h2,
    .backup-section h2,
    .backup-capability-panel h2,
    .backup-architecture-panel h2,
    .backup-cta-strip h2,
    .backup-sources h2 {
        font-size: 1.55rem;
        line-height: 1.18;
    }

    .backup-hero-points strong {
        display: block;
        min-width: 0;
        margin-bottom: 2px;
    }

    .backup-cta-strip .btn {
        width: 100%;
    }
}

.virtualization-page {
    display: grid;
    gap: 72px;
}

.content-body .virtualization-page h2 {
    padding-bottom: 0;
    border-bottom: 0;
}

.virtual-kicker {
    display: inline-flex;
    align-items: center;
    max-width: 100%;
    min-height: 44px;
    margin-bottom: 16px;
    padding: 10px 18px;
    border: 2px solid #93c5fd;
    border-radius: 16px;
    color: #0b4fd9;
    background: linear-gradient(135deg, #fff 0%, #eff6ff 100%);
    box-shadow: 0 14px 30px rgba(37, 99, 235, .12);
    font-size: clamp(1rem, 1.6vw, 1.3rem);
    font-weight: 850;
    letter-spacing: 0;
    line-height: 1.2;
    text-transform: uppercase;
}

.virtual-hero-panel,
.virtual-capability-panel,
.virtual-architecture-panel {
    display: grid;
    grid-template-columns: minmax(0, 1.08fr) minmax(320px, .92fr);
    gap: 34px;
    align-items: start;
}

.virtual-hero-panel {
    padding: 34px;
    border: 1px solid #dbe8fb;
    border-radius: 8px;
    background:
        radial-gradient(circle at top right, rgba(34, 197, 94, .12), transparent 32%),
        linear-gradient(135deg, #f8fbff 0%, #eef6ff 48%, #fff 100%);
    box-shadow: 0 24px 60px rgba(16, 24, 40, .08);
}

.virtual-hero-panel h2,
.virtual-section h2,
.virtual-capability-panel h2,
.virtual-architecture-panel h2,
.virtual-sources h2,
.virtual-contact-box h2 {
    margin-top: 0;
    color: #07172d;
    font-size: clamp(1.9rem, 3.2vw, 3.05rem);
    line-height: 1.1;
}

.virtual-section h2,
.virtual-capability-panel h2,
.virtual-architecture-panel h2,
.virtual-sources h2,
.virtual-contact-box h2 {
    font-size: clamp(1.55rem, 2.4vw, 2.25rem);
}

.virtual-hero-panel p,
.virtual-section p,
.virtual-capability-panel p,
.virtual-architecture-panel p,
.virtual-sources p {
    color: #51627a;
    line-height: 1.82;
}

.virtual-hero-copy {
    grid-column: 1 / -1;
}

.virtual-hero-copy > h2,
.virtual-hero-copy > p {
    margin-bottom: 0;
}

.virtual-hero-figure {
    grid-column: 2;
    grid-row: 2;
    align-self: start;
    margin: 0;
}

.virtual-hero-figure img,
.virtual-solution-grid img {
    display: block;
    width: 100%;
    object-fit: contain;
}

.virtual-hero-figure figcaption {
    margin-top: 12px;
    color: #657188;
    font-size: .88rem;
    line-height: 1.6;
    text-align: center;
}

.virtual-hero-points {
    grid-column: 1;
    align-self: start;
    display: grid;
    gap: 10px;
    margin-top: 0;
}

.virtual-hero-points span {
    display: block;
    padding: 12px 14px;
    border: 1px solid #dbe8fb;
    border-radius: 8px;
    color: #34445c;
    background: rgba(255, 255, 255, .82);
}

.virtual-hero-points strong {
    display: inline-block;
    min-width: 116px;
    color: #0f53c7;
}

.virtual-section {
    display: grid;
    gap: 18px;
}

.virtual-section-lead {
    max-width: 930px;
    margin-bottom: 8px;
}

.virtual-card-grid,
.virtual-solution-grid {
    display: grid;
    gap: 22px;
}

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

.virtual-solution-grid {
    grid-template-columns: repeat(auto-fit, minmax(215px, 1fr));
}

.virtual-card-grid article,
.virtual-solution-grid a,
.virtual-sources,
.virtual-fit-grid > div {
    min-height: 100%;
    padding: 24px;
    border: 1px solid #dfe8f5;
    border-radius: 8px;
    background: #fff;
    box-shadow: 0 18px 42px rgba(16, 24, 40, .06);
}

.virtual-card-grid i {
    display: grid;
    place-items: center;
    width: 42px;
    height: 42px;
    margin-bottom: 14px;
    border-radius: 10px;
    color: #fff;
    background: linear-gradient(135deg, #0f53c7, #1d8b6a);
}

.virtual-card-grid h3,
.virtual-solution-grid strong,
.virtual-fit-grid h3 {
    display: block;
    margin-bottom: 8px;
    color: #07172d;
    font-size: 1.12rem;
}

.virtual-solution-grid a {
    color: #172033;
    transition: transform .18s ease, border-color .18s ease, box-shadow .18s ease;
}

.virtual-solution-grid a:hover {
    border-color: #93c5fd;
    color: #0f53c7;
    transform: translateY(-3px);
    box-shadow: 0 24px 50px rgba(37, 99, 235, .12);
}

.virtual-solution-grid img {
    max-width: 185px;
    height: 126px;
    margin-bottom: 14px;
}

.virtual-solution-grid span {
    display: block;
    color: #51627a;
}

.virtual-capability-panel,
.virtual-architecture-panel {
    padding: 34px;
    border-radius: 8px;
    color: #fff;
    background:
        radial-gradient(circle at top right, rgba(34, 197, 94, .28), transparent 32%),
        linear-gradient(135deg, #07172d 0%, #103257 58%, #17324b 100%);
}

.virtual-capability-panel h2,
.virtual-capability-panel p,
.virtual-architecture-panel h2,
.virtual-architecture-panel p {
    color: #fff;
}

.virtual-capability-panel .virtual-kicker,
.virtual-architecture-panel .virtual-kicker {
    border-color: rgba(147, 197, 253, .62);
    color: #dff7ff;
    background: linear-gradient(135deg, rgba(13, 148, 136, .36), rgba(37, 99, 235, .22));
    box-shadow: 0 18px 36px rgba(0, 0, 0, .18);
}

.virtual-capability-list {
    display: grid;
    gap: 14px;
}

.virtual-capability-list div {
    padding: 16px;
    border: 1px solid rgba(191, 219, 254, .24);
    border-radius: 8px;
    background: rgba(255, 255, 255, .08);
}

.virtual-capability-list strong,
.virtual-capability-list span {
    display: block;
}

.virtual-capability-list strong {
    color: #93c5fd;
}

.virtual-capability-list span {
    margin-top: 4px;
    color: #dce8f8;
    line-height: 1.7;
}

.virtual-fit-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 22px;
}

.virtual-fit-grid ul,
.virtual-sources ul {
    margin: 0;
    padding: 0;
    list-style: none;
}

.virtual-fit-grid li,
.virtual-sources li {
    position: relative;
    padding-left: 24px;
    line-height: 1.72;
}

.virtual-fit-grid li + li,
.virtual-sources li + li {
    margin-top: 10px;
}

.virtual-fit-grid li::before,
.virtual-sources li::before {
    content: "\2713";
    position: absolute;
    left: 0;
    color: #1d8b6a;
    font-weight: 900;
}

.virtual-contact-box {
    align-items: stretch;
}

.virtual-sources a {
    color: #0f53c7;
    font-weight: 650;
}

@media (max-width: 991.98px) {
    .virtual-hero-panel,
    .virtual-capability-panel,
    .virtual-architecture-panel,
    .virtual-card-grid,
    .virtual-fit-grid {
        grid-template-columns: 1fr;
    }

    .virtual-hero-copy,
    .virtual-hero-points,
    .virtual-hero-figure {
        grid-column: auto;
        grid-row: auto;
    }
}

@media (max-width: 767.98px) {
    .virtualization-page {
        gap: 46px;
    }

    .virtual-hero-panel,
    .virtual-capability-panel,
    .virtual-architecture-panel,
    .virtual-card-grid article,
    .virtual-solution-grid a,
    .virtual-sources,
    .virtual-fit-grid > div {
        padding: 20px;
    }

    .virtual-hero-panel h2,
    .virtual-section h2,
    .virtual-capability-panel h2,
    .virtual-architecture-panel h2,
    .virtual-sources h2,
    .virtual-contact-box h2 {
        font-size: 1.55rem;
        line-height: 1.18;
    }

    .virtual-hero-points strong {
        display: block;
        min-width: 0;
        margin-bottom: 2px;
    }
}

.m365-section,
.gateway-section,
.backup-section,
.virtual-section {
    gap: 12px;
}

.m365-section > h2,
.gateway-section > h2,
.backup-section > h2,
.virtual-section > h2 {
    margin-bottom: 0;
}

.m365-section-lead,
.gateway-section-lead,
.backup-section-lead,
.virtual-section-lead {
    width: 100%;
    max-width: none;
    margin: 0 0 8px;
}

@media (max-width: 767.98px) {
    .m365-section,
    .gateway-section,
    .backup-section,
    .virtual-section {
        gap: 10px;
    }
}

.content-body .license-article {
    width: 100%;
}

.content-body .license-article .lead {
    margin-bottom: 24px;
    color: #334155;
    font-size: 1.12rem;
    line-height: 1.85;
}

.content-body .license-article figure {
    margin: 8px 0 32px;
}

.content-body .license-article figcaption {
    margin-top: 10px;
    color: #64748b;
    font-size: .94rem;
    line-height: 1.6;
}

.content-body .license-article table {
    width: 100%;
    margin: 18px 0 30px;
    border-collapse: separate;
    border-spacing: 0;
    overflow: hidden;
    border: 1px solid #d7e4f5;
    border-radius: 8px;
    font-size: .98rem;
    line-height: 1.55;
}

.content-body .license-article th,
.content-body .license-article td {
    padding: 12px 14px;
    vertical-align: top;
    border-bottom: 1px solid #d7e4f5;
}

.content-body .license-article th {
    color: #082f6f;
    background: #eff6ff;
    font-weight: 750;
}

.content-body .license-article tr:last-child td {
    border-bottom: 0;
}

@media (max-width: 767.98px) {
    .content-body .license-article table {
        display: block;
        overflow-x: auto;
        white-space: nowrap;
    }
}

.microsoft-brand-mark {
    display: grid;
    grid-template-columns: repeat(2, 13px);
    grid-template-rows: repeat(2, 13px);
    gap: 3px;
    padding: 8px;
    background: #fff;
    border: 1px solid #dbe8fb;
    box-shadow: 0 12px 24px rgba(16, 24, 40, .08);
}

.microsoft-brand-mark span,
.microsoft-grid-mark span {
    display: block;
}

.microsoft-brand-mark span:nth-child(1),
.microsoft-grid-mark span:nth-child(1) { background: #f25022; }
.microsoft-brand-mark span:nth-child(2),
.microsoft-grid-mark span:nth-child(2) { background: #7fba00; }
.microsoft-brand-mark span:nth-child(3),
.microsoft-grid-mark span:nth-child(3) { background: #00a4ef; }
.microsoft-brand-mark span:nth-child(4),
.microsoft-grid-mark span:nth-child(4) { background: #ffb900; }

.premium-brand .brand-mark.microsoft-brand-mark,
body.home-shell .premium-brand .brand-mark.microsoft-brand-mark {
    display: grid;
    grid-template-columns: repeat(2, 13px);
    grid-template-rows: repeat(2, 13px);
    gap: 3px;
    width: 46px;
    height: 46px;
    padding: 8px;
    overflow: visible;
    border: 1px solid #cfe0f6;
    border-radius: 10px;
    color: inherit;
    background: #fff;
    box-shadow: 0 12px 24px rgba(16, 24, 40, .08);
}

.premium-brand .brand-mark.microsoft-brand-mark span,
body.home-shell .premium-brand .brand-mark.microsoft-brand-mark span {
    display: block;
    width: 13px;
    height: 13px;
    border-radius: 1px;
    opacity: 1;
}

.premium-brand .brand-mark.microsoft-brand-mark span:nth-child(1),
body.home-shell .premium-brand .brand-mark.microsoft-brand-mark span:nth-child(1) { background: #f25022; }
.premium-brand .brand-mark.microsoft-brand-mark span:nth-child(2),
body.home-shell .premium-brand .brand-mark.microsoft-brand-mark span:nth-child(2) { background: #7fba00; }
.premium-brand .brand-mark.microsoft-brand-mark span:nth-child(3),
body.home-shell .premium-brand .brand-mark.microsoft-brand-mark span:nth-child(3) { background: #00a4ef; }
.premium-brand .brand-mark.microsoft-brand-mark span:nth-child(4),
body.home-shell .premium-brand .brand-mark.microsoft-brand-mark span:nth-child(4) { background: #ffb900; }

.m365vn-hero {
    padding: 92px 0 76px;
    background:
        linear-gradient(135deg, #f7fbff 0%, #fff 46%, #eef6ff 100%);
}

.m365vn-hero::after {
    opacity: .35;
}

.m365-hero-panel {
    border: 1px solid #d7e6fb;
    border-radius: 8px;
    background: #fff;
    box-shadow: 0 28px 68px rgba(16, 24, 40, .12);
    overflow: hidden;
}

.m365-panel-head {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 22px;
    border-bottom: 1px solid #d7e6fb;
    background: linear-gradient(135deg, #eff6ff, #fff);
}

.microsoft-grid-mark {
    display: grid;
    grid-template-columns: repeat(2, 16px);
    grid-template-rows: repeat(2, 16px);
    gap: 4px;
    width: 42px;
    height: 42px;
    padding: 3px;
    flex: 0 0 auto;
}

.m365-panel-head strong,
.m365-panel-head span {
    display: block;
}

.m365-panel-head strong {
    color: #07172d;
    font-size: 1.1rem;
    font-weight: 800;
}

.m365-panel-head span {
    color: #51627a;
    font-size: .92rem;
}

.m365-hero-services {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0;
}

.m365-hero-service {
    display: grid;
    grid-template-columns: 42px minmax(0, 1fr);
    gap: 14px;
    min-height: 176px;
    padding: 22px 18px;
    border-right: 1px solid #e5eefb;
    border-bottom: 1px solid #e5eefb;
}

.m365-hero-service:nth-child(3n) {
    border-right: 0;
}

.m365-hero-service i {
    width: 38px;
    height: 38px;
    display: grid;
    place-items: center;
    border-radius: 8px;
    color: #0f53c7;
    background: #eff6ff;
}

.m365-hero-service strong,
.m365-hero-service span {
    display: block;
}

.m365-hero-service strong {
    color: #07172d;
    font-weight: 780;
    line-height: 1.3;
}

.m365-hero-service span {
    margin-top: 5px;
    color: #51627a;
    font-size: .86rem;
    line-height: 1.58;
}

.compact-service-grid .solution-showcase-card {
    min-height: 100%;
}

.compact-service-card .solution-card-top {
    min-height: 92px;
}

.compact-service-card .solution-showcase-body {
    padding-bottom: 24px;
}

.compact-service-card .solution-showcase-body h3 {
    margin-bottom: 12px;
}

.compact-service-card .solution-description {
    margin-bottom: 0;
}

@media (max-width: 991.98px) {
    .m365-hero-panel {
        margin-top: 8px;
    }

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

    .m365-hero-service:nth-child(3n) {
        border-right: 1px solid #e5eefb;
    }

    .m365-hero-service:nth-child(2n) {
        border-right: 0;
    }
}

@media (max-width: 575.98px) {
    .m365-hero-services {
        grid-template-columns: 1fr;
    }

    .m365-hero-service {
        border-right: 0;
    }
}

body.home-shell .site-header {
    box-shadow: 0 12px 34px rgba(16, 24, 40, .10);
}

body.home-shell .premium-navbar {
    background: rgba(255, 255, 255, .96);
    border-bottom-color: #d7e6fb;
}

body.home-shell .premium-nav-link {
    color: #25344d !important;
}

body.home-shell .premium-nav-link:hover,
body.home-shell .premium-nav-link.active {
    color: #0b63ce !important;
    background: #eaf3ff;
}

body.home-shell .brand-name {
    color: #07172d;
}

body.home-shell .brand-subtitle {
    color: #475569;
}

body.home-shell .microsoft-brand-mark {
    display: grid;
    grid-template-columns: repeat(2, 13px);
    grid-template-rows: repeat(2, 13px);
    gap: 3px;
    width: 46px;
    height: 46px;
    padding: 8px;
    border: 1px solid #dbe8fb;
    border-radius: 10px;
    background: #fff;
    box-shadow: 0 12px 24px rgba(16, 24, 40, .08);
}

body.home-shell .microsoft-brand-mark span:nth-child(1) { background: #f25022; }
body.home-shell .microsoft-brand-mark span:nth-child(2) { background: #7fba00; }
body.home-shell .microsoft-brand-mark span:nth-child(3) { background: #00a4ef; }
body.home-shell .microsoft-brand-mark span:nth-child(4) { background: #ffb900; }

body.home-shell .m365vn-hero,
body.home-shell .cyber-hero.m365vn-hero {
    min-height: auto;
    padding: 88px 0 78px;
    color: #07172d;
    background:
        radial-gradient(circle at 78% 18%, rgba(0, 120, 212, .12), transparent 28%),
        linear-gradient(135deg, #ffffff 0%, #f6fbff 50%, #eaf4ff 100%);
}

body.home-shell .m365vn-hero .cyber-eyebrow {
    border-color: #93c5fd;
    color: #075fb8;
    background: #eaf5ff;
    box-shadow: none;
}

body.home-shell .m365vn-hero .home-hero-title,
body.home-shell .m365vn-hero .home-hero-title span {
    color: #07172d;
    text-shadow: none;
}

body.home-shell .m365vn-hero .home-hero-title .hero-gradient {
    color: #0078d4;
    background: none;
    -webkit-text-fill-color: #0078d4;
}

body.home-shell .m365vn-hero .home-hero-copy {
    max-width: 720px;
    color: #334155;
    font-weight: 500;
    text-shadow: none;
}

body.home-shell .m365vn-hero .btn-hero-primary {
    color: #fff;
    background: #0b63ce;
    border-color: #0b63ce;
    box-shadow: 0 16px 30px rgba(11, 99, 206, .22);
}

body.home-shell .m365vn-hero .btn-hero-secondary {
    color: #0f172a;
    background: #fff;
    border-color: #b7c7dd;
    box-shadow: 0 12px 24px rgba(16, 24, 40, .08);
}

body.home-shell .m365vn-hero .hero-stats {
    border-top-color: #d7e6fb;
}

body.home-shell .m365vn-hero .hero-stats strong {
    color: #0b63ce;
    text-shadow: none;
}

body.home-shell .m365vn-hero .hero-stats span {
    color: #475569;
    text-shadow: none;
}

body.home-shell .m365-hero-panel {
    color: #07172d;
    background: #fff;
}

body.home-shell .m365-hero-service strong {
    color: #07172d;
}

body.home-shell .m365-hero-service span {
    color: #334155;
}

.m365-hero-service .fa-office-365 { color: #d83b01; background: #fff4ed; }
.m365-hero-service .fa-exchange-online { color: #0078d4; background: #eaf5ff; }
.m365-hero-service .fa-onedrive { color: #0369a1; background: #e0f2fe; }
.m365-hero-service .fa-sharepoint { color: #008272; background: #e6fffa; }
.m365-hero-service .fa-teams { color: #6264a7; background: #f0f0ff; }
.m365-hero-service .fa-intune { color: #0f53c7; background: #eff6ff; }
.m365-hero-service .fa-microsoft-defender { color: #166534; background: #dcfce7; }
.m365-hero-service .fa-microsoft-purview { color: #7c3aed; background: #f3e8ff; }

/* Home hero layout repair: keep the app list readable in a fixed 2x3 grid. */
body.home-shell .brand-name,
body.home-shell .premium-brand .brand-name {
    color: #005fb8 !important;
    font-weight: 850;
    letter-spacing: .02em;
}

body.home-shell .m365-hero-panel {
    display: block;
    grid-template-columns: none;
    max-width: 620px;
    padding: 24px 28px;
    height: 100%;
}

body.home-shell .m365-hero-services {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    grid-template-rows: repeat(4, minmax(0, 1fr));
    width: 100%;
    height: 100%;
}

body.home-shell .m365-hero-service {
    min-height: 116px;
    padding: 18px 20px;
    border-right: 1px solid #e5eefb;
    border-bottom: 1px solid #e5eefb;
}

body.home-shell .m365-hero-service:nth-child(3n) {
    border-right: 1px solid #e5eefb;
}

body.home-shell .m365-hero-service:nth-child(2n) {
    border-right: 0;
}

body.home-shell .m365-hero-service:nth-last-child(-n+2) {
    border-bottom: 0;
}

body.home-shell .m365-hero-service strong {
    font-size: .98rem;
    line-height: 1.28;
}

body.home-shell .m365-hero-service span {
    font-size: .86rem;
    line-height: 1.45;
}

body.home-shell.home-nav-scrolled .premium-navbar {
    background: rgba(4, 16, 34, .94);
    border-bottom-color: rgba(177, 208, 255, .16);
    box-shadow: 0 18px 42px rgba(0, 0, 0, .26);
}

body.home-shell.home-nav-scrolled .premium-nav-link {
    color: #e8f2ff !important;
}

body.home-shell.home-nav-scrolled .premium-nav-link:hover,
body.home-shell.home-nav-scrolled .premium-nav-link.active {
    color: #06152b !important;
    background: #eaf3ff;
}

body.home-shell.home-nav-scrolled .brand-subtitle {
    color: rgba(211, 228, 255, .82);
}

body.home-shell .m365vn-hero .row {
    align-items: stretch !important;
}

body.home-shell .m365-hero-copy-col,
body.home-shell .m365-hero-panel-col {
    display: flex;
    flex-direction: column;
}

body.home-shell .section-intro-wide {
    width: 100%;
    max-width: none;
    padding: 28px 32px;
    border: 1px solid #d7e6fb;
    border-radius: 8px;
    background: linear-gradient(135deg, #ffffff 0%, #f8fbff 100%);
    box-shadow: 0 18px 42px rgba(16, 24, 40, .06);
}

body.home-shell .compact-service-grid {
    --bs-gutter-x: 1.25rem;
    --bs-gutter-y: 1.25rem;
}

body.home-shell .compact-service-card .solution-card-top {
    min-height: 86px;
    padding: 20px;
    background: linear-gradient(135deg, #f7fbff 0%, #eaf3ff 100%);
}

body.home-shell .compact-service-card .solution-brand-icon {
    width: 48px;
    height: 48px;
    border: 0;
    color: #fff;
    box-shadow: 0 14px 26px rgba(16, 24, 40, .14);
}

body.home-shell .compact-service-grid > div:nth-child(8n+1) .solution-brand-icon { background: #0078d4; }
body.home-shell .compact-service-grid > div:nth-child(8n+2) .solution-brand-icon { background: #4f46e5; }
body.home-shell .compact-service-grid > div:nth-child(8n+3) .solution-brand-icon { background: #0f766e; }
body.home-shell .compact-service-grid > div:nth-child(8n+4) .solution-brand-icon { background: #d83b01; }
body.home-shell .compact-service-grid > div:nth-child(8n+5) .solution-brand-icon { background: #dc2626; }
body.home-shell .compact-service-grid > div:nth-child(8n+6) .solution-brand-icon { background: #ca8a04; }
body.home-shell .compact-service-grid > div:nth-child(8n+7) .solution-brand-icon { background: #16a34a; }
body.home-shell .compact-service-grid > div:nth-child(8n+8) .solution-brand-icon { background: #0369a1; }

@media (max-width: 575.98px) {
    body.home-shell .m365-hero-panel {
        padding: 16px;
    }

    body.home-shell .m365-hero-services {
        grid-template-columns: 1fr;
        grid-template-rows: auto;
    }

    body.home-shell .m365-hero-service,
    body.home-shell .m365-hero-service:nth-child(2n),
    body.home-shell .m365-hero-service:nth-child(3n) {
        border-right: 0;
    }

    body.home-shell .m365-hero-service:nth-last-child(2) {
        border-bottom: 1px solid #e5eefb;
    }
}
