.tagcs-hero{
/*height:100vh;*/
display:flex;
align-items:center;
justify-content:space-between;
padding:0px 10%;
perspective:2000px;
}

.tagcs-hero-text{max-width:500px;}

.tagcs-nexus-wrapper{
position:relative;
width:500px;
/*height:500px;*/
display:flex;
align-items:center;
justify-content:center;
transform-style:preserve-3d;
}

.tagcs-main-core{
width:260px;
height:260px;
background:linear-gradient(135deg,#294671 0%,#1ab1de 100%);
border-radius:50%;
box-shadow:0 0 80px rgba(0,97,255,.4);
position:relative;
z-index:2;
}

.tagcs-info-chip{
position:absolute;
background:rgba(255,255,255,0.9);
padding:15px 20px;
border-radius:16px;
border:1px solid rgba(0,97,255,0.2);
box-shadow:0 10px 30px rgba(0,0,0,0.05);
display:flex;
align-items:center;
gap:12px;
backdrop-filter:blur(10px);
z-index:3;
transition:transform .3s ease, box-shadow .3s ease;
cursor:pointer;
width:max-content;
}

.tagcs-info-chip:hover{
transform:scale(1.1) translateZ(50px);
box-shadow:0 20px 40px rgba(0,97,255,.2);
}

.tagcs-chip-icon{
width:30px;
height:30px;
background:#294671;
border-radius:8px;
}

.tagcs-chip-text b{
display:block;
font-size:.9rem;
color:#294671;
}

.tagcs-chip-text span{
font-size:.75rem;
color:#666;
font-weight:600;
}

.tagcs-chip-1{top:10%;right:-20px;}
.tagcs-chip-2{bottom:15%;left:-20px;}
.tagcs-chip-3{top:50%;left:-40px;transform:translateY(-50%);}

.tagcs-btn{
background:#294671;
color:#fff;
border:none;
padding:18px 40px;
border-radius:50px;
font-weight:700;
}


.tagcs-partnership {
--primary-blue:#0061FF;
--navy:#050A1F;
--slate:#475569;
--bg-light:#F8FAFF;

display:grid;
grid-template-columns:1fr 1.1fr;
gap:50px;
padding:70px 8%;
background:#fff;
align-items:start;
}

.tagcs-pointers{
display:flex;
flex-direction:column;
gap:15px;
}

.tagcs-pointer-card{
padding:25px;
background:var(--bg-light);
border-radius:20px;
border:2px solid transparent;
cursor:pointer;
transition:all .4s cubic-bezier(.2,1,.3,1);
}

.tagcs-pointer-card:hover,
.tagcs-pointer-card.tagcs-active{
background:var(--bg-light);
border-color:#294671;
/*transform:translateX(15px);*/
box-shadow:15px 15px 40px rgba(0,97,255,.08);
}

.tagcs-pointer-card h3{
color:#294671;
font-size:1.3rem;
margin-bottom:6px;
font-weight:800;
}

.tagcs-pointer-card p{
color:var(--slate);
font-size:.95rem;
line-height:1.5;
margin:0;
}

.tagcs-impact-terminal{
position:sticky;
top:10%;
background:#294671;
border-radius:30px;
padding:40px;
color:#fff;
min-height:550px;
display:flex;
flex-direction:column;
justify-content:space-between;
/*box-shadow:0 30px 60px rgba(5,10,31,.2);*/
}

.tagcs-terminal-header{
border-bottom:1px solid rgba(255,255,255,.1);
padding-bottom:20px;
margin-bottom:30px;
}

.tagcs-terminal-status{
color:#294671;
font-family:monospace;
font-weight:700;
letter-spacing:2px;
}

.tagcs-impact-metric{
font-size:4rem;
font-weight:800;
margin:10px 0;
color:#fff;
}

.tagcs-impact-label{
font-size:1rem;
color:rgba(255,255,255,.6);
text-transform:uppercase;
letter-spacing:1px;
}

.tagcs-outcome-list{
list-style:none;
margin-top:30px;
}

.tagcs-outcome-item{
display:flex;
align-items:center;
gap:15px;
margin-bottom:15px;
padding:15px;
background:rgba(255,255,255,.05);
border-radius:12px;
font-size:.95rem;
}

.tagcs-check-icon{
color:#294671;
font-weight:900;
}


/* --- OUTCOMES SECTION --- */
.outcomes-wrapper {
    --primary-blue: #0061FF;
    --deep-navy: #050A1F;
    --muted-slate: #64748b;
    --accent-green: #10b981;

    display: grid;
    grid-template-columns: 0.8fr 1.2fr;
    gap: 80px;
    padding: 120px 8%;
    background: #ffffff;
}

/* Left Column */
.outcomes-left h2 {
    font-size: 3.5rem;
    color: #294671;
    line-height: 1.1;
    margin-bottom: 24px;
}

.outcomes-left p {
    font-size: 1.1rem;
    color: var(--muted-slate);
    line-height: 1.6;
    margin-bottom: 40px;
}

.outcomes-highlight {
    border-left: 3px solid #294671;
    padding-left: 30px;
    margin-bottom: 30px;
}

.highlight-value {
    font-size: 3rem;
    font-weight: 800;
    color: #294671;
    display: block;
}

.highlight-label {
    font-size: 0.9rem;
    text-transform: uppercase;
    letter-spacing: 1px;
    color: var(--muted-slate);
}

/* Right Column Bento */
.outcomes-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    grid-template-rows: repeat(2, 1fr);
    gap: 20px;
}

