:root{
            --asa-blue: #0f79b8;
            --asa-blue-dark: #0b5f90;
            --asa-green: #67d339;
            --asa-dark: #1f2937;
            --asa-text: #5b6575;
            --asa-soft: #f4f8fb;
            --asa-border: #dce6ef;
            --asa-white: #ffffff;
        }

        html{scroll-behavior:smooth;}

        body{
            font-family: Arial, Helvetica, sans-serif;
            color: var(--asa-dark);
            background:#fff;
        }

        a{text-decoration:none;}

        .section-space{padding:90px 0;}

        .section-title{
            margin-bottom:50px;
        }

        .section-title .mini-title{
            display:inline-block;
            font-size:13px;
            font-weight:700;
            letter-spacing:.8px;
            text-transform:uppercase;
            color:var(--asa-blue);
            margin-bottom:12px;
        }

        .section-title h2{
            font-size:2.3rem;
            font-weight:800;
            margin-bottom:14px;
        }

        .section-title p{
            color:var(--asa-text);
            line-height:1.9;
            max-width:760px;
            margin:0 auto;
        }

        .topbar{
            background:#fff;
            border-bottom:1px solid rgba(15,121,184,0.08);
            font-size:14px;
        }

        .topbar a,
        .topbar span{
            color:var(--asa-text);
        }

        .main-navbar{
            background:rgba(255,255,255,0.96);
            backdrop-filter:blur(10px);
            border-bottom:1px solid rgba(15,121,184,0.08);
        }

        .navbar-brand{
            display:flex;
            align-items:center;
            gap:14px;
        }

        .brand-logo{
            width:56px;
            height:56px;
            object-fit:contain;
            border-radius:14px;
            background:#fff;
            padding:5px;
            box-shadow:0 8px 22px rgba(0,0,0,0.08);
        }

        .brand-text strong{
            display:block;
            font-size:1.15rem;
            color:var(--asa-dark);
            line-height:1.1;
        }

        .brand-text span{
            display:block;
            font-size:.82rem;
            color:var(--asa-text);
            line-height:1.2;
        }

        .navbar-nav .nav-link{
            color:var(--asa-dark);
            font-weight:600;
            padding-left:14px !important;
            padding-right:14px !important;
        }

        .navbar-nav .nav-link:hover,
        .navbar-nav .nav-link.active{
            color:var(--asa-blue);
        }

        .navbar .dropdown-menu{
            border:1px solid rgba(15,121,184,0.10);
            border-radius:18px;
            padding:14px;
            box-shadow:0 20px 45px rgba(15,23,42,0.08);
        }

        .navbar .dropdown-toggle::after{
            margin-left:8px;
            vertical-align:middle;
        }

        .mega-menu{
            width:min(1120px, calc(100vw - 40px));
            left:50% !important;
            right:auto !important;
            transform:translateX(-50%);
            padding:24px;
        }

        .solutions-mega-head{
            padding-bottom:14px;
            margin-bottom:18px;
            border-bottom:1px solid rgba(15,121,184,0.10);
        }

        .solutions-mega-head small{
            display:inline-block;
            font-size:12px;
            font-weight:800;
            letter-spacing:.8px;
            text-transform:uppercase;
            color:var(--asa-blue);
            margin-bottom:6px;
        }

        .solutions-mega-head h4{
            font-size:1.15rem;
            font-weight:800;
            color:var(--asa-dark);
            margin:0;
        }

        .mega-menu-title{
            font-size:13px;
            font-weight:800;
            letter-spacing:.7px;
            text-transform:uppercase;
            color:var(--asa-blue);
            margin-bottom:14px;
        }

        .mega-menu-layout{
            align-items:stretch;
        }

        .mega-menu-content{
            padding-right:6px;
        }

        .mega-menu-visual{
            height:auto;
            align-self:stretch;
            display:flex;
        }

        .mega-menu-image{
            width:100%;
            height:100%;
            min-height:100%;
            border-radius:22px;
            overflow:hidden;
            position:relative;
            background:url('../img/hero.webp');
            background-size:cover;
            background-position:right center;
            background-repeat:no-repeat;
            box-shadow:inset 0 1px 0 rgba(255,255,255,.10);
            display:block;
        }

        .mega-menu-list{
            list-style:none;
            padding:0;
            margin:0;
        }

        .mega-menu-list li + li{
            margin-top:10px;
        }

        .mega-menu-link{
            display:flex;
            gap:12px;
            align-items:flex-start;
            padding:12px 14px;
            border-radius:14px;
            color:var(--asa-dark);
            transition:.2s ease;
        }

        .mega-menu-link:hover{
            background:var(--asa-soft);
            color:var(--asa-blue);
        }

        .mega-menu-link i{
            color:var(--asa-blue);
            margin-top:4px;
            min-width:18px;
        }

        .mega-menu-link strong{
            display:block;
            font-size:15px;
            margin-bottom:3px;
        }

        .mega-menu-link span{
            display:block;
            font-size:13px;
            line-height:1.6;
            color:var(--asa-text);
        }

        .btn-asa{
            background:linear-gradient(135deg, var(--asa-blue), var(--asa-blue-dark));
            color:#fff;
            border:none;
            border-radius:14px;
            padding:12px 20px;
            font-weight:700;
        }

        .btn-asa:hover{
            color:#fff;
            opacity:.95;
        }

        .btn-soft{
            background:#fff;
            color:var(--asa-dark);
            border:1px solid var(--asa-border);
            border-radius:14px;
            padding:12px 20px;
            font-weight:700;
        }

        .title-hero{
            position:relative;
            overflow:hidden;
            background:
                radial-gradient(circle at top left, rgba(103,211,57,.10), transparent 32%),
                radial-gradient(circle at bottom right, rgba(15,121,184,.12), transparent 34%),
                linear-gradient(180deg, #f8fbfe 0%, #ffffff 100%);
            padding:72px 0 56px;
        }

        .title-card{
            position:relative;
            overflow:hidden;
            border-radius:34px;
            padding:42px;
            color:#fff;
            background:
                linear-gradient(rgba(15,121,184,.90), rgba(11,95,144,.82)),
                url("../img/hero.webp");
            background-size:cover;
            background-position:right center;
            background-repeat:no-repeat;
            box-shadow:0 28px 60px rgba(11,95,144,.20);
        }

        .title-card::before{
            content:"";
            position:absolute;
            width:220px;
            height:220px;
            border-radius:50%;
            background:rgba(255,255,255,.08);
            top:-80px;
            right:-70px;
        }

        .title-card::after{
            content:"";
            position:absolute;
            width:140px;
            height:140px;
            border-radius:50%;
            background:rgba(255,255,255,.06);
            bottom:-50px;
            left:-35px;
        }

        .title-card > *{
            position:relative;
            z-index:2;
        }

        .title-badge{
            display:inline-flex;
            align-items:center;
            gap:10px;
            padding:10px 16px;
            border-radius:999px;
            background:rgba(255,255,255,.12);
            color:rgba(255,255,255,.94);
            font-size:13px;
            font-weight:700;
            margin-bottom:18px;
        }

        .title-card h1{
            font-size:3rem;
            font-weight:800;
            line-height:1.08;
            margin-bottom:16px;
        }

        .title-card p{
            max-width:760px;
            color:rgba(255,255,255,.88);
            line-height:1.9;
            font-size:1.05rem;
            margin:0;
        }

        .breadcrumb-line{
            display:flex;
            flex-wrap:wrap;
            gap:10px;
            align-items:center;
            margin-top:20px;
            color:rgba(255,255,255,.78);
            font-size:14px;
        }

        .breadcrumb-line a{
            color:#fff;
        }

        .intro-card{
            background:linear-gradient(180deg, #ffffff 0%, #fbfdff 100%);
            border:1px solid rgba(15,121,184,0.08);
            border-radius:28px;
            box-shadow:0 16px 40px rgba(15,23,42,0.04);
            padding:34px;
            height:100%;
        }

        .intro-card p{
            color:var(--asa-text);
            line-height:1.9;
            margin-bottom:16px;
        }

        .mini-points{
            list-style:none;
            padding:0;
            margin:22px 0 0;
            display:grid;
            gap:12px;
        }

        .mini-points li{
            display:flex;
            gap:12px;
            align-items:flex-start;
            padding:15px 16px;
            border-radius:18px;
            background:#f7fbff;
            border:1px solid rgba(15,121,184,0.08);
            color:var(--asa-text);
            line-height:1.75;
        }

        .mini-points i{
            color:var(--asa-green);
            margin-top:4px;
        }

        .services-wrap{
            display:flex;
            flex-direction:column;
            gap:24px;
        }

        .solution-card{
            background:linear-gradient(180deg, #ffffff 0%, #fbfdff 100%);
            border:1px solid rgba(15,121,184,0.10);
            border-radius:30px;
            padding:32px;
            box-shadow:0 18px 45px rgba(15,23,42,0.05);
            transition:.30s ease;
            position:relative;
            overflow:hidden;
        }

        .solution-card:hover{
            transform:translateY(-6px);
            box-shadow:0 28px 65px rgba(15,23,42,0.10);
            border-color:rgba(15,121,184,0.18);
        }

        .solution-card::before{
            content:"";
            position:absolute;
            inset:0 0 auto 0;
            height:4px;
            background:linear-gradient(90deg, var(--asa-blue), var(--asa-green));
        }

        .solution-card::after{
            content:"";
            position:absolute;
            width:180px;
            height:180px;
            border-radius:50%;
            background:radial-gradient(circle, rgba(15,121,184,.10) 0%, rgba(103,211,57,.05) 35%, rgba(15,121,184,0) 72%);
            top:-70px;
            right:-70px;
            pointer-events:none;
        }

        .solution-grid{
            display:grid;
            grid-template-columns:320px 1fr;
            gap:30px;
            align-items:start;
            position:relative;
            z-index:2;
        }

        .solution-left{
            padding-right:10px;
        }

        .solution-kicker{
            display:inline-block;
            font-size:12px;
            font-weight:800;
            letter-spacing:.8px;
            text-transform:uppercase;
            color:var(--asa-blue);
            margin-bottom:14px;
        }

        .solution-head{
            display:flex;
            align-items:center;
            gap:16px;
            margin-bottom:16px;
        }

        .solution-icon{
            width:72px;
            height:72px;
            min-width:72px;
            border-radius:22px;
            background:linear-gradient(145deg, rgba(15,121,184,.16), rgba(103,211,57,.18));
            border:1px solid rgba(15,121,184,.10);
            color:var(--asa-blue);
            font-size:1.6rem;
            display:flex;
            align-items:center;
            justify-content:center;
            box-shadow:inset 0 1px 0 rgba(255,255,255,.9), 0 14px 28px rgba(15,121,184,.10);
        }

        .solution-title{
            font-size:2rem;
            font-weight:800;
            line-height:1.1;
            letter-spacing:-0.02em;
            margin:0;
            color:var(--asa-dark);
        }

        .solution-desc{
            color:var(--asa-text);
            line-height:1.8;
            font-size:1rem;
            margin:0 0 18px 0;
            max-width:95%;
        }

        .solution-note{
            display:flex;
            align-items:center;
            gap:10px;
            color:var(--asa-text);
            font-size:15px;
            font-weight:600;
        }

        .solution-note i{
            color:var(--asa-green);
        }

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

        .solution-link{
            display:flex;
            align-items:flex-start;
            gap:14px;
            padding:18px;
            border:1px solid rgba(15,121,184,0.10);
            border-radius:18px;
            background:rgba(255,255,255,.82);
            transition:.22s ease;
            color:var(--asa-dark);
            min-height:100%;
        }

        .solution-link:hover{
            transform:translateY(-3px);
            border-color:rgba(15,121,184,0.20);
            box-shadow:0 14px 28px rgba(15,121,184,.10);
            color:var(--asa-blue);
        }

        .solution-link-icon{
            width:42px;
            height:42px;
            min-width:42px;
            border-radius:14px;
            background:rgba(15,121,184,.08);
            color:var(--asa-blue);
            display:flex;
            align-items:center;
            justify-content:center;
            font-size:1rem;
        }

        .solution-link strong{
            display:block;
            font-size:1.02rem;
            font-weight:800;
            line-height:1.35;
            margin-bottom:4px;
        }

        .solution-link span{
            display:block;
            font-size:14px;
            line-height:1.65;
            color:var(--asa-text);
        }

        .cta-box{
            position:relative;
            overflow:hidden;
            padding:36px;
            border-radius:28px;
            background:
                linear-gradient(155deg, rgba(15,121,184,.96), rgba(11,95,144,.92)),
                url("../img/hero.webp");
            background-size:cover;
            background-position:right center;
            color:#fff;
            box-shadow:0 24px 55px rgba(11,95,144,.22);
        }

        .cta-box::before{
            content:"";
            position:absolute;
            width:170px;
            height:170px;
            border-radius:50%;
            background:rgba(255,255,255,.08);
            top:-60px;
            right:-50px;
        }

        .cta-box > *{
            position:relative;
            z-index:2;
        }

        .cta-box h3{
            font-size:1.9rem;
            font-weight:800;
            margin-bottom:12px;
        }

        .cta-box p{
            color:rgba(255,255,255,.88);
            line-height:1.9;
            margin-bottom:22px;
            max-width:760px;
        }

        .footer{
            background:
                radial-gradient(circle at top left, rgba(15,121,184,.18), transparent 28%),
                radial-gradient(circle at bottom right, rgba(103,211,57,.10), transparent 24%),
                #0f1720;
            color:rgba(255,255,255,.76);
            padding:0;
            position:relative;
            overflow:hidden;
        }

        .footer strong{color:#fff;}

        .footer-top{
            padding:70px 0 34px;
            position:relative;
            z-index:2;
        }

        .footer-brand{
            display:flex;
            align-items:center;
            gap:16px;
            margin-bottom:18px;
        }

        .footer-brand img{
            width:64px;
            height:64px;
            object-fit:contain;
            border-radius:16px;
            background:rgba(255,255,255,.08);
            padding:6px;
            box-shadow:0 10px 24px rgba(0,0,0,.18);
        }

        .footer-brand-text strong{
            display:block;
            font-size:1.1rem;
            line-height:1.15;
        }

        .footer-brand-text span{
            display:block;
            font-size:.82rem;
            color:rgba(255,255,255,.58);
            line-height:1.3;
        }

        .footer-about{
            max-width:420px;
            line-height:1.9;
            color:rgba(255,255,255,.72);
            margin-bottom:22px;
        }

        .footer-social{
            display:flex;
            flex-wrap:wrap;
            gap:12px;
        }

        .footer-social a{
            width:42px;
            height:42px;
            border-radius:14px;
            display:inline-flex;
            align-items:center;
            justify-content:center;
            background:rgba(255,255,255,.06);
            border:1px solid rgba(255,255,255,.08);
            color:#fff;
            transition:.22s ease;
        }

        .footer-social a:hover{
            background:linear-gradient(135deg, var(--asa-blue), var(--asa-blue-dark));
            border-color:transparent;
            transform:translateY(-2px);
        }

        .footer-title{
            font-size:.95rem;
            font-weight:800;
            letter-spacing:.6px;
            text-transform:uppercase;
            color:#fff;
            margin-bottom:18px;
        }

        .footer-links,
        .footer-contact-list{
            list-style:none;
            padding:0;
            margin:0;
        }

        .footer-links li + li,
        .footer-contact-list li + li{
            margin-top:12px;
        }

        .footer-links a{
            color:rgba(255,255,255,.72);
            transition:.2s ease;
        }

        .footer-links a:hover{
            color:#fff;
            padding-left:4px;
        }

        .footer-contact-list li{
            display:flex;
            gap:12px;
            align-items:flex-start;
            color:rgba(255,255,255,.72);
            line-height:1.7;
        }

        .footer-contact-list i{
            width:18px;
            min-width:18px;
            margin-top:4px;
            color:var(--asa-green);
        }

        .footer-contact-list a,
        .footer-contact-list span{
            color:rgba(255,255,255,.72);
        }

        .footer-contact-list a:hover{
            color:#fff;
        }

        .footer-bottom{
            border-top:1px solid rgba(255,255,255,.08);
            padding:18px 0;
            position:relative;
            z-index:2;
        }

        .footer-bottom-text,
        .footer-bottom-links span{
            color:rgba(255,255,255,.60);
            font-size:.95rem;
        }

        .footer-bottom-links{
            display:flex;
            flex-wrap:wrap;
            gap:18px;
        }

        @media (max-width: 991px){
            .solution-grid{
                grid-template-columns:1fr;
                gap:24px;
            }

            .solution-right{
                grid-template-columns:1fr;
            }

            .solution-title{
                font-size:1.7rem;
            }

            .title-card h1{
                font-size:2.4rem;
            }
        }

        @media (max-width: 575px){
            .section-space{
                padding:70px 0;
            }

            .solution-card,
            .intro-card,
            .cta-box,
            .title-card{
                padding:22px;
                border-radius:24px;
            }

            .solution-head{
                align-items:flex-start;
            }

            .solution-icon{
                width:62px;
                height:62px;
                min-width:62px;
                font-size:1.35rem;
            }

            .solution-title{
                font-size:1.45rem;
            }

            .title-card h1{
                font-size:2rem;
            }

            .footer-top{
                padding:50px 0 28px;
            }
        }
