   /* :root {
           
            --primary-blue: #122268;
            --line-color: #adb5bd;  
            --line-width: 2px;
            --line-style: dashed;
        }
            .travel-and-leisure-firms-competitive-intelligence-solution {
                background: url(../../images/agentic-ai-client_onboarding.jpg) no-repeat center top;
                background-size: cover;

            }

            .blue_path_text p {
                font-size: 0.8rem;
                line-height: 1.4rem;
                font-weight: normal;
                margin: 15px 0;
            }

            .text_formatting p {
                margin: 25px 0;
                display: block;
            }

            .cob_list ul {
                margin: 20px 0 0;
                padding: 0 0 0 15px;
                line-height: 15px;
            }



            @media (max-width: 767px) {

                .innerpgBanner,
                section.banner_section.height100 {
                    padding: 120px 0 30px;
                    height: 480px;
                }

                .text_formatting p {
                    margin: 15px 0;
                }

                .bannerBlueBoxInner .tab_inner {
                    padding-top: 5px;
                }

                p {
                    text-wrap: balance;
                }
                .parent-node:after{display: none !important;}
            } */
  
/* *********Updated**************** */

          .travel-and-leisure-firms-competitive-intelligence-solution {
                background: url(../../images/agentic-ai-client_onboarding.jpg) no-repeat center top;
                background-size: cover;

            }

            .blue_path_text p {
                font-size: 0.8rem;
                line-height: 1.4rem;
                font-weight: normal;
                margin: 15px 0;
            }

            .text_formatting p {
                margin: 25px 0;
                display: block;
            }

            .cob_list ul {
                margin: 20px 0 0;
                padding: 0 0 0 15px;
                line-height: 15px;
            }



            @media (max-width: 767px) {

                .innerpgBanner,
                section.banner_section.height100 {
                    padding: 120px 0 30px;
                    height: 480px;
                }

                .text_formatting p {
                    margin: 15px 0;
                }

                .bannerBlueBoxInner .tab_inner {
                    padding-top: 5px;
                }

                p {
                    text-wrap: balance;
                }
            }       
      
        /* Responsive Connector Logic */
        .spine-mobile {
            position: absolute;
            left: 1.5rem;
            top: -100px;
            bottom: 0;
            width: 2px;
            border-left: 2px dashed #cbd5e1;
            z-index: 0;
        }

        .agent-card-container {
            position: relative;
            padding-left: 3rem; /* Space for mobile spine */
        }

        .agent-card-container::before {
            content: '';
            position: absolute;
            left: 1.5rem;
            top: 2rem;
            width: 1.5rem;
            height: 2px;
            border-top: 2px dashed #cbd5e1;
        }
        .agent-card-container{position: relative;}
.agent-card-container:after {
    content: " ";
    position: absolute;
    top: 31%;
    left: -1rem;
    width: .9rem;
    height: 2px;
    border-top: 2px dashed #cbd5e1;
}

.agent-card-container:first-child:after {
    display: none;}