.outcome-card {
    padding: 40px;
    border-radius: 32px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    transition: transform 0.4s ease;
}

.card-dark { 
    background: #294671; 
    color: #fff; 
    grid-row: span 2; 
}

.card-blue { 
    background: #294671; 
    color: #fff; 
}

.card-light { 
    background: #F0F6FF; 
    color: #294671; 
}
.card {
    background-color: #294671 !important;
}
.card-icon {
    font-size: 1.5rem;
    margin-bottom: 20px;
    opacity: 0.8;
}

.card-number {
    font-size: 4.5rem;
    font-weight: 800;
    line-height: 1;
    margin-bottom: 10px;
}

.card-description {
    font-size: 1rem;
    opacity: 0.9;
    line-height: 1.4;
}

.arrow-up {
    color: var(--accent-green);
    font-size: 1.2rem;
    margin-right: 5px;
}

.service-ribbon-wrapper {
    /*display: flex;*/
    justify-content: center;
    padding: 60px 0px;
}

/* MAIN RIBBON */
.service-ribbon {
    position: relative;
    background: linear-gradient(135deg, #294671, #294671);
    color: #fff;
    padding:90px 80px 90px;
    text-align: center;
    border-radius: 18px 18px 0 0;
    width: 100%;
    
    box-shadow: 0 10px 25px rgba(0,0,0,0.08);
}

/* CENTER BOTTOM POINT */
.service-ribbon::after {
    content: "";
    position: absolute;
    bottom: -40px;
    left: 50%;
    transform: translateX(-50%);
    width: 120px;
    height: 80px;
    background: linear-gradient(135deg, #0a73a2, #0b3aa9);
    clip-path: polygon(0 0, 100% 0, 50% 100%);
}

/* TEXT */
.ribbon-small {
    font-size: 12px;
    letter-spacing: 2px;
    margin-bottom: 8px;
    opacity: 0.9;
}

.service-ribbon h3 {
    font-size: 4vw;
    line-height: 1.3;
    margin: 0;
    font-weight: 600;
    color: white;
}

/* -------- RESPONSIVE -------- */

@media (max-width: 768px) {

    .service-ribbon {
        padding: 30px 40px 60px;
    }

    .service-ribbon h3 {
        font-size: 22px;
    }

    .service-ribbon::after {
        width: 90px;
        height: 60px;
        bottom: -30px;
    }
}

@media (max-width: 480px) {

    .service-ribbon {
        padding: 25px 20px 50px;
    }

    .service-ribbon h3 {
        font-size: 18px;
    }

    .ribbon-small {
        font-size: 10px;
    }
}

.process-section{
    display:flex;
    align-items:center;
    justify-content:center;
    gap:80px;
    padding:100px 8%;
    flex-wrap:wrap;
    background:#f8f8f8;
}

/* LEFT BIG CIRCLE */

.big-circle{
    width:280px;
    height:280px;
    border-radius:50%;
    background:#fff;
    display:flex;
    align-items:center;
    justify-content:center;
    text-align:center;
    box-shadow:0 10px 30px rgba(0,0,0,0.08);
    border:8px solid #f2f2f2;
}

.big-circle h3 span{
    font-size:22px;
    font-weight:500;
}

.big-circle i{
    font-size:26px;
    font-style:italic;
}

.big-circle b{
    font-size:32px;
}

/* RIGHT SIDE */

.process-right{
    display:flex;
    flex-direction:column;
    gap:40px;
}

.step-row{
    display:flex;
    align-items:center;
    position:relative;
    gap:25px;
}

/* LINE */

.step-line{
    width:80px;
    height:6px;
    border-radius:10px;
}

.yellow{background:#f7c948;}
.orange{background:#ff7a45;}
.pink{background:#ff3e6c;}

/* CIRCLE */

.step-circle{
    width:70px;
    height:70px;
    border-radius:50%;
    display:flex;
    align-items:center;
    justify-content:center;
    font-size:26px;
    color:#fff;
    box-shadow:0 10px 20px rgba(0,0,0,0.1);
}

/* CONTENT */

.step-content h4{
    margin:0;
    font-size:18px;
}

.step-content p{
    margin:4px 0 0;
    font-size:14px;
    color:#666;
}

/* NUMBER */

.step-number{
    font-size:22px;
    font-weight:600;
    margin-left:10px;
}

/* RESPONSIVE */

@media(max-width:768px){

.process-section{
    flex-direction:column;
    text-align:center;
}

.step-row{
    flex-direction:column;
}

.step-line{
    width:6px;
    height:40px;
}

}



:root {
    --accent-lime: #294671;
    --dark-black: #294671;
    --soft-gray: #666;
    --light-border: #e1e1e1;
}

/* WRAPPER */
.layout-wrapper {
    margin-top: 70px;
    background: white;
    padding: 60px;
    position: relative;
    font-family: sans-serif; /* Added for consistency */
}

/* TOP SECTION */
.top-section {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 40px;
}

.title-block-line {
    width: 60px;
    height: 2px;
    background-color: var(--accent-lime);
    margin-bottom: 20px;
}

.main-heading {
    font-size: 2.5rem;
    font-weight: 700;
    line-height: 1.1;
    margin: 0;
    color: var(--dark-black);
}

.decor-boxes {
    position: relative;
    width: 60px;
    height: 60px;
}

.box-shape {
    width: 35px;
    height: 35px;
    position: absolute;
}

.box-dark { background: var(--dark-black); top: 0; right: 0; z-index: 2; }
.box-accent { background: var(--accent-lime); bottom: 0; left: 0; z-index: 1; }

/* CONTENT SECTION */
.content-section {
    display: grid;
    grid-template-columns: 1.2fr 1fr;
    gap: 40px;
}

.primary-image img {
    width: 100%;
    height: auto;
    border-radius: 15px;
    display: block;
}

.text-area {
    display: flex;
    flex-direction: column;
}

.text-description {
    color: var(--soft-gray);
    font-size: 0.95rem;
    line-height: 1.6;
    margin-bottom: 25px;
}

/* CLIENT SPECIFICATION TABLE */
.client-spec-table {
    margin-top: 20px;
    border-top: 1px solid var(--light-border);
    padding-top: 20px;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
}

.spec-column h5 {
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 1.2px;
    color: var(--soft-gray);
    margin: 0 0 5px 0;
}

.spec-column p {
    font-size: 1.1rem;
    font-weight: 600;
    color: var(--dark-black);
    margin: 0;
}

/* BADGE */
.badge-wrapper {
    margin-top: 40px;
    display: flex;
    justify-content: flex-start;
}

.circular-badge {
    position: relative;
    width: 130px;
    height: 130px;
}

.circular-badge svg {
    width: 100%;
    height: 100%;
    animation: spin 20s linear infinite;
}

.circular-badge text {
    font-weight: 700;
    font-size: 10px;
    letter-spacing: 2px;
    fill: #333;
}

.badge-center {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 50px;
    height: 50px;
    background: var(--accent-lime);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
}

.badge-arrow {
    font-size: 20px;
}

@keyframes spin {
    from { transform: rotate(0deg); }
    to { transform: rotate(360deg); }
}

/* RESPONSIVE */
@media (max-width: 992px) {
    .content-section {
        grid-template-columns: 1fr;
    }
    .layout-wrapper {
        padding: 30px;
    }
}


   .step-label {
            color: #4a90e2;
            text-transform: uppercase;
            font-size: 12px;
            font-weight: bold;
            letter-spacing: 1px;
            display: flex;
            align-items: center;
            gap: 8px;
            margin-bottom: 10px;
        }

        .step-label::before {
            content: '';
            width: 8px;
            height: 8px;
            background-color: #4a90e2;
            border-radius: 50%;
        }

        .title-row {
            display: flex;
            justify-content: space-between;
            align-items: center;
        }

      
        .lines {
            flex-grow: 1;
            height: 1px;
            background-color: #294671;
            margin-left: 40px;
        }

        /* Grid Layout */
        .process-grid {
            display: flex;
            gap: 20px;
            flex-wrap: wrap; /* Allows wrapping on mobile */
        }

        /* Card Styles */
        .card {
            background-color: #294671; /* Muted purple-blue card */
            flex: 1;
            min-width: 220px;
            padding: 40px 30px;
            border-radius: 20px;
            display: flex;
            flex-direction: column;
            justify-content: space-between;
            /*min-height: 350px;*/
            transition: transform 0.3s ease;
        }

        .card:hover {
            transform: translateY(-10px);
            background-color: #294671;
        }

        .card-number {
            font-size: 1.2rem;
            font-weight: bold;
            margin-bottom: 10px;
        }

        .card-title {
            font-size: 1.5rem;
            font-weight: 500;
            margin-bottom: auto;
            line-height: 1.3;
        }

        .card-description {
            font-size: 0.9rem;
            color: white;
            line-height: 1.6;
            /*margin-top: 40px;*/
        }

        /* Responsive adjustments */
        @media (max-width: 768px) {
            .title-row { flex-direction: column; align-items: flex-start; }
            .lines { display: none; }
           
        }