:root {
    --iis-blue: #2f4f9f;
    --iis-blue-2: #4f83c9;
    --iis-sky: #6aaed6;
    --iis-green: #17a86b;
    --iis-red: #c5253a;
    --ink: #0f172a;
    --text: #334155;
    --muted: #64748b;
    --line: #e2e8f0;
    --soft: #f6f9fc;
    --surface: #ffffff;
    --surface-2: #fbfdff;
    --glow-blue: rgba(47, 79, 159, .10);
    --glow-sky: rgba(106, 174, 214, .12);
    --white: #ffffff;
}

html {
    scroll-behavior: smooth;
}

body {
    font-family: "Poppins", sans-serif;
    color: var(--ink);
    background:
        repeating-linear-gradient(0deg, rgba(47, 79, 159, .035) 0 1px, transparent 1px 34px),
        radial-gradient(circle at 8% 8%, rgba(106, 174, 214, .10), transparent 24%),
        radial-gradient(circle at 92% 0%, rgba(47, 79, 159, .08), transparent 22%),
        linear-gradient(180deg, #ffffff 0%, #f8fbff 42%, #ffffff 100%);
    text-rendering: optimizeLegibility;
}

h1, h2, h3, h4, h5, h6,
.h1, .h2, .h3, .h4, .h5, .h6 {
    font-family: "Montserrat", sans-serif;
    color: var(--ink);
    font-weight: 800;
    letter-spacing: 0;
}

p {
    color: var(--muted);
    line-height: 1.78;
}

a {
    text-decoration: none;
}

.btn {
    border-radius: 12px;
    padding: 12px 22px;
    font-weight: 800;
    letter-spacing: 0;
    transform: translateY(0);
    transition: transform .22s ease, box-shadow .22s ease, background .22s ease, border-color .22s ease;
}

.btn-primary {
    background: linear-gradient(135deg, #2f4f9f, #5f90cf);
    border-color: transparent;
    box-shadow: 0 14px 30px rgba(47, 79, 159, .16);
}

.btn-primary:hover {
    background: linear-gradient(135deg, #294684, #4f7fba);
    color: #fff;
    transform: translateY(-2px);
    box-shadow: 0 18px 38px rgba(47, 79, 159, .22);
}

.btn-outline-dark {
    border-color: #cbd5e1;
    color: var(--ink);
    background: #fff;
}

.btn-outline-dark:hover {
    background: #f1f5f9;
    color: var(--ink);
}

.site-header {
    position: sticky;
    top: 0;
    z-index: 1000;
    background: rgba(255, 255, 255, .88);
    backdrop-filter: blur(22px);
    border-bottom: 1px solid rgba(226, 232, 240, .9);
    box-shadow: 0 10px 28px rgba(15, 23, 42, .045);
}

.site-header .navbar,
.site-header .navbar.sticky-top {
    position: static !important;
    background: transparent !important;
    box-shadow: none !important;
    padding: 12px 0;
}

.site-header .navbar-brand {
    display: inline-flex;
    align-items: center;
}

.site-header .navbar-brand img {
    max-height: 50px;
    width: auto;
}

.site-header .navbar-light .navbar-nav .nav-link {
    padding: 14px 0;
    margin-right: 30px;
    color: #25324b;
    font-size: 14px;
    font-weight: 800;
}

.site-header .navbar-light .navbar-nav .nav-link:hover,
.site-header .navbar-light .navbar-nav .nav-link.active {
    color: var(--iis-blue);
}

.site-header .navbar-light .navbar-nav .nav-link::before,
.site-header .navbar-light .navbar-nav .nav-link::after {
    display: none !important;
}

.site-header .dropdown-menu {
    display: none;
    visibility: visible;
    opacity: 1;
    transform: none;
    min-width: 210px;
    padding: 8px;
    border: 1px solid var(--line);
    border-radius: 8px;
    box-shadow: 0 22px 60px rgba(16, 24, 40, .12);
}

.site-header .dropdown:hover .dropdown-menu,
.site-header .dropdown-menu.show {
    display: block;
}

.site-header .dropdown-item {
    border-radius: 6px;
    padding: 11px 13px;
    color: #26324a;
    font-weight: 800;
}

.site-header .dropdown-item:hover,
.site-header .dropdown-item.active {
    background: #eef4ff;
    color: var(--iis-blue);
}

.hero-section {
    position: relative;
    overflow: hidden;
    padding: 96px 0 78px;
    background:
        repeating-linear-gradient(0deg, rgba(47, 79, 159, .04) 0 1px, transparent 1px 36px),
        linear-gradient(90deg, rgba(47, 79, 159, .032) 1px, transparent 1px),
        linear-gradient(180deg, #fbfdff 0%, #f4f8fc 100%);
    background-size: 44px 44px, auto;
}

.home-hero::before,
.biz-hero::before,
.cyber-hero::before {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    background:
        radial-gradient(circle at 12% 18%, rgba(23, 168, 107, .12), transparent 24%),
        radial-gradient(circle at 86% 12%, rgba(106, 174, 214, .13), transparent 24%),
        linear-gradient(135deg, rgba(255,255,255,0) 0%, rgba(255,255,255,.6) 100%);
}

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

.hero-section h1 {
    max-width: 650px;
    margin: 18px 0 22px;
    font-size: clamp(32px, 2.2vw, 38px);
    line-height: 1.3;
}

.lead {
    max-width: 650px;
    color: #475569;
    font-size: 17.5px;
}

.eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    color: var(--iis-blue);
    font-size: 12px;
    font-weight: 900;
    letter-spacing: .04em;
    text-transform: uppercase;
}

.eyebrow::before {
    content: "";
    width: 32px;
    height: 2px;
    border-radius: 999px;
    background: linear-gradient(90deg, #c86b73, #69b88f, var(--iis-sky));
}

.hero-actions,
.trust-row,
.feature-pills {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    align-items: center;
    margin-top: 28px;
}

.trust-row span,
.feature-pills span {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 9px 12px;
    background: rgba(255,255,255,.92);
    border: 1px solid var(--line);
    border-radius: 12px;
    color: #344054;
    font-size: 14px;
    font-weight: 800;
}

.hero-image-frame {
    position: relative;
    overflow: hidden;
    padding: 28px;
    border: 1px solid rgba(226,232,240,.9);
    border-radius: 26px;
    background:
        linear-gradient(135deg, rgba(255,255,255,.98), rgba(241,247,255,.92));
    box-shadow: 0 28px 70px rgba(15, 23, 42, .12);
}

.hero-image-frame::before {
    content: "";
    position: absolute;
    inset: -40% -15% auto auto;
    width: 260px;
    height: 260px;
    border-radius: 50%;
    background: radial-gradient(circle, var(--glow-sky), transparent 65%);
}

.hero-image-frame img {
    position: relative;
    z-index: 1;
    width: 100%;
    max-height: 440px;
    object-fit: contain;
    filter: drop-shadow(0 22px 32px rgba(15, 23, 42, .12));
}

.logo-hero-frame img {
    max-height: 260px;
}

.enterprise-visual,
.dashboard-card,
.phone-mockup {
    position: relative;
    border: 1px solid rgba(207, 216, 228, .9);
    box-shadow: 0 28px 70px rgba(16, 24, 40, .14);
}

.enterprise-visual {
    padding: 18px;
    border-radius: 18px;
    background: rgba(255,255,255,.86);
    backdrop-filter: blur(14px);
}

.visual-topbar {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 12px 14px;
    border: 1px solid var(--line);
    border-radius: 10px;
    background: #fff;
}

.visual-topbar span {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: var(--iis-red);
}

.visual-topbar span:nth-child(2) {
    background: var(--iis-green);
}

.visual-topbar span:nth-child(3) {
    background: var(--iis-sky);
}

.visual-topbar strong {
    margin-left: auto;
    color: #475467;
    font-size: 13px;
}

.visual-grid {
    display: grid;
    grid-template-columns: 1.25fr 1fr;
    gap: 14px;
    margin-top: 14px;
}

.visual-main,
.visual-card {
    border: 1px solid var(--line);
    border-radius: 12px;
    background: #fff;
}

.visual-main {
    grid-row: span 3;
    padding: 28px;
    min-height: 370px;
}

.visual-main small,
.visual-card span {
    display: block;
    color: var(--muted);
    font-weight: 800;
}

.visual-main strong {
    display: block;
    margin: 18px 0 28px;
    color: var(--iis-blue);
    font-size: 70px;
    line-height: 1;
}

.bar-row {
    height: 12px;
    margin-top: 18px;
    overflow: hidden;
    border-radius: 999px;
    background: #eef2f7;
}

.bar-row span {
    display: block;
    height: 100%;
    border-radius: inherit;
    background: linear-gradient(90deg, #4d70b5, #79b8d8);
}

.visual-card {
    padding: 22px;
}

.visual-card i {
    display: inline-flex;
    width: 42px;
    height: 42px;
    align-items: center;
    justify-content: center;
    margin-bottom: 16px;
    border-radius: 10px;
    color: #fff;
}

.visual-card strong {
    display: block;
    margin-bottom: 4px;
}

.visual-card.red i { background: var(--iis-red); }
.visual-card.green i { background: var(--iis-green); }
.visual-card.blue i { background: var(--iis-blue); }

.section-pad {
    padding: 82px 0;
}

main > .section-pad {
    position: relative;
    overflow: hidden;
}

main > .section-pad::before {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    background:
        repeating-linear-gradient(0deg, rgba(47, 79, 159, .032) 0 1px, transparent 1px 38px),
        radial-gradient(circle at 8% 18%, rgba(106, 174, 214, .07), transparent 24%),
        radial-gradient(circle at 92% 82%, rgba(47, 79, 159, .055), transparent 24%);
    opacity: .85;
}

main > .section-pad > .container {
    position: relative;
    z-index: 1;
}

.soft-band {
    background:
        repeating-linear-gradient(0deg, rgba(47, 79, 159, .04) 0 1px, transparent 1px 34px),
        linear-gradient(90deg, rgba(47, 79, 159, .025) 1px, transparent 1px),
        linear-gradient(180deg, #f8fbff 0%, #eef5fb 100%);
    background-size: 42px 42px, auto;
}

.section-heading {
    max-width: 820px;
    margin: 0 auto 44px;
}

.section-heading h2,
.cta-inner h2 {
    margin-top: 14px;
    font-size: clamp(31px, 4vw, 50px);
    line-height: 1.13;
}

.product-card,
.cert-card,
.value-tile,
.rule-board article,
.timeline-grid div,
.compare-grid div {
    height: 100%;
    overflow: hidden;
    background: #fff;
    border: 1px solid var(--line);
    border-radius: 16px;
    box-shadow: 0 14px 36px rgba(15, 23, 42, .06);
    transition: transform .28s ease, box-shadow .28s ease, border-color .28s ease;
}

.product-card:hover,
.value-tile:hover,
.rule-board article:hover {
    transform: translateY(-4px);
    border-color: #ccd8e7;
    box-shadow: 0 24px 60px rgba(15, 23, 42, .11);
}

.product-preview {
    position: relative;
    min-height: 260px;
    padding: 28px;
    overflow: hidden;
    background:
        radial-gradient(circle at 15% 20%, rgba(14, 165, 216, .13), transparent 34%),
        linear-gradient(135deg, #f8fbff, #eef4fb);
}

.erp-preview::before,
.cyber-preview::before {
    content: "";
    position: absolute;
    inset: auto -20% -45% -20%;
    height: 220px;
    background: radial-gradient(circle, rgba(46,49,146,.18), transparent 60%);
}

.mini-window {
    display: flex;
    gap: 7px;
    width: 75%;
    padding: 14px;
    border: 1px solid var(--line);
    border-radius: 10px;
    background: #fff;
}

.mini-window div {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: var(--iis-red);
}

.mini-window div:nth-child(2) { background: var(--iis-green); }
.mini-window div:nth-child(3) { background: var(--iis-sky); }

.preview-lines {
    position: relative;
    margin-top: 28px;
}

.preview-lines span {
    display: block;
    height: 12px;
    margin: 14px 0;
    border-radius: 999px;
    background: #dbe5f2;
}

.preview-lines span:nth-child(1) { width: 92%; }
.preview-lines span:nth-child(2) { width: 74%; }
.preview-lines span:nth-child(3) { width: 84%; }

.preview-kpis {
    position: relative;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 10px;
    margin-top: 26px;
}

.preview-kpis strong {
    padding: 16px 8px;
    border-radius: 8px;
    text-align: center;
    color: var(--iis-blue);
    background: #fff;
    border: 1px solid var(--line);
}

.cyber-preview {
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, #fff8f8, #eefbf5);
}

.shield-core {
    position: relative;
    z-index: 2;
    display: flex;
    width: 122px;
    height: 122px;
    align-items: center;
    justify-content: center;
    border-radius: 36px;
    color: #fff;
    font-size: 46px;
    background: linear-gradient(135deg, var(--iis-red), var(--iis-blue));
    box-shadow: 0 24px 48px rgba(46,49,146,.22);
}

.signal-line {
    position: absolute;
    border: 1px solid rgba(46,49,146,.16);
    border-radius: 50%;
}

.signal-line.one { width: 180px; height: 180px; }
.signal-line.two { width: 250px; height: 250px; }
.signal-line.three { width: 320px; height: 320px; }

.product-body {
    padding: 30px;
}

.icon-badge,
.value-tile i {
    display: inline-flex;
    width: 50px;
    height: 50px;
    align-items: center;
    justify-content: center;
    margin-bottom: 18px;
    border-radius: 14px;
    color: #fff;
    background: linear-gradient(135deg, #2f4f9f, #5f90cf);
}

.accent-card .icon-badge {
    background: var(--iis-red);
}

.product-body h3 {
    margin-bottom: 12px;
    font-size: 28px;
}

.product-body a {
    color: var(--iis-blue);
    font-weight: 900;
}

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

.value-tile {
    padding: 26px;
}

.value-tile h4 {
    font-size: 19px;
}

.cert-card {
    padding: 24px;
    text-align: center;
}

.cert-card img {
    width: 100%;
    height: 300px;
    object-fit: contain;
}

.cta-band {
    padding: 72px 0;
    background: linear-gradient(135deg, #233b7d 0%, #3f68aa 58%, #6aaed6 100%);
}

.cta-inner {
    display: flex;
    gap: 28px;
    align-items: center;
    justify-content: space-between;
}

.cta-inner h2,
.cta-inner .eyebrow,
.dark-panel h2,
.dark-panel h4,
.dark-panel .eyebrow {
    color: #fff;
}

.cta-inner .eyebrow::before,
.dark-panel .eyebrow::before {
    background: #fff;
}

.footer-modern {
    padding: 56px 0 20px;
    background:
        radial-gradient(circle at 10% 0%, rgba(14, 165, 216, .12), transparent 30%),
        linear-gradient(180deg, #07111f 0%, #050b14 100%);
    color: #d7e0ea;
}

.footer-modern p,
.footer-modern a {
    color: #b9c6d4;
}

.footer-modern a {
    display: block;
    margin-bottom: 8px;
}

.footer-modern h4 {
    color: #fff;
    font-size: 18px;
}

.footer-logo {
    max-width: 260px;
    padding: 10px;
    margin-bottom: 18px;
    border-radius: 8px;
    background: #fff;
}

.footer-bottom {
    padding-top: 18px;
    margin-top: 34px;
    border-top: 1px solid rgba(255,255,255,.12);
    color: #94a3b8;
}

.phone-mockup {
    max-width: 400px;
    margin: 0 auto;
    padding: 14px;
    border-radius: 34px;
    background: #101828;
}

.phone-screen {
    min-height: 590px;
    padding: 38px 24px;
    border-radius: 24px;
    text-align: center;
    background: linear-gradient(180deg, #fbfdff, #eef6ff);
}

.scan-ring {
    display: inline-flex;
    width: 118px;
    height: 118px;
    align-items: center;
    justify-content: center;
    margin-bottom: 28px;
    border-radius: 32px;
    color: #fff;
    font-size: 42px;
    background: linear-gradient(135deg, var(--iis-blue), var(--iis-green));
    box-shadow: 0 0 0 12px rgba(46,49,146,.07);
}

.call-row {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    padding: 14px;
    margin-top: 12px;
    background: #fff;
    border: 1px solid var(--line);
    border-radius: 8px;
}

.call-row strong {
    color: var(--iis-red);
}

.call-row .allowed {
    color: var(--iis-green);
}

.dashboard-card {
    overflow: hidden;
    border-radius: 18px;
    background: #fff;
}

.dashboard-card img,
.rounded-visual {
    display: block;
    width: 100%;
    height: 500px;
    object-fit: cover;
}

.metric-grid {
    position: absolute;
    right: 18px;
    bottom: 18px;
    left: 18px;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 10px;
}

.metric-grid div {
    padding: 14px;
    border: 1px solid rgba(255,255,255,.7);
    border-radius: 8px;
    background: rgba(255,255,255,.9);
    backdrop-filter: blur(12px);
}

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

.timeline-grid,
.module-grid,
.compare-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 18px;
}

.timeline-grid div {
    padding: 24px;
}

.timeline-grid strong,
.insight-strip strong {
    display: inline-flex;
    width: 40px;
    height: 40px;
    align-items: center;
    justify-content: center;
    margin-bottom: 16px;
    border-radius: 10px;
    background: var(--iis-green);
    color: #fff;
}

.rule-board,
.insight-strip {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 20px;
}

.rule-board article {
    padding: 28px;
}

.rule-board i {
    margin-bottom: 18px;
    color: var(--iis-blue);
    font-size: 32px;
}

.rule-board span {
    display: inline-block;
    padding: 7px 10px;
    margin: 4px;
    border-radius: 999px;
    background: #eef4ff;
    color: #24508c;
    font-size: 13px;
    font-weight: 800;
}

.dark-panel {
    position: relative;
    overflow: hidden;
    background:
        radial-gradient(circle at 12% 10%, rgba(106, 174, 214, .16), transparent 28%),
        radial-gradient(circle at 88% 85%, rgba(23, 168, 107, .10), transparent 24%),
        linear-gradient(135deg, #0f172a 0%, #172554 58%, #102a43 100%);
}

.dark-panel::before {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    background:
        linear-gradient(90deg, rgba(255,255,255,.045) 1px, transparent 1px),
        linear-gradient(180deg, rgba(255,255,255,.035) 1px, transparent 1px);
    background-size: 46px 46px;
    opacity: .5;
}

.dark-panel .container {
    position: relative;
    z-index: 1;
}

.dark-panel p {
    color: #cbd5e1;
}

.insight-strip div {
    padding: 24px;
    border: 1px solid rgba(255,255,255,.14);
    border-radius: 10px;
    background: rgba(255,255,255,.06);
}

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

.module-grid div {
    min-height: 120px;
    padding: 20px;
    border: 1px solid var(--line);
    border-radius: 10px;
    background: #fff;
    color: #26324a;
    font-weight: 800;
}

.module-grid-enhanced div {
    min-height: 170px;
}

.module-grid-enhanced strong,
.module-grid-enhanced span {
    display: block;
}

.module-grid-enhanced strong {
    margin-bottom: 8px;
    color: var(--ink);
    font-family: "Montserrat", sans-serif;
    font-size: 16px;
}

.module-grid-enhanced span {
    color: var(--muted);
    font-size: 13.5px;
    font-weight: 500;
    line-height: 1.65;
}

.mode-grid {
    margin-top: 34px;
    grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
}

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

.faq-grid div {
    position: relative;
    overflow: hidden;
    padding: 28px 28px 28px 74px;
    border: 1px solid rgba(226, 232, 240, .95);
    border-radius: 18px;
    background:
        linear-gradient(180deg, rgba(255,255,255,.98), rgba(248,251,255,.96));
    box-shadow: 0 16px 42px rgba(15, 23, 42, .06);
    transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}

.faq-grid div::before {
    content: "Q";
    position: absolute;
    top: 26px;
    left: 24px;
    width: 34px;
    height: 34px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 10px;
    color: #fff;
    background: linear-gradient(135deg, #2f4f9f, #5f90cf);
    font-family: "Montserrat", sans-serif;
    font-size: 14px;
    font-weight: 800;
    box-shadow: 0 10px 24px rgba(47, 79, 159, .18);
}

.faq-grid div::after {
    content: "";
    position: absolute;
    right: -34px;
    top: -34px;
    width: 100px;
    height: 100px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(106, 174, 214, .16), transparent 68%);
    pointer-events: none;
}

.faq-grid div:hover {
    transform: translateY(-4px);
    border-color: rgba(95, 144, 207, .42);
    box-shadow: 0 24px 58px rgba(15, 23, 42, .1);
}

.faq-grid h4 {
    margin-bottom: 12px;
    color: #172554;
    font-size: 17px;
    line-height: 1.45;
}

.faq-grid p {
    margin-bottom: 0;
    color: #5f6f85;
    font-size: 14.5px;
    line-height: 1.75;
}

.home-hero {
    background:
        repeating-linear-gradient(0deg, rgba(47, 79, 159, .035) 0 1px, transparent 1px 36px),
        radial-gradient(circle at 12% 18%, rgba(95, 144, 207, .13), transparent 24%),
        radial-gradient(circle at 86% 10%, rgba(23,168,107,.09), transparent 24%),
        linear-gradient(180deg, #ffffff, #f5f8fc);
}

.biz-hero {
    background:
        repeating-linear-gradient(0deg, rgba(47, 79, 159, .035) 0 1px, transparent 1px 36px),
        radial-gradient(circle at 10% 18%, rgba(95, 144, 207, .16), transparent 25%),
        radial-gradient(circle at 88% 14%, rgba(23,168,107,.10), transparent 23%),
        linear-gradient(180deg, #ffffff, #f4f8fc);
}

.cyber-hero {
    background:
        repeating-linear-gradient(0deg, rgba(47, 79, 159, .035) 0 1px, transparent 1px 36px),
        radial-gradient(circle at 16% 16%, rgba(197,37,58,.08), transparent 24%),
        radial-gradient(circle at 82% 12%, rgba(106,174,214,.18), transparent 25%),
        linear-gradient(180deg, #ffffff, #f5faff);
}

.module-grid i {
    display: block;
    margin-bottom: 12px;
    color: var(--iis-blue);
    font-size: 23px;
}

.compare-grid {
    margin-top: 20px;
}

.compare-grid div {
    padding: 22px;
}

.rounded-visual {
    border-radius: 10px;
    box-shadow: 0 24px 70px rgba(16,24,40,.12);
}

.product-media img {
    width: 100%;
    height: 260px;
    object-fit: cover;
}

.outcome-strip {
    position: relative;
    z-index: 2;
    margin-top: -28px;
    padding-bottom: 42px;
}

.outcome-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    overflow: hidden;
    border: 1px solid var(--line);
    border-radius: 18px;
    background: rgba(255,255,255,.94);
    box-shadow: 0 22px 60px rgba(15,23,42,.09);
    backdrop-filter: blur(16px);
}

.outcome-grid div {
    padding: 26px;
    border-right: 1px solid var(--line);
}

.outcome-grid div:last-child {
    border-right: 0;
}

.outcome-grid span {
    display: inline-block;
    margin-bottom: 12px;
    color: var(--iis-sky);
    font-weight: 900;
}

.outcome-grid strong {
    display: block;
    margin-bottom: 8px;
    color: var(--ink);
    font-family: "Montserrat", sans-serif;
    font-size: 17px;
}

.outcome-grid p {
    margin: 0;
    font-size: 14px;
}

.inner-hero {
    position: relative;
    overflow: hidden;
    padding: 82px 0 64px;
    background:
        linear-gradient(90deg, rgba(46, 49, 146, .04) 1px, transparent 1px),
        linear-gradient(180deg, #fbfcff 0%, #f5f8fc 100%);
    background-size: 42px 42px, auto;
}

.inner-hero::before {
    content: "";
    position: absolute;
    inset: 0;
    background:
        radial-gradient(circle at 12% 10%, rgba(11, 191, 104, .12), transparent 23%),
        radial-gradient(circle at 86% 12%, rgba(46, 143, 218, .14), transparent 24%);
}

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

.inner-hero-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.4fr) minmax(280px, .65fr);
    gap: 34px;
    align-items: center;
}

.inner-hero h1 {
    max-width: 760px;
    margin: 16px 0;
    font-size: clamp(32px, 4vw, 50px);
    line-height: 1.13;
}

.inner-hero p {
    max-width: 700px;
    font-size: 17px;
}

.hero-stat-panel {
    display: grid;
    gap: 12px;
    padding: 18px;
    border: 1px solid var(--line);
    border-radius: 14px;
    background: rgba(255,255,255,.86);
    box-shadow: 0 24px 60px rgba(16,24,40,.1);
    backdrop-filter: blur(14px);
}

.hero-stat-panel div {
    padding: 16px;
    border: 1px solid var(--line);
    border-radius: 10px;
    background: #fff;
}

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

.hero-stat-panel strong {
    color: var(--iis-blue);
    font-size: 28px;
    line-height: 1.1;
}

.hero-stat-panel span {
    color: var(--muted);
    font-weight: 700;
}

.about-panel {
    display: grid;
    gap: 16px;
}

.about-panel div,
.leader-card,
.contact-form,
.contact-stack a,
.contact-stack div {
    border: 1px solid var(--line);
    border-radius: 12px;
    background: #fff;
    box-shadow: 0 14px 36px rgba(16, 24, 40, .06);
}

.about-panel div {
    padding: 24px;
}

.about-panel i {
    display: inline-flex;
    width: 46px;
    height: 46px;
    align-items: center;
    justify-content: center;
    margin-bottom: 14px;
    border-radius: 10px;
    color: #fff;
    background: var(--iis-blue);
}

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

.leader-card {
    overflow: hidden;
}

.leader-card img {
    width: 100%;
    height: 330px;
    object-fit: cover;
    object-position: center top;
    background: #f1f5f9;
}

.leader-card div {
    padding: 26px;
}

.leader-card span {
    display: inline-block;
    margin-bottom: 8px;
    color: var(--iis-blue);
    font-size: 12px;
    font-weight: 900;
    letter-spacing: .04em;
    text-transform: uppercase;
}

.leader-card h3 {
    font-size: 24px;
}

.contact-stack {
    display: grid;
    gap: 14px;
    margin-top: 24px;
}

.contact-stack a,
.contact-stack div {
    display: flex;
    gap: 14px;
    align-items: flex-start;
    padding: 16px;
    color: var(--text);
}

.contact-stack i {
    display: inline-flex;
    width: 40px;
    height: 40px;
    flex: 0 0 40px;
    align-items: center;
    justify-content: center;
    border-radius: 10px;
    color: #fff;
    background: var(--iis-blue);
}

.contact-stack strong,
.contact-stack span span {
    display: block;
}

.contact-stack strong {
    color: var(--ink);
}

.contact-form {
    padding: 28px;
}

.contact-form label {
    display: block;
    margin-bottom: 7px;
    color: var(--ink);
    font-size: 13px;
    font-weight: 800;
}

.contact-form input,
.contact-form select,
.contact-form textarea {
    width: 100%;
    border: 1px solid #d7deea;
    border-radius: 8px;
    padding: 13px 14px;
    color: var(--ink);
    background: #fbfcff;
    outline: none;
    transition: border-color .2s ease, box-shadow .2s ease, background .2s ease;
}

.contact-form input:focus,
.contact-form select:focus,
.contact-form textarea:focus {
    border-color: var(--iis-blue);
    background: #fff;
    box-shadow: 0 0 0 4px rgba(46,49,146,.08);
}

body > .container-fluid.text-light {
    color: var(--text) !important;
    background:
        linear-gradient(90deg, rgba(46, 49, 146, .035) 1px, transparent 1px),
        linear-gradient(180deg, #fbfcff 0%, #f7f9fc 100%);
    background-size: 42px 42px, auto;
    padding: 60px 0;
}

body > .container-fluid.text-light .container {
    max-width: 980px;
    padding: 42px;
    border: 1px solid var(--line);
    border-radius: 14px;
    background: #fff;
    box-shadow: 0 20px 52px rgba(16,24,40,.08);
}

body > .container-fluid.text-light h2 {
    margin-bottom: 26px !important;
    color: var(--ink);
    font-size: clamp(28px, 3vw, 40px);
    line-height: 1.2;
}

body > .container-fluid.text-light h4 {
    margin-top: 28px;
    margin-bottom: 10px;
    color: var(--iis-blue);
    font-size: 18px;
}

body > .container-fluid.text-light p,
body > .container-fluid.text-light li {
    color: #475467 !important;
    line-height: 1.75;
}

body > .container-fluid.text-light a {
    color: var(--iis-blue);
    font-weight: 800;
}

.service-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 18px;
}

.service-grid div,
.compact-list div {
    background: #fff;
    border: 1px solid var(--line);
    border-radius: 10px;
    padding: 24px;
    box-shadow: 0 12px 30px rgba(16, 24, 40, .05);
}

.service-grid i {
    width: 44px;
    height: 44px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    background: var(--iis-blue);
    border-radius: 10px;
    margin-bottom: 16px;
}

.compact-list {
    display: grid;
    gap: 14px;
}

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

.compact-list strong {
    color: var(--ink);
    margin-bottom: 5px;
}

.compact-list span {
    color: var(--muted);
}

/* Final typography pass: calmer scale for a cleaner corporate feel. */
body {
    font-size: 15.5px;
}

.hero-section {
    padding: 40px 0 72px;
}

.hero-section h1 { 
    max-width: 650px;
    font-size: clamp(32px, 2.2vw, 38px);
    line-height: 1.3;
}

.lead {
    font-size: 17px;
}

.section-pad {
    padding: 70px 0;
}

.section-heading {
    max-width: 760px;
    margin-bottom: 34px;
}

.section-heading h2,
.cta-inner h2 {
    font-size: clamp(27px, 3vw, 38px);
    line-height: 1.2;
}

.product-body h3 {
    font-size: 24px;
}

.value-tile h4,
.service-grid h4,
.rule-board h3,
.timeline-grid h4,
.insight-strip h4,
.cert-card h3 {
    font-size: 18px;
}

.value-tile,
.service-grid div,
.product-body,
.rule-board article,
.timeline-grid div,
.insight-strip div,
.compare-grid div {
    padding: 22px;
}

.visual-main {
    min-height: 310px;
}

.visual-main strong {
    font-size: 54px;
}

.product-preview {
    min-height: 230px;
}

.footer-modern {
    font-size: 14px;
}

.footer-modern p {
    line-height: 1.55;
}

@media (max-width: 991.98px) {
    .site-header .navbar-light .navbar-nav .nav-link {
        margin-right: 0;
        padding: 10px 0;
    }

    .site-header .dropdown:hover .dropdown-menu {
        display: none;
    }

    .site-header .dropdown-menu.show {
        display: block;
    }

    .hero-section {
        padding: 76px 0 62px;
    }

    .visual-grid,
    .inner-hero-grid,
    .leader-grid,
    .outcome-grid,
    .value-grid,
    .service-grid,
    .timeline-grid,
    .rule-board,
    .insight-strip,
    .module-grid,
    .faq-grid,
    .compare-grid {
        grid-template-columns: 1fr;
    }

    .outcome-grid div {
        border-right: 0;
        border-bottom: 1px solid var(--line);
    }

    .outcome-grid div:last-child {
        border-bottom: 0;
    }

    .visual-main {
        min-height: 270px;
    }

    .dashboard-card img,
    .rounded-visual {
        height: 360px;
    }

    .cta-inner {
        align-items: flex-start;
        flex-direction: column;
    }
}

@media (max-width: 575.98px) {
    .site-header .navbar-brand img {
        max-height: 40px;
    }

    .hero-section h1 {
        font-size: 31px;
    }

    .hero-image-frame {
        padding: 18px;
        border-radius: 18px;
    }

    .outcome-strip {
        margin-top: 0;
        padding: 28px 0 0;
    }

    .faq-grid div {
        padding: 24px 22px 24px 68px;
    }

    .faq-grid div::before {
        left: 20px;
        top: 24px;
    }

    .lead {
        font-size: 17px;
    }

    .section-pad {
        padding: 64px 0;
    }

    .product-preview {
        min-height: 230px;
    }

    .phone-screen {
        min-height: 520px;
    }

    .metric-grid {
        position: static;
        grid-template-columns: 1fr;
        padding: 14px;
    }
}

.product-preview.logo-preview {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 250px;
    padding: 34px;
}

.product-logo-img {
    position: relative;
    z-index: 2;
    display: block;
    max-width: min(78%, 360px);
    max-height: 150px;
    object-fit: contain;
    filter: drop-shadow(0 18px 28px rgba(16, 24, 40, .12));
}

.cyber-logo-lockup {
    position: relative;
    z-index: 2;
    display: grid;
    justify-items: center;
    gap: 10px;
    text-align: center;
}

.cyber-logo-lockup .shield-core {
    width: 96px;
    height: 96px;
    border-radius: 28px;
    font-size: 36px;
}

.cyber-logo-lockup strong {
    color: var(--ink);
    font-size: 28px;
    line-height: 1.1;
}

.cyber-logo-lockup span {
    color: var(--muted);
    font-weight: 800;
}

.product-card,
.cert-card,
.value-tile,
.service-grid div,
.compact-list div,
.module-grid div,
.rule-board article,
.timeline-grid div,
.compare-grid div,
.faq-grid div,
.contact-form,
.contact-stack a,
.contact-stack div,
.about-panel div,
.leader-card {
    background-color: rgba(255, 255, 255, .94);
    backdrop-filter: blur(10px);
}

/* Final premium polish layer */
::selection {
    color: #ffffff;
    background: #3f68aa;
}

a:focus-visible,
button:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible {
    outline: 3px solid rgba(95, 144, 207, .32);
    outline-offset: 3px;
}

.site-header .btn {
    padding: 10px 18px;
    font-size: 13px;
}

.hero-section::after,
.inner-hero::after {
    content: "";
    position: absolute;
    left: 50%;
    bottom: 0;
    width: min(1120px, calc(100% - 32px));
    height: 1px;
    transform: translateX(-50%);
    background: linear-gradient(90deg, transparent, rgba(95, 144, 207, .32), transparent);
    pointer-events: none;
}

.product-card,
.value-tile,
.service-grid div,
.module-grid div,
.rule-board article,
.faq-grid div,
.contact-form,
.leader-card {
    transition: transform .28s ease, box-shadow .28s ease, border-color .28s ease, background .28s ease;
}

.product-card:hover,
.value-tile:hover,
.service-grid div:hover,
.module-grid div:hover,
.rule-board article:hover,
.faq-grid div:hover,
.contact-form:hover,
.leader-card:hover {
    transform: translateY(-4px);
    border-color: rgba(95, 144, 207, .42);
    box-shadow: 0 24px 60px rgba(15, 23, 42, .105);
}

.value-tile,
.service-grid div,
.module-grid div {
    position: relative;
    overflow: hidden;
}

.value-tile::after,
.service-grid div::after,
.module-grid div::after {
    content: "";
    position: absolute;
    inset: 0 auto 0 0;
    width: 3px;
    background: linear-gradient(180deg, #5f90cf, #9dccdf);
    opacity: .82;
}

.footer-modern a:hover {
    color: #ffffff;
    transform: translateX(2px);
}

.footer-modern a {
    transition: color .2s ease, transform .2s ease;
}

@media (max-width: 991.98px) {
    .site-header .navbar-collapse {
        margin-top: 12px;
        padding: 16px;
        border: 1px solid var(--line);
        border-radius: 16px;
        background: rgba(255,255,255,.96);
        box-shadow: 0 18px 45px rgba(15, 23, 42, .1);
    }

    .site-header .btn {
        margin-top: 12px;
    }
}