.branch-row-2 .agent-card-container:after {top:63%}
    
        /* Orchestrator Bottom Connector (Mobile) */
        .orchestrator-connector-mobile {
            position: absolute;
            bottom: -2rem;
            left: 50%;
            height: 2rem;
            width: 2px;
            border-left: 2px dashed #cbd5e1;
            transform: translateX(-50%);
            display: none !important;
        }

        /* Desktop Flow Lines (Side-by-Side) */
        @media (min-width: 992px) {
            .spine-mobile, .agent-card-container::before, .orchestrator-connector-mobile {
                display: none;
            }

            .agent-card-container {
                padding-left: 0;
            }

            .flow-line-main {
                position: absolute;
                top: 50%;
                right: -1rem; /* Adjust based on Bootstrap gutters */
                width: .9rem;
                height: 2px;
                border-top: 2px dashed #cbd5e1;
            }

            .spine-desktop {
                position: absolute;
                left: -8px;
                top: 15%;
                bottom: 15%;
                width: 2rem;
                border-left: 2px dashed #cbd5e1;
                border-top: 2px dashed #cbd5e1;
                border-bottom: 2px dashed #cbd5e1;
            }

            .branch-row-1::before, .branch-row-2::before {
                content: '';
                position: absolute;
                left: -1rem;
                top: 50%;
                width: 2rem;
                height: 2px;
                border-top: 2px dashed #cbd5e1;
                display: none;
            }
        }

        /* Custom Card Styling */
        .agent-card {
            border: 1px solid #e2e8f0;
            border-radius: 1rem;
            transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
            background: white;
            height: 100%;
        }

        .agent-card:hover {
            transform: translateY(-4px);
            box-shadow: 0 10px 25px -5px rgba(0, 0, 0, 0.1);
        }

        .orchestrator-node {
            background-color: #122268;
            border-radius: 1.5rem;
            border: 1px solid #122268;
            box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.25);
        }

        .orchestrator-pulse {
            animation: pulse-border 3s infinite;
        }

        @keyframes pulse-border {
            0% { box-shadow: 0 0 0 0 rgba(37, 99, 235, 0.2); }
            70% { box-shadow: 0 0 0 15px rgba(37, 99, 235, 0); }
            100% { box-shadow: 0 0 0 0 rgba(37, 99, 235, 0); }
        }

        .orbit-badge {
            background-color: rgba(30, 58, 138, 0.5);
            border: 1px solid rgba(96, 165, 250, 0.3);
            font-size: 10px;
            letter-spacing: 0.05em;
        }

        .icon-box {
            width: 48px;
            height: 48px;
            display: flex;
            align-items: center;
            justify-content: center;
            border-radius: 0.75rem;
        }

        .node-list {
            list-style: none;
            padding: 0;
            margin: 0;
        }

        .node-list li {
            font-size: 0.75rem;
            color: #64748b;
            display: flex;
            gap: 0.5rem;
            margin-bottom: 0.5rem;
        }

        .node-list li::before {
            content: "•";
            color: #3b82f6;
            font-weight: bold;
        } @media (max-width: 768px) {

            .agent-card-container:after {display: none !important;}
        
        }
 

     

       .col-connector{z-index: 9;}

        /* --- Card Styling --- */
        .node-card {
            background: white;
            border: none;
            border-top: 5px solid var(--primary-blue);
            border-radius: 8px;
            padding: 25px 20px;
            box-shadow: 0 4px 15px rgba(0,0,0,0.05);
            height: 100%;
            position: relative;
            z-index: 10; /* Keeps card on top of lines */
            text-align: left;
        }

        .node-title {
            color: var(--primary-blue);
            font-weight: 700;
            text-transform: uppercase;
            font-size: 0.9rem;
            margin-bottom: 8px;
        }

        .node-orbit {
            font-size: 0.8rem;
            font-weight: 600;
            color: #495057;
            margin-bottom: 12px;
        }

        .node-list {
            list-style-type: none;
            padding-left: 0;
            font-size: 0.85rem;
            color: #6c757d;
        }

        .node-list li {
            margin-bottom: 6px;
            padding-left: 15px;
            position: relative;
            line-height: 1.4;
        }

        /* Custom Blue Bullet Points */
        .node-list li::before {
            content: "•";
            color: var(--primary-blue);
            font-weight: bold;
            position: absolute;
            left: 0;
            top: -2px;
        }

        /* --- Parent Node (Blue Box) --- */
        .parent-node {
            background: var(--primary-blue);
            color: white;
            border-radius: 8px;
            padding: 25px;
            text-align: center;
            max-width: 500px;
            margin: 0 auto;
            position: relative;
            z-index: 20;
            box-shadow: 0 6px 12px rgba(13, 110, 253, 0.2);
        }

        .parent-node h4 {
            font-weight: 700;
            font-size: 1.1rem;
            margin-bottom: 5px;
            text-transform: uppercase;
        }

        .parent-node .orbit-text {
            font-weight: 600;
            font-size: 0.9rem;
            margin-bottom: 10px;
            opacity: 0.95;
        }

        .parent-node p {
            font-size: 0.85rem;
            margin-bottom: 0;
            opacity: 0.9;
        }
 .tree-container {
                position: relative;
            }
        /* --- TREE CONNECTOR LINES (Desktop/Tablet) --- */
        /* Applied when screen is wider than 768px (md breakpoint) */
        @media (min-width: 768px) {
            
            /* 1. PARENT CONNECTOR: Line straight down from Blue Box */
            .parent-node::after {
                content: '';
                position: absolute;
                top: 100%; /* Starts at bottom of card */
                left: 50%;
                width: 0;
                height: 48px; /* Extends down through the margin-bottom gap */
                border-left: var(--line-width) var(--line-style) var(--line-color);
                transform: translateX(-50%);
                z-index: 1;
            }

            .tree-container {
                position: relative;
            }

            /* 2. Central Vertical Spine */
            /* Connects Row 1 Horizontal Bar to Row 2 Horizontal Bar */
            .vertical-spine {
                position: absolute;
                top: -25px; /* Starts at Row 1 Horizontal Bar level */
                bottom: 50px; /* Ends at Row 2 Horizontal Bar level */
                left: 50%;
                border-left: var(--line-width) var(--line-style) var(--line-color);
                transform: translateX(-50%);
                z-index: 1; 
            }

            /* 3. Horizontal Bars */
            /* Spans the width of the row to connect left/right columns */
            .horizontal-bar {
                position: absolute;
                top: -25px; /* Position above the cards */
                /* Math: Center of first col (16.66%) to Center of last col (83.33%) */
                left: 16.66%; 
                right: 16.66%; 
                border-top: var(--line-width) var(--line-style) var(--line-color);
                z-index: 1;
                width: 66.6%;
            }

            /* 4. Small Vertical Droppers */
            /* Connects the horizontal bar down to each card */
            .col-connector {
                position: relative;
            }
            
            .col-connector::before {
                content: '';
                position: absolute;
                top: -25px; /* Must match horizontal-bar top */
                left: 50%;
                height: 25px; /* Distance to card */
                border-left: var(--line-width) var(--line-style) var(--line-color);
                transform: translateX(-50%);
                z-index: 1;
            }
            
            /* Add spacing between rows */
            .row-gap-large {
                margin-top: 80px; 
            }
        }

        /* --- Mobile Styles (< 768px) --- */
        @media (max-width: 767px) {
            
            /* Hide the Desktop Horizontal Bar */
            .horizontal-bar {
                display: none; 
            }

            /* 1. PARENT DROP: Line down from center of Blue Box */
            .parent-node::after {
                content: '';
                position: absolute;
                top: 100%;
                left: 50%;
                width: 0;
                height: 25px;
                border-left: var(--line-width) var(--line-style) var(--line-color);
                transform: translateX(-50%);
                z-index: 1;
                display: block;
            }

            /* 2. SPINE: Moves to the LEFT side */
                .vertical-spine {
        display: block;
        position: absolute;
        top: -120px;
        left: 18px;
        border-left: var(--line-width) var(--line-style) var(--line-color);
        transform: none;
        z-index: 1;
        height: 96%;
    }

            /* 3. BRIDGE: Connects Center (Parent Drop) to Left (Spine) */
            /* We use a box with top-border and left-radius to create the curve */
           

            /* 4. CARD WRAPPER: Shift right to make room for spine */
            .col-connector {
                margin-bottom: 25px;
                padding-left: 80px !important; /* increased space for cleaner look */
                position: relative;
            }

            /* 5. CARD CONNECTOR: Horizontal line from Left Spine to Card */
            .col-connector::before {
                content: '';
                position: absolute;
                /* Align line nicely with the top part of the card (Title) */
                top: 45px; 
                left: 30px; /* Starts at spine */
                width: 50px; /* Connects to the padding edge */
                border-top: var(--line-width) var(--line-style) var(--line-color);
                display: block;
                z-index: 1;
            }

            /* 6. JUNCTION DOTS: Adds a crisp "node" at the intersection */
            .col-connector::after {
                content: '';
                position: absolute;
                top: 41px; /* (Top 45px) - (Half Height 4px) */
                left: 26px; /* (Left 30px) - (Half Width 4px) */
                width: 10px;
                height: 10px;
                background-color: white;
                border: 2px solid var(--primary-blue);
                border-radius: 50%;
                z-index: 5;
            }

            .node-card {
                border-top-width: 4px;
            }

            /* Remove large row gap on mobile to keep flow consistent */
            .row-gap-large {
                margin-top: 0; 
            }
        }
  