        /* ----- BOSCH SANS FONTS (from local folder) ----- */
        @font-face {
            font-family: 'Bosch Sans';
            src: url('asset/fonts/BoschSans-Regular.otf') format('opentype');
            font-weight: 400;
            font-display: swap;
        }

        @font-face {
            font-family: 'Bosch Sans';
            src: url('asset/fonts/BoschSans-Medium.otf') format('opentype');
            font-weight: 500;
            font-display: swap;
        }

        @font-face {
            font-family: 'Bosch Sans';
            src: url('asset/fonts/BoschSans-Bold.otf') format('opentype');
            font-weight: 700;
            font-display: swap;
        }

        * {
            margin: 0;
            padding: 0;
            box-sizing: border-box;
        }

        body {
            font-family: 'Bosch Sans', 'Inter', -apple-system, sans-serif;
            background: #fefefe;
            color: #111827;
            width: 100%;
            position: relative;
        }

        html {
            width: 100%;
        }

        html,
        body {
            overflow-x: clip;
            /* better than hidden */
        }

        :root {
            --bosch-blue: #4C90CD;
            --bosch-red: #ED0007;
            --bosch-blue-dark: #3a7bb5;
            --shadow-card: 0 20px 35px -12px rgba(0, 0, 0, 0.08);
            --shadow-hover: 0 25px 40px -14px rgba(76, 144, 205, 0.25);
        }

        /* custom scroll */
        ::-webkit-scrollbar {
            width: 7px;
        }

        ::-webkit-scrollbar-track {
            background: #eef2f6;
        }

        ::-webkit-scrollbar-thumb {
            background: var(--bosch-blue);
            border-radius: 12px;
        }

        /* ========== NAVIGATION ========= */
        .navbar-alternative {
            background: rgba(255, 255, 255, 0.96);
            backdrop-filter: blur(14px);
            box-shadow: 0 1px 0 rgba(0, 0, 0, 0.05), 0 4px 20px rgba(0, 0, 0, 0.02);
            padding: 0.6rem 0;
            transition: all 0.2s;
            position: sticky;
            top: 0;
            z-index: 1030;
        }

        .logo-alt {
            height: 44px;
            filter: drop-shadow(0 2px 4px rgba(0, 0, 0, 0.02));
        }

        .tagline-mobile {
            font-size: 0.7rem;
            font-weight: 600;
            color: var(--bosch-blue);
            border-left: 2px solid var(--bosch-red);
            padding-left: 0.7rem;
            margin-left: 0.5rem;
        }

        .nav-link-alt {
            font-weight: 600;
            font-size: 0.9rem;
            color: #1f2a3e;
            transition: 0.2s;
            margin: 0 0.25rem;
            text-decoration: none;
        }

        .nav-link-alt:hover {
            color: var(--bosch-blue);
        }

        /* Offcanvas menu styles */
        .offcanvas-body .nav-link-offcanvas {
            font-weight: 600;
            font-size: 1rem;
            padding: 0.75rem 0;
            color: #1f2a3e;
            border-bottom: 1px solid #eef2f6;
            text-decoration: none;
            display: block;
        }

        .offcanvas-body .nav-link-offcanvas:last-child {
            border-bottom: none;
        }

        .btn-outline-bosch {
            border: 1.5px solid var(--bosch-blue);
            background: transparent;
            border-radius: 40px;
            padding: 7px 22px;
            font-weight: 600;
            font-size: 0.8rem;
            color: var(--bosch-blue);
            transition: all 0.2s;
            display: inline-block;
            text-decoration: none;
            text-align: center;
        }

        .btn-outline-bosch:hover {
            background: var(--bosch-blue);
            color: white;
            transform: translateY(-1px);
        }

        .btn-solid-bosch {
            background: var(--bosch-blue);
            border: none;
            border-radius: 40px;
            padding: 8px 26px;
            font-weight: 600;
            font-size: 0.85rem;
            color: white;
            box-shadow: 0 4px 10px rgba(76, 144, 205, 0.25);
            transition: all 0.2s;
            display: inline-block;
            text-decoration: none;
            text-align: center;
        }

        .btn-solid-bosch:hover {
            background: var(--bosch-blue-dark);
            transform: translateY(-2px);
            box-shadow: 0 8px 20px rgba(76, 144, 205, 0.3);
            color: white;
        }

        /* hero section */
        .hero-wave {
            background: linear-gradient(120deg, #ffffff 0%, #f4f9ff 100%);
            padding: 1.5rem 0 1rem;
        }

        .hero-badge {
            background: rgba(76, 144, 205, 0.12);
            border-radius: 80px;
            padding: 6px 16px;
            display: inline-block;
            font-weight: 600;
            font-size: 0.75rem;
            color: var(--bosch-blue);
            letter-spacing: 0.3px;
        }

        .main-headline {
            font-size: 2.6rem;
            font-weight: 800;
            line-height: 1.2;
            letter-spacing: -0.02em;
            color: #0a2540;
        }

        .highlight-red {
            color: var(--bosch-red);
        }

        .carousel-alt {
            border-radius: 28px;
            overflow: hidden;
            box-shadow: var(--shadow-card);
            position: relative;
        }

        /* Carousel Caption Overlay */
        .carousel-caption-bosch {
            position: absolute;
            bottom: 0;
            left: 0;
            right: 0;
            background: linear-gradient(0deg, rgba(0, 0, 0, 0.8) 0%, rgba(0, 0, 0, 0) 100%);
            color: white;
            padding: 30px 25px 20px;
            text-align: left;
        }

        .carousel-caption-bosch h5 {
            font-size: 1.3rem;
            font-weight: 700;
            margin-bottom: 5px;
        }

        .carousel-caption-bosch p {
            font-size: 0.85rem;
            opacity: 0.9;
            margin-bottom: 0;
        }

        .stat-grid {
            background: white;
            border-radius: 32px;
            padding: 1rem 0.8rem;
            box-shadow: 0 6px 18px rgba(0, 0, 0, 0.02);
            border: 1px solid rgba(0, 0, 0, 0.03);
        }

        .stat-number {
            font-size: 1.6rem;
            font-weight: 800;
            color: var(--bosch-blue);
        }

        /* Service cards */
        .service-glass-card {
            background: rgba(255, 255, 255, 0.9);
            border-radius: 28px;
            padding: 1.6rem 0.8rem;
            text-align: center;
            transition: all 0.3s ease;
            border: 1px solid rgba(76, 144, 205, 0.08);
            height: 100%;
            cursor: pointer;
            opacity: 1;
            transform: translateY(0);
        }

        .service-glass-card:hover {
            transform: translateY(-8px);
            box-shadow: var(--shadow-hover);
            background: white;
            border-color: rgba(76, 144, 205, 0.2);
        }

        /* Simple fade-in animation for cards */
        .fade-in-up {
            animation: fadeInUp 0.6s ease forwards;
            opacity: 0;
        }

        @keyframes fadeInUp {
            from {
                opacity: 0;
                transform: translateY(30px);
            }

            to {
                opacity: 1;
                transform: translateY(0);
            }
        }

        /* Staggered delays */
        .delay-1 {
            animation-delay: 0.1s;
        }

        .delay-2 {
            animation-delay: 0.13s;
        }

        .delay-3 {
            animation-delay: 0.16s;
        }

        .delay-4 {
            animation-delay: 0.19s;
        }

        .delay-5 {
            animation-delay: 0.22s;
        }

        .delay-6 {
            animation-delay: 0.25s;
        }

        .service-icon-round {
            width: 64px;
            height: 64px;
            background: #eef5ff;
            border-radius: 32px;
            display: flex;
            align-items: center;
            justify-content: center;
            margin: 0 auto 1rem;
            transition: 0.2s;
        }

        .service-glass-card:hover .service-icon-round {
            background: var(--bosch-blue);
        }

        .service-glass-card:hover .service-icon-round i {
            color: white !important;
        }

        .service-icon-round i {
            font-size: 28px;
            color: var(--bosch-blue);
        }

        /* Form Styles */
        .form-radial-card {
            background: white;
            border-radius: 32px;
            box-shadow: var(--shadow-card);
            overflow: hidden;
            border: 1px solid #eef2ff;
        }

        .form-header-radial {
            background: radial-gradient(circle at 10% 30%, var(--bosch-blue-dark), var(--bosch-blue));
            padding: 1.4rem 1.5rem;
        }

        .form-control-modern {
            width: 100%;
            padding: 12px 16px;
            border-radius: 20px;
            border: 1.5px solid #e9edf2;
            font-size: 0.85rem;
            transition: 0.2s;
            background: #ffffff;
            font-family: 'Bosch Sans', sans-serif;
        }

        .form-control-modern:focus {
            border-color: var(--bosch-blue);
            box-shadow: 0 0 0 3px rgba(76, 144, 205, 0.15);
            outline: none;
        }

        .btn-submit-radial {
            background: var(--bosch-blue);
            border: none;
            border-radius: 44px;
            padding: 12px;
            font-weight: 700;
            width: 100%;
            transition: all 0.2s;
            color: white;
            font-family: 'Bosch Sans', sans-serif;
        }

        .btn-submit-radial:hover {
            background: var(--bosch-blue-dark);
            transform: scale(0.98);
            box-shadow: 0 6px 16px rgba(76, 144, 205, 0.25);
        }

        /* Footer */
        .footer-dark-alt {
            background: #0b1c2c;
            color: #b0c4de;
            padding: 3rem 0 2rem;
            margin-top: 4rem;
        }

        .footer-heading-alt {
            color: white;
            font-weight: 700;
            font-size: 1rem;
            margin-bottom: 1.2rem;
        }

        .footer-link-alt {
            color: #9bb7d0;
            text-decoration: none;
            font-size: 0.8rem;
            transition: 0.2s;
        }

        .footer-link-alt:hover {
            color: white;
            padding-left: 4px;
        }

        .social-icon-alt {
            background: rgba(255, 255, 255, 0.08);
            width: 36px;
            height: 36px;
            display: inline-flex;
            align-items: center;
            justify-content: center;
            border-radius: 30px;
            margin-right: 8px;
            color: #b0c4de;
            transition: 0.2s;
            text-decoration: none;
        }

        .social-icon-alt:hover {
            background: var(--bosch-blue);
            color: white;
            transform: translateY(-2px);
        }

        .mobile-fixed-actions {
            position: fixed;
            bottom: 0;
            left: 0;
            right: 0;
            background: rgba(255, 255, 255, 0.96);
            backdrop-filter: blur(20px);
            border-top: 1px solid rgba(0, 0, 0, 0.05);
            padding: 10px 20px;
            display: flex;
            gap: 12px;
            z-index: 1040;
            display: none;
        }

        .toast-notify {
            position: fixed;
            bottom: 30px;
            left: 30px;
            z-index: 1200;
            background: #111827;
            border-radius: 50px;
            padding: 12px 24px;
            font-weight: 500;
            opacity: 0;
            transition: 0.25s;
            pointer-events: none;
            display: flex;
            align-items: center;
            gap: 8px;
            color: white;
            font-size: 0.85rem;
        }

        /* Fix overflow - but keep sticky working */
        .container {
            overflow-x: visible !important;
        }

        .row {
            margin-left: 0;
            margin-right: 0;
        }

        img {
            max-width: 100%;
            height: auto;
        }

        /* Mobile styles */
        @media (max-width: 992px) {
            .hero-wave .row {
                display: flex;
                flex-direction: column;
            }

            .hero-wave .row>.col-lg-5:first-child {
                order: 2;
            }

            .hero-wave .row>.col-lg-7:last-child {
                order: 1;
                margin-bottom: 1.5rem;
            }

            .main-headline {
                font-size: 1.9rem;
            }

            .mobile-fixed-actions {
                display: flex;
            }

            footer {
                margin-bottom: 70px;
            }

            .hero-wave {
                padding: 1rem 0 1rem;
            }

            .stat-grid {
                margin-bottom: 1rem;
            }

            .carousel-caption-bosch h5 {
                font-size: 1rem;
            }

            .carousel-caption-bosch p {
                font-size: 0.7rem;
            }

            .carousel-caption-bosch {
                padding: 20px 15px 12px;
            }
        }

        @media (max-width: 576px) {
            .main-headline {
                font-size: 1.6rem;
            }

            .hero-badge {
                font-size: 0.7rem;
            }

            .btn-solid-bosch,
            .btn-outline-bosch {
                padding: 6px 18px;
                font-size: 0.75rem;
            }

            .stat-number {
                font-size: 1.3rem;
            }

            .service-glass-card {
                padding: 1.2rem 0.5rem;
            }

            .service-icon-round {
                width: 50px;
                height: 50px;
            }

            .service-icon-round i {
                font-size: 22px;
            }

            .form-header-radial {
                padding: 1rem;
            }

            .form-header-radial h3 {
                font-size: 1.2rem;
            }

            .carousel-alt {
                border-radius: 20px;
            }
        }

        /* Carousel indicators */
        .carousel-alt .carousel-indicators {
            margin-bottom: 0.5rem;
            z-index: 15;
        }

        .carousel-alt .carousel-indicators button {
            background-color: #fff;
            opacity: 0.6;
            width: 8px;
            height: 8px;
            border-radius: 50%;
            margin: 0 5px;
        }

        .carousel-alt .carousel-indicators button.active {
            opacity: 1;
            background-color: var(--bosch-blue);
        }

        .carousel-control-prev-icon,
        .carousel-control-next-icon {
            background-size: 60%;
            border-radius: 50%;
            padding: 1.2rem;
        }

        /* Hero section fade-in */
        .hero-content {
            animation: fadeInLeft 0.6s ease forwards;
        }

        @keyframes fadeInLeft {
            from {
                opacity: 0;
                transform: translateX(-20px);
            }

            to {
                opacity: 1;
                transform: translateX(0);
            }
        }

        .carousel-wrapper {
            animation: fadeInRight 0.6s ease forwards;
        }

        @keyframes fadeInRight {
            from {
                opacity: 0;
                transform: translateX(20px);
            }

            to {
                opacity: 1;
                transform: translateX(0);
            }
        }

        .form-fade-up {
            animation: fadeInUp 0.6s ease forwards;
        }