:root {
    --base-font-size: max(1rem, 15px);
    --side-padding: 2.2rem;
    --inner-side-padding: 1.55rem;
      --color-aai: #ff6b6b;
      --color-idp: #ffa100;
      --color-rpa: #fedc61;
      --color-nlp: #7fcfff;
      --color-cai: #49f9e0;
      --color-tau: #9ef97d;
      --color-iwf: #c084f5;
    }
html{overflow-x: hidden}
.bg--dark.bg--gray {
    background-color: #72727c !important;
}
.bg--dark.bg--gray {
    background-color: #72727c !important;
}
.bg--dark {
    background-color: #000;
}
p {
    font-weight: 400
}
body {
    /* font-family: Overused Grotesk-haas-grotesk-display, sans-serif;*/ font-family: "Overused Grotesk", sans-serif;
    background-color: #000 !important;
    -webkit-font-smoothing: antialiased; overflow-x: hidden;
}
h1, h2,  .h1, .h2, .h3, .h4, .h5, .h6 {
    font-family: "sfp", sans-serif;
    line-height: 1;
    color: #fff;
}

h4 a {font-weight: 500 !important;}
h3, h4, h5, h6{ font-family: "overused grotesk", sans-serif;
    line-height: 1;
    color: #fff;}
a {
    text-decoration: none !important;
}
* a:hover {
    text-decoration: none;
    cursor: pointer !important;
}
.title--heading h1 {
    text-shadow: 2px 2px 2px rgba(0, 0, 0, 0.2);
}
h2.h2 {
    font-size: 3.6vw;
    letter-spacing: -0.1vw;
    font-weight: 500;
    line-height: .9;
}
h2 {
    font-size: 48px;
    line-height: 1.07143;
    letter-spacing: -2.5px;
}
h3 {
    font-size: 3.78571429em;
}

#observer-slides p:not(:has(a)) {
  /* styles for <p> without <a> inside */
 letter-spacing: -1px;
}


h3::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  height: 1px;
  width: 100%;
  background-color: #dee2e6;
  transform-origin: left center;
  transform: scaleX(0);
}
.subpage h2 {
    font-size: 4vw;
    line-height: 1.07143;
    font-weight: 600;
    letter-spacing: -1.5px !important;
}
h4 {
    font-size: 1.8em;
}
.we-400 {
    font-weight: 400 !important
}
.we-500 {
    font-weight: 500 !important
}
.we-600 {
    font-weight: 600 !important
}
.we-700 {
    font-weight: 700 !important
}
h2.big-title {
    font-size: 5.5vw !important;
    font-weight: 600;
    line-height: 1;
    margin-bottom: 0;
    letter-spacing: -4px !important;
}
h2.news-title {
    font-size: 3vmax !important;
    font-weight: 500;
    line-height: 1;
    margin-bottom: 0;
    margin-left: 40px;
    letter-spacing: -0.1vw;
    color: #000
}
h2.project-title {
    font-size: 64px !important;
    font-weight: 500;
    line-height: 10vh;
    margin-bottom: 0;
    letter-spacing: -0.1vw;
    color: #000;
}
/*h3 span {
    font-weight: 700;
    line-height: 1;
    font-size: 80%; position: relative;
}*/

h2.use-case {
  font-size: 2.2cqw;
  letter-spacing: -1px;
}
.sectors h3 {
    font-size: 40px;
}
p.desc {}
.btn--primary-1 {
    background-color: #000 !important;
    background: #000 !important;
    border: none;
    border-radius: 100px
}
.btn--primary-1 span {
    color: #fff;
}
.hww h4 {
    font-size: 24px;
    color: #000 !important;
    font-weight: 700;
}
.no-border {
    border: 0 !important;
}
.h2-container span.fw-400 {
    font-weight: 400;
}
.material-symbols-rounded {
    font-family: 'Material Symbols Rounded';
    font-weight: normal;
    font-style: normal;
    font-size: 24px;
    line-height: 1;
    letter-spacing: normal;
    text-transform: none;
    display: inline-block;
    white-space: nowrap;
    word-wrap: normal;
    direction: ltr;
    -moz-font-feature-settings: 'liga';
    -moz-osx-font-smoothing: grayscale;
}
.slider h2 {
    font-size: 80px;
    letter-spacing: -0.22vmin;
    margin-bottom: 25px;
    line-height: .9;
}
sup.register {
    font-size: 2.5vw;
}
[data-overlay]::before {
    mix-blend-mode: multiply;
}
.earth {
    background-repeat: no-repeat !important;
    background-size: 33% !important;
    background-position-x: right !important;
    background-image: url("../images/globe.jpg");
    opacity: 0.8;
    background-position-y: center;
}
ul.list {
    font-size: 18px;
    line-height: 1.5;
    margin-left: 30px;
    list-style: disclosure-closed; color:#fff;
}
ul.list ul {
    margin-left: 20px;
    list-style: circle;
}
h3.figures, h3.projects {
    font-size: 5vw;
    margin-bottom: 0px;
    line-height: 1
}
h3.figure-title {
    font-size: 28px;
    margin-bottom: 0px;
   /* /* font-family: Gotham; */*/
    font-weight: 500;
}
span.counter1 {
    font-size: 5vw;
}
span.plus {
    font-size: 5vw;
}
h3.figures span {
    line-height: 5vw;
}
p.figure-title {
    margin-bottom: -5px;
    font-size: 24px;
    font-weight: 700;
    color: darkorange;
    margin-top: 25px;
}
.blacking {
    color: lightgray;
}
strong {
    font-weight: 600;
}
.black-button {
    padding: 6px 25px;
    padding-top: 6px;
    background: black;
    padding-top: 5px;
    border-radius: 200px;
    color: #fff;
    position: relative;
}
.title.title-x {
    border-top: 0px solid var(--wst-orange);
    padding: 4vh 2vw;
    padding-top: 2vh;
    background: black;
    background: rgba(73, 73, 73, 0);
    backdrop-filter: blur(10px) saturate(40%);
    -webkit-backdrop-filter: blur(16px) saturate(30%);
    border-radius: 12px;
    box-shadow: 2.8px 2.8px 2.2px rgb(0 0 0 / 2%), 6.7px 6.7px 5.3px rgb(0 0 0 / 3%), 12.5px 12.5px 10px rgb(0 0 0 / 4%), 22.3px 22.3px 17.9px rgb(0 0 0 / 4%), 41.8px 41.8px 33.4px rgb(0 0 0 / 5%), 100px 100px 80px rgb(0 0 0 / 7%);
}
.video-cover {
    box-shadow: 2.8px 2.8px 2.2px rgb(0 0 0 / 2%), 6.7px 6.7px 5.3px rgb(0 0 0 / 3%), 12.5px 12.5px 10px rgb(0 0 0 / 4%), 22.3px 22.3px 17.9px rgb(0 0 0 / 4%), 41.8px 41.8px 33.4px rgb(0 0 0 / 5%), 100px 100px 80px rgb(0 0 0 / 7%);
}
#page-title1 {}
.glass-container {
    height: 70vh;
    /*max-height: calc(90vh - env(safe-area-inset-top) - env(safe-area-inset-bottom)); */
}
p {
    font-weight: 400;
    font-size: 1.5625rem;
    color: #D5D5D5;
}
p.lead {
 color: #a2a2a2;
  line-height: 1.1;
  font-size: 31px;
}
.black-button:hover {
    color: orange;
    text-decoration: none;
}
.sm-arrow {
    font-size: 14px !important;
    line-height: 14px !important;
    vertical-align: middle;
}
img.menu-logo {
    height: 30px;
    left: 54px;
    top: 50px;
    position: absolute;
    opacity: .8;
}
.flickity-prev-next-button {
 background: #272727;
  width: 50px;
  height: 50px;

  opacity: .9;
  border-radius: 500px;
}
.border-4em{border-radius: 4em;}
.border-2em{border-radius: 2em;}
.border-1em{border-radius: 1em;}
.padding-50{padding:50px;}
.gray-box{background: #202020;}
.flickity-prev-next-button:hover {
    background: black !important;
}
.flickity-prev-next-button:hover {
    background: black !important;
}
.flickity-prev-next-button::before {
    color: #fff;
}
.pos-vertical-bottom {
    position: absolute !important;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
}
.br-1-w {
    border-right: 1px solid #fff;
}
.br-1-b {
    border-right: 1px solid #000;
}
.hero {
    position: relative;
    width: 100vw;
    height: 100vh;
    /*background-image: url("../images/bg1.jpg");*/
    overflow: hidden;
    background-repeat: no-repeat;
    background-size: cover;
}
.slider .pos-vertical-bottom {
    bottom: 50px;
}
.slider-height {
    height: 100vh;
    height: 100svh
}
.qlink {
    width: 50px;
    height: 50px;
    background: #9f9f9f;
    display: flex;
    /* Define flex container */
    align-items: center;
    /* Center children vertically */
    justify-content: center;
    /* Center children horizontally */
    text-decoration: none;
}
a.qlink:hover {
    text-decoration: none;
}
.qlink span {
    font-size: 30px;
    color: #fff !important;
    left: 1.5px;
    position: relative;
}
h2.how-we-work {
    position: absolute;
    top: 25px;
}
.glass-box .hww {
    background: rgba(255, 255, 255, 0);
    height: 50vh;
    border-radius: 12px;
    padding: 20px;
    backdrop-filter: blur(15px);
    -webkit-backdrop-filter: blur(15px);
    width: 100%;
    margin-right: 25px;
    backdrop-filter: blur(16px) saturate(90%);
    -webkit-backdrop-filter: blur(16px) saturate(107%);
    border-radius: 12px;
    padding: 50px;
}
ul.slide-show {
    /*  padding-top: 200px;
  padding-bottom: 250px;*/
}
.sliding {
    overflow: hidden;
}
.pillar-text {
    background-color: white;
    background-image: url("../images/halftone.jpg");
    /*background-size: cover; background-repeat: no-repeat; background-attachment: fixed; background-position: center; */
    background-color: white;
    background-image: url("../images/halftone.jpg");
    background-attachment: scroll !important;
    background-repeat: no-repeat;
    background-size: cover;
    position: relative;
}
.pillar-text p.desc {
    color: #484848 !important;
    font-size: 1.5vmin;
    bottom: 10%;
    letter-spacing: -0.5px;
    font-weight: 600;
    line-height: 1;
}
.slide-show {
    display: flex;
}
.product {
    position: relative;
    flex: 0 0 auto;
    max-width: 50vw;
    overflow: hidden;
    margin-bottom: 0.92857143em;
}
.product h4 {
    color: black !important;
   /* /* font-family: Gotham; */*/
    font-weight: 500;
    font-size: 2.2vmin;
    line-height: 1;
}
.process-icon {
    width: auto;
    height: 100px;
    margin: auto;
    margin-left: auto;
    text-align: center;
    display: block;
}
.welcome {
    position: absolute;
    top: 50%
}
p.icon-container {
    position: absolute;
    top: calc(50% - 50px);
    left: calc(50% - 50px);
}
.product-number {
    position: relative;
    right: 10px;
    font-size: 250px;
    color: #fff;
    opacity: .3;
    /* font-family: Gotham; */
    font-weight: 700;
    color: #8080802e !important;
    display: none;
}
.tl-border {
    border-top: 1px solid #262626;
    border-left: 1px solid #262626
}
.logo-box {
    padding: 30px;
    border-bottom: 1px solid #262626;
    border-right: 1px solid #262626;
}
.logo-box img {
    height: 24px;
    filter: brightness(0) invert(1);
}
img.work-image {
    height: 250px;
}
.glass-info {
    position: absolute;
    bottom: 0px;
    left: 0px;
    padding: 25px;
    width: 100%;
    padding-top: 30vh !important;
}
.glass-info::before, .summaryImage::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: linear-gradient(to bottom, transparent 0%, rgba(0, 0, 0, 0.68) 100%);
    mix-blend-mode: multiply;
    /* or choose another blend mode */
}
.glass-title {
    z-index: 1;
    position: relative;
}
.glass-title h5 {
    font-weight: 500;
    color: #fff;
    font-size: 30px;
    margin-bottom: 0px;
    letter-spacing: -0.7px;
    line-height: 1;
}
.glass-title span {
    font-size: 18px;
    color: white;
    font-weight: 500;
}
.slide {
    padding: 0
}
.work-overlay {
    float: right;
    margin: 40px;
}
.work-container {
    margin-bottom: 25px;
}
section.pillar-text .h2-container {
    height: 10vh;
    position: absolute;
}
.pillar-text .mimic {
    font-size: 7vw;
    height: 150px;
    position: absolute;
    line-height: 150px;
    color: #d7d7d7;
    letter-spacing: -.2vw;
}
.pillar-text .background-image-holder {
    border-top-left-radius: 12px;
    border-bottom-left-radius: 12px;
    /*filter: grayscale(100%);*/
}
section.glass-animation .h2-container {
    height: 10vh;
    position: inherit;
    background: #fff;
}
ul.slide-show2 {
    padding-top: 0px;
    padding-bottom: 0px;
}
ul:last-child {
    margin: 0;
}
.sliding2 {
    overflow-x: hidden;
}
.slide-show2 {
    display: flex;
    flex-wrap: nowrap;
}
.glass-animation {
    margin: 0;
    padding: 0;
    max-height: 100vh;
}
.icon-container {
    display: flex;
    justify-content: end;
    align-items: center;
    padding: 10px;
    position: absolute;
    z-index: 20;
    top: -15px;
    background: #ffef00 !important;
    border-radius: 12px;
    right: -5px;
}
.process-icon {
    /* Adjust icon styles as needed */
    max-width: 100%;
    /* Ensure the image doesn't exceed its container */
    max-height: 100%;
    /* Ensure the image doesn't exceed its container */
    margin: auto;
    /* Center the image */
    margin-bottom: 0px;
}
#chart {
    border: 0px solid black;
    width: 500px;
    height: 500px;
    /*margin: 50px;*/
    position: relative;
}
svg#svgChart {
    max-width: 500px;
    max-height: 500px;
    width: 100%;
    height: 100%;
}
.axis-label {
 
    font-size: 14px;
    text-anchor: middle;
}
.product-label {

    font-size: 12px;
    fill: black;
    /* Or any other color you prefer */
    text-anchor: end;
    /* Align text to the end of the anchor point */
}
path {
    stroke-width: 2;
    fill: none;
}
div.static {
    height: 100vh;
}
.v-middle {
    display: flex;
    flex-direction: column;
    justify-content: center;
    height: 100%;
    /* Ensure it takes up the full height of its parent */
}
.sectors .row {
    border-top: 1px solid gray;
}
.sectors .row:first-of-type {
    border-top: 0;
}
.overlap {
    min-height: 100vh;
    position: relative;
    /* Required for pinning */
    overflow: scroll;
    /* Hide overflowed content */
    width: 100%;
    /* Ensure the section takes the full width */
    /* Add your background or styling */
}
.attributes {
    height: 40vh;
}
.rt--90 {
    transform: rotate(-90deg);
}
.footer-211 a {
    text-decoration: none !important;
    color: black;
    font-weight: 700;
}
.footer-211 ul li a {
    font-size: 15px;
    /* font-family: Gotham; */
    font-style: normal;
    font-weight: 600 !important;
    line-height: 30px;
    color: black !important;
    padding: 0;
}
.footer-211 {
    border-top: 1px solid rgba(4, 4, 14, 0.1);
}
.footer-211 p {
    font-size: 15px;
    /* font-family: Gotham; */
    font-style: normal;
    font-weight: 600 !important;
    line-height: 30px;
    padding: 0;
}
h5.footer-title {
    font-size: 1.3em;
    line-height: 1;
    margin-bottom: 1.5714286em;
    letter-spacing: -0.3px;
}
.footer-211 img {
    max-height: 32px;
}
.text-link-sm {
    color: black !important;
    font-size: 14px !important;
    font-weight: 600;
    /* font-family: Gotham; */
}
a.text-link-sm:hover {
    color: gray !important;
}
/* home news*/
/* Custom CSS to style the latest news section */
.card {
    /* box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);  Example shadow, adjust as needed */
   /* border: solid 1px #DFDFDF;*/
}
.card-img-top {
    width: 12vw;
    height: 100%;
    min-height: 18vh;
    object-fit: cover;
    object-position: center;
}
.card-body {
    padding: 24px;
    /* Adjust padding to match your design */
}
.card-title {
    font-size: 22px;
    color: #000;
    font-weight: 500;
    margin-bottom: 0.5rem;
}
.text-muted {
    color: rgb(164, 164, 174) !important;
    /* Default Bootstrap muted text color */
    font-size: 13px;
    font-weight: 600;
    margin-bottom: 40px;
}
.btn-link {
    color: #007bff;
    /* Bootstrap primary color for links */
    text-decoration: none;
    font-weight: bold;
    padding: 0;
    background: none;
    border: none;
    margin-top: 1.5rem;
    /* Align vertically with the title */
}
/* Adjust button on hover */
.btn-link:hover {
    color: #0056b3;
    /* Darken the link color on hover */
}
/* Responsive adjustments */
@media (max-width: 767px) {
    .btn-link {
        margin-top: 0;
        margin-bottom: 1rem;
    }
}
/* Add any additional custom styles needed for your site */
/* end of home news */
.summaryLink {
    height: 33vh;
    display: inline-block;
}
.projectName {
    position: absolute;
    bottom: 20px;
    z-index: 10;
    margin: 0;
}
.projectName h3 {
    color: white;
    margin: 0;
    font-weight: 600;
    font-size: 30px;
    margin-left: 20px;
}
.section .filter-box .input-relativer .select-box-custom {
    font-weight: 500;
    font-size: 14px;
    color: rgba(27, 43, 59, .5);
    cursor: pointer;
}
.section .filter-box .input-relativer .select-box-custom .arrow.down {
    transform: rotate(0deg);
}
.section .filter-box .input-relativer .select-box-custom .arrow {
    width: 14px;
    height: 7px;
    display: block;
    position: absolute;
    right: 0;
    bottom: 31%;
    transition: all .8s;
    background: url("../img/icons/down-up-arrow.svg");
}
.section .filter-box .input-relativer .select-box-custom .dropdown-list {
    background: #f0f0f0;
    padding: 30px;
    position: absolute;
    top: 34px;
    left: -6px;
    display: none;
    width: 103%;
    max-height: 220px;
    overflow-x: hidden;
    z-index: 9;
}
.section .filter-box .input-relativer .select-box-custom .dropdown-list ul {
    list-style: none;
    padding: 0 0 0 8px;
    margin: 0;
}
.section .filter-box .input-relativer .select-box-custom .dropdown-list .styled-checkbox {
    position: absolute;
    opacity: 0;
}
.section .filter-box .input-relativer .select-box-custom .dropdown-list ul li {
    display: block;
    font-weight: 500;
    color: #1b2b3b;
    padding-bottom: 12px;
}
.categories h4 {
    margin-bottom: 5px;
    font-weight: 500;
}
.plogo {
    filter: brightness(6.4%) invert(50%);
}
.categories h5 {
    font-size: 18px;
    margin-bottom: 15px;
}
.categories h5 span.category-name {
    font-weight: 600;
}
h4.technologies-title {
    margin-bottom: 15px;
    border-bottom: solid 1px lightgray;
    padding-bottom: 15px;
    font-weight: 700;
}
.fixed-height {
    position: relative;
    width: 100%;
    /* The padding-top is removed and height is set to enforce the fixed height */
    height: 0;
    padding-top: 56.25%;
    /* 16:9 Aspect Ratio */
    overflow: hidden;
}
.fixed-height img {
    position: absolute;
    top: 50%;
    left: 50%;
    width: 100%;
    height: 100%;
    object-fit: cover;
    /* This will cover the area, cropping the image if necessary */
    transform: translate(-50%, -50%);
}
.vendor-logo {
    /*  padding: 0px;
  position: relative;
  top: 15px;
  display: inline-block;
  bottom: 15px;
  text-align: left;*/
    min-height: 40px;
    display: inline-block;
    vertical-align: middle;
}
.vendor-logo img {
    height: 20px;
}
.title.title-5 {
    backdrop-filter: blur(16px) saturate(90%);
    -webkit-backdrop-filter: blur(16px) saturate(107%);
    background-color: rgba(255, 255, 255, 0.21);
    border-radius: 24px;
    padding: 5vh 3vw;
    box-shadow: -1px 1px 30px 2px rgba(0, 0, 0, 0.14);
    -webkit-box-shadow: -1px 1px 30px 2px rgba(0, 0, 0, 0.14);
    -moz-box-shadow: -1px 1px 30px 2px rgba(0, 0, 0, 0.14);
    border-top-left-radius: 0;
    border-bottom-left-radius: 0;
}
.title--heading h1 {
    font-weight: 60000;
    color: #fff;
    letter-spacing: -2px;
    margin-bottom: 15px;
    color: #fff !important;
    font-size: 3.5vw;
}
.title--subtitle h4 {
    font-weight: 500;
    color: #fff;
    font-size: 1.4vw;
    letter-spacing: -0.5px;
    text-shadow: 1px 1px 2px rgba(0, 0, 0, 0.2);
    line-height: 0.9;
}
.view-box {
    display: none;
}
.tech-explain {
    visibility: collapse;
    height: 0px;
}
.tech-text p strong {
    font-size: 12px;
    font-weight: 600;
    line-height: 1;
}
.tech-text p {
    line-height: 1;
    margin-bottom: 0;
    margin-top: 10px;
}
.tlogo {
    filter: brightness(6.4%) invert(50%);
    height: 22px;
}
.tbox {
    margin-bottom: 20px;
    transition: all .4s;
}
.tbox:hover {
    scale: 1.15;
}
.tcontainer {
    min-height: 100px;
    border-radius: 6px;
    padding-top: 10px;
    background: #f7f7f7;
}
.tbox {
    position: relative;
    /* Needed to position the speech balloon absolutely relative to tbox */
}
.tech-explain {
    position: absolute;
    bottom: 100%;
    /* Positioning above the tbox */
    left: 50%;
    /* Centering */
    transform: translateX(-50%);
    /* Fine-tuning the centering */
    width: 200px;
    /* Width of the balloon */
    background-color: black;
    border: none !important;
    border-radius: 5px;
    padding: 10px;
    box-shadow: 0 2px 5px rgba(0, 0, 0, 0.2);
    visibility: hidden;
    opacity: 0;
    color: white;
    transition: visibility 0s, opacity 0.5s linear;
    padding: 15px;
}
.tech-explain::after {
    content: "";
    position: absolute;
    top: 100%;
    /* Bottom of the balloon */
    left: 50%;
    border-width: 10px;
    border-style: solid;
    border-color: black transparent transparent transparent;
    transform: translateX(-50%);
}
.tbox:hover .tech-explain {
    visibility: visible;
    opacity: 1;
    font-size: 14px;
    height: fit-content;
    backdrop-filter: blur(16px) saturate(90%);
    -webkit-backdrop-filter: blur(16px) saturate(107%);
    background-color: rgba(36, 42, 104, 0.21));
    border-radius: 6px;
    box-shadow: -1px 1px 30px 2px rgba(0, 0, 0, 0.14);
    -webkit-box-shadow: -1px 1px 30px 2px rgba(0, 0, 0, 0.14);
    -moz-box-shadow: -1px 1px 30px 2px rgba(0, 0, 0, 0.14);
    line-height: 1.2;
    font-weight: 600;
    text-align: left;
}
.tech-text a:hover {
    text-decoration: none;
    color: inherit;
}
.img-shadow {
    box-shadow: -1px 1px 30px 2px rgba(0, 0, 0, 0.14);
    -webkit-box-shadow: -1px 1px 30px 2px rgba(0, 0, 0, 0.14);
    -moz-box-shadow: -1px 1px 30px 2px rgba(0, 0, 0, 0.14);
}
ul.list:last-child {
    margin-left: 30px;
}
.spec-box {
    border-left: 1px solid lightgray;
    padding: 2em;
}
.spec-box p, .spec-box ul {
    font-size: 1.1rem;
}
.feature-2 p {
    margin-bottom: 15px;
}
.ref-title p {
    background: #000;
    color: #fff;
    padding: 10px 15px;
    font-weight: 500;
    font-size: 16px;
    display: inline-block;
}
div.categories {
    min-height: 100px;
}
.ref-about {
    background: black;
}
/* Define the container with overflow hidden */
.ref-about .image-bg, .ref-container {
    width: 100%;
    /* Set the width and height of your container as needed */
    height: 33vh;
    overflow: hidden;
    /* Hide any content that overflows */
    position: relative;
    width: 100%;
}
.ref-about .col-md-6 {
    padding: 0px !important
}
/* Define the initial state of the element */
.zoom {
    max-width: 100%;
    max-height: 100%;
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center;
    transform: scale(1.1);
    /* Initial state, not zoomed in */
    transition: transform 1.4s ease;
    /* Add easing to the transition */
}
/* Apply the zoom animation on hover */
.zoom:hover {
    transform: scale(1.3);
    /* Zoom to 120% size on hover */
    transition: transform 1.2s ease;
    /* Add easing to the hover transition */
}
.self-center {
    align-self: center;
}
.process-1::before {
    background: #bdbdbd;
}
.process__item::after {
    border: 2px solid #bdbdbd;
}
.glass-effect {
    background: rgba(255, 255, 255, 0);
    backdrop-filter: blur(15px);
    -webkit-backdrop-filter: blur(15px);
    backdrop-filter: blur(16px) saturate(90%);
    -webkit-backdrop-filter: blur(16px) saturate(107%);
}
.bg-head {
    position: relative;
}
.mimic1 {
    font-size: 7vw;
    height: 150px;
    position: absolute;
    line-height: 150px;
    color: #d7d7d7;
    letter-spacing: -.2vw;
}
/*.history::before {
  content: "Our History";
  font-size: 20vw;
  color: #F0F0F0;
  position: absolute;
  letter-spacing: -1.5vw;
  margin-top: 20vh;
  padding-left: 5vw;
}*/
/*.subpage img {margin-bottom: 3rem;}*/
.tech-logo img {
    margin: 0px;
}
.other-category-item img {
    margin-bottom: 5px;
    border-radius: 6px;
    box-shadow: 0px 0px 20px 0px rgba(0, 0, 0, 0.06);
}
a .inner {
    color: black;
    /* font-family: Gotham; */
    font-weight: 600;
}
.mask-dark {
    background: black;
}
.mask-light {
    background: white;
}
.mask-dark img {
    mix-blend-mode: darken;
}
.mask-light img {
    mix-blend-mode: lighten;
}
.flickity-page-dots {
    position: absolute;
    /* bottom: 30px !important;*/
}
.hero .slider[data-paging="true"]:not(section) {
    margin-bottom: q !important;
}
/* slide animation */
.slide-animate-nav {
    width: 100%;
    position: absolute;
    bottom: 30px;
    z-index: 4;
    display: none;
}
.col-xl-2dot4 {
    -webkit-box-flex: 0;
    -ms-flex: 0 0 20%;
    flex: 0 0 20%;
    max-width: 20%;
    opacity: 0.6;
    transition: all;
}
.col-xl-2dot4.is-selected {
    opacity: 1
}
.bullet-number {
    display: inline-grid;
    font-size: 24px;
    color: white;
    font-weight: 700;
    margin-right: 15px;
    margin-top: 21px;
    line-height: 1;
}
.bullet-text {
    display: inline-grid;
    font-weight: 600;
    font-size: 24px;
    color: #fff;
    line-height: 1;
    padding: 0;
    margin: 0;
    letter-spacing: -1px;
}
.g-padding {
    padding-left: 60px;
    padding-right: 60px;
}
.animate-white-bullet {
    position: relative;
    border-radius: 0;
    width: auto;
    height: auto;
    border-bottom: 3px solid rgba(255, 255, 255, .5);
    opacity: 1;
    -webkit-transition: all .3s ease-out;
    transition: all .3s ease-out;
}
.slider[data-paging="true"]:not(section) {
    margin-bottom: 0;
}
.hero .flickity-page-dots {
    display: none;
}
.slide-animate-nav .col-xl-2dot4 {
    cursor: pointer;
}
.animate-nav-item {
    width: 100%;
    height: 3px;
    /* or your desired height */
    background-color: #fff;
    /* or your desired color */
    transition: width;
}
.navik-menu * {
    font-family: "Overused Grotesk", Arial, sans-serif !important;
    text-transform: none !important;
    font-weight: normal !important;
}
.navik-menu ul li > a {
    font-size: 16px !important;
}
.navik-menu ul ul.second-line li > a {
    font-size: 16px;
  /*  font-family: Overused Grotesk, arial;*/
}
.navik-menu ul ul li > a {
    font-style: normal;
}

.imageblock.switchable {overflow-y: hidden;}


.height-100 {
    height: 100vh;
    height: 100svh;
}
.height-90 {
    height: 90vh;
    height: 90svh;
}
.height-80 {
    height: 80vh;
    height: 80svh;
}
.height-70 {
    height: 70vh;
    height: 70svh;
}
.height-60 {
    height: 60vh;
    height: 60svh;
}
.height-50 {
    height: 50vh;
    height: 50svh;
}
.row.technology-logos > div:first-child {
    display: none;
}
.category-name:first-child::after {
    content: '';
    font-size: smaller;
    /* Optional: Adjusts the size of the symbol */
    vertical-align: super;
    /* Optional: Aligns the symbol slightly above the baseline */
    margin-left: -2px;
    /* Optional: Adds a little space before the symbol */
}
div.category-name {
    text-transform: capitalize;
    font-weight: 500;
    font-size: 16px;
    height: 40px;
    line-height: 1;
}
.category-name:not(:first-child)::after {
    content: '\00AE';
    /* Unicode for the registered trademark symbol */
    font-size: smaller;
    /* Optional: Adjusts the size of the symbol */
    vertical-align: super;
    /* Optional: Aligns the symbol slightly above the baseline */
    margin-left: -2px;
    /* Optional: Adds a little space before the symbol */
}
.search-bkg {
    height: auto;
}
/* end of slide animation */
ul.menu-vertical {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    list-style-type: none;
    /* Removes bullet points */
    padding: 0;
    /* Removes default padding */
}
ul.menu-vertical li.input-checkbox {
    margin-right: 10px;
    /* Space between items */
    margin-bottom: 10px;
    /* Space below each item */
    width: inherit;
}
ul.menu-vertical li label span {
    margin-left: 32px;
}
div.dropdown {
    line-height: 45px;
    font-weight: 700;
    font-size: 14px;
}
.grid-item {
    width: 50% !important;
    margin-bottom: 0px;
    margin-top: 0px;
}
.input-checkbox.disabled label span {
    opacity: .2;
}
.title-container {
    text-align: center;
    background: #ffffff85;
    vertical-align: middle;
    display: inline-block;
    padding: 40px;
    display: flex;
    /*backdrop-filter: blur(10px) saturate(40%);
  -webkit-backdrop-filter: blur(16px) saturate(30%);*/
}
.title-container .title--heading h1 {
    font-weight: 600;
    color: #fff;
    letter-spacing: -2px;
    margin-bottom: 0px;
    color: #000 !important;
}
.title--subtitle h4 {
    margin-bottom: 0px;
    text-align: left;
}
.news-summary {
    font-size: 14px;
    font-weight: 600;
	border-radius: 2em;
	background: linear-gradient(160deg, #4169e1 0%, #1e40af 20%, #1d4ed8 40%, #1e3a8a 60%, #0f172a 80%, #000000 100%);
    background-color: rgba(0, 0, 0, 0); border:0px !important; padding: 2em; margin-bottom: 20px;
}
.tabs li.active .tab__title span {
    color: #000;
}
/* marquee */
.glassbox .imageblock > .container, .imageblock > div[class*="col-"]:not(.imageblock__content) {
    padding-top: 10vh;
    padding-bottom: 0;
    float: none;
    overflow: visible;
}
.marquee {
    overflow-x: hidden;
    white-space: nowrap;
    height: 90px;
    /* Set the marquee container height */
    line-height: 90px;
    /* Use line height to assist with vertical centering */
    position: relative;
    /* Position relative to allow absolute positioning inside */
    background: black;
    mask-image: linear-gradient(var(--mask-direction, to right), hsl(0 0% 0% / 0), hsl(0 0% 0% / 1) 20%, hsl(0 0% 0% / 1) 80%, hsl(0 0% 0% / 0));
}
section.marquee-section {
    background: black;
}
.images {
    display: flex;
    /* Use flex display to keep images in a row */
    align-items: center;
    /* Align items vertically in the center */
    height: 100%;
    /* Make sure the .images div takes the full height of the container */
    background: black;
    will-change: transform;
    /* Hint at transform changes for performance */
}
.marquee img {
    height: 20px;
    /* Set your image height */
    margin-right: 40px;
    margin-left: 40px;
    /* Adjust the space between images */
    vertical-align: middle;
    /* Vertically align to middle - works with inline or inline-block elements */
    margin-bottom: 0px;
    filter: brightness(0) invert(1);
}
.section {
    position: relative;
}
.bg-contain {
    background-size: contain !important;
}
.bg-no-repeat {
    background-repeat: no-repeat !important;
}
span.page-desc {
    font-family: sfp;
    font-variation-settings: "wght"400;
    font-size: 16px;
    margin-bottom: 20px;
    padding: 5px 35px;
    background: #ffef00 !important;
    border-radius: 50px;
    color: black !important;
    position: absolute;
    top: -20px;
    font-weight: 500;
    left: -20px;
}
.desc {
   /* font-family: roobert;*/
    font-weight: 500;
    font-size: 16px;
    padding: 5px 35px;
    background: #ffef00 !important;
    border-radius: 50px;
    color: black !important;
    display: inline;
}
.product-container {
    box-shadow: 2.8px 2.8px 2.2px rgb(0 0 0 / 2%), 6.7px 6.7px 5.3px rgb(0 0 0 / 3%), 12.5px 12.5px 10px rgb(0 0 0 / 4%), 22.3px 22.3px 17.9px rgb(0 0 0 / 4%), 41.8px 41.8px 33.4px rgb(0 0 0 / 5%), 100px 100px 80px rgb(0 0 0 / 7%);
    backdrop-filter: blur(16px) saturate(90%);
    -webkit-backdrop-filter: blur(16px) saturate(107%);
    background-color: rgba(255, 255, 255, 0.21);
    border-radius: 12px;
    padding: 40px;
    box-shadow: -1px 1px 30px 2px rgba(0, 0, 0, 0.14);
    -webkit-box-shadow: -1px 1px 30px 2px rgba(0, 0, 0, 0.14);
    -moz-box-shadow: -1px 1px 30px 2px rgba(0, 0, 0, 0.14);
    padding-top: 60px;
    padding-bottom: 60px;
}
.product-image {
    display: block;
    text-align: center;
    margin: auto;
}
.feature-icon {
    width: 24px;
}
.b-shadow-large {
    box-shadow: 2.8px 2.8px 2.2px rgb(0 0 0 / 2%), 6.7px 6.7px 5.3px rgb(0 0 0 / 3%), 12.5px 12.5px 10px rgb(0 0 0 / 4%), 22.3px 22.3px 17.9px rgb(0 0 0 / 4%), 41.8px 41.8px 33.4px rgb(0 0 0 / 5%), 100px 100px 80px rgb(0 0 0 / 7%);
}
.bd-filter {
    backdrop-filter: blur(16px) saturate(100%);
    -webkit-backdrop-filter: blur(16px) saturate(100%);
    background-color: rgb(255 255 255 / 32%);
    border-radius: 12px;
}
.bd-filter-dark {
    backdrop-filter: blur(16px) saturate(100%);
    -webkit-backdrop-filter: blur(16px) saturate(100%);
    background-color: rgba(0, 0, 0, 0.32);
    border-radius: 12px;
}
.bd-filter-dark * {
    color: #fff;
}
.feature-2 {
    padding: 50px;
}
.icon-container {}
.toBlack::before {
    content: '';
    background-color: black;
    height: 25vh;
    height: 25svh;
    mask-image: linear-gradient(to top, transparent, black);
    mask-size: cover;
    position: absolute;
}
.overlays::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: var(--overlay-color, transparent);
    /* Default to transparent if not set */
    mix-blend-mode: var(--overlay-mix-mode, normal);
    /* Default to normal if not set */
}
.labels {
    display: block;
    margin: auto;
    height: 120px;
    margin-bottom: 20px;
}
.title.title-6 {
    /* backdrop-filter: blur(16px) saturate(90%);
  -webkit-backdrop-filter: blur(16px) saturate(107%);*/
    position: absolute;
    bottom: 5vh;
    /* border-bottom-left-radius: 24px;
  padding-left: 50px;
  padding-top: 35px;*/
}
.product-row {
    margin-bottom: 50px;
}
footer .logo {
    height: 36px !important;
}
.mobile-hero {
    height: 100vh;
    height: 100svh
}
.container-100 {
    max-width: 100% !important;
}
.feature h4 + p {
    max-width: 100%;
}
.product-image {
    scale: .8;
}
/*end marquee*/
/*.video-play-icon {
  width: 80px;
  height: 80px;
  border-radius: 50%;
  position: relative;
  z-index: 4;
  display: inline-block;
  border: 0;
  cursor: pointer;
  background: transparent;
}*/
.video-play-icon::before {
    position: absolute;
    top: calc(50% - 8px);
    margin-top: -5px;
    left: 50%;
    margin-left: -7px;
    content: '';
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 12px 0 12px 24px;
}
.navik-header.header-transparent-on {
    background-color: rgba(0, 0, 0, 0.25);
}
.bg-right-bottom {
    background-position: right bottom !important;
}
.bg-man {
    background-position: left center !important;
}
.papyroot {
    width: 150px;
    height: auto;
    z-index: 5000;
    position: fixed;
    left: calc(100vw - 165px);
    bottom: 15px;
}
.papyroot-menu-container {
    z-index: 100;
    left: inherit !important;
    right: 0px !important;
    bottom: 150px;
}
.trans-box {
    border-radius: 12;
    background: #fff;
    box-shadow: 10px 10px 25px
}
.feature h4 {
    font-size: 22px;
    margin-bottom: 15px;
}
.city {
    background-position-y: 80% !important;
    background-size: 90% !important
}
.feature-2:hover {
    background: linear-gradient(345deg, rgba(0, 0, 0, 0.05) 0%, rgba(0, 0, 0, 0.1) 100%);
    border-radius: 16px;
    box-shadow: rgba(0, 0, 0, 0.1) 0px 1px 1px 0px inset;
}
.sticker {
    width: 350px;
    margin: auto;
    text-align: center;
    z-index: 0;
}
.subheader .background-image-holder {
    background-position-y: top !important;
}
.sticker-a {
    display: block;
    margin: auto;
    text-align: center;
}
a:hover {
    /*color: inherit !important*/
}
.navik-menu a:hover {
    color: lightgray !important
}
h4 {
    margin-top: 25px !important;
}
.borderw {
    border: rgba(255, 255, 255, 0.5);
}
.borderb {
    border: rgba(0, 0, 0, 0.5);
    color: black;
}
.buttonc {
    --padding-left: .7em;
    --padding-right: 1.025em;
    display: inline-flex;
    justify-content: space-between;
    align-items: center;
    min-width: 11.2em;
    height: 2.45em;
    padding-left: var(--padding-left);
    padding-right: var(--padding-right);
    position: relative;
    font-size: 1.25rem;
    white-space: nowrap;
    -webkit-user-select: none;
    -moz-user-select: none;
    user-select: none;
    /*font-family: Overused Grotesk, sans-serif;*/
    border: 1px solid;
    font-weight: 300 !important;
}
.button-icon {
    width: 1.36565em;
    height: 1.07795em;
}
a.buttonc {
    font-size: 24px;
}
.buttonc::before {
    content: "";
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    border: 1px solid rgba(51, 51, 51, .5);
    border-top-width: 1px;
    border-top-color: rgba(51, 51, 51, 0.5);
    border-right-width: 1px;
    border-right-color: rgba(51, 51, 51, 0.5);
    border-bottom-width: 1px;
    border-bottom-color: rgba(51, 51, 51, 0.5);
    border-left-width: 1px;
    border-left-color: rgba(51, 51, 51, 0.5);
    transition: border-color .15s;
}
.bg--dark .whiting span, .whiting span {
    color: rgba(16, 16, 16, 1.00);
}
.image--light .whiting {
    /*  color: black !important;*/
}
.whiting {
    /* color: black !important;*/
}
.arrow-top-left {
    width: 60px;
    top: 10px;
    position: relative;
}
.navik-menu ul ul li > a {
    line-height: 1;
}
.sans {
    font-family: Overused Grotesk;
}
.border-bottom {
    border-bottom: 1px solid rgba(51, 51, 51, 0.5);
}
h2.figures {
    font-size: 12vw;
    line-height: 1;
    margin-bottom: 25px;
    font-family: Overused Grotesk, arial;
    font-weight: 200;
}
p.legend {
    font-size: 2.5vw;
    letter-spacing: -2px;
    line-height: 1
}
.navik-menu {
    background: transparent !important;
}
.subpage h3 {
  border-top: 1px solid #dee2e6 ;
  margin-bottom: 0.7em;
  padding-top: 0.5em;
  font-weight: 600;
  letter-spacing: -2px;
}
.inner {
    margin-top: 60px;
    margin-bottom: 60px;
    overflow: hidden;
    width: 100%
}
.i-image {
    background-position: center center;
   
    background-size: cover;
    background-repeat: no-repeat;
    height: 100vh;
	  position: relative; /* so ::before can be positioned correctly */
  z-index: 0;
   
}
.i-image-resize {
    width: 70vw;
    z-index: 5;
    overflow: hidden;
    z-index: 1;
    position: relative;
    margin: auto;
    height: 100%; 
}

.i-image::before {
  content: "";
  position: absolute;
  inset: 0;
  background-position: center center;
  background-size: cover;
  background-repeat: no-repeat;
  background-image: url("your-image.jpg");
  filter: grayscale(1);
  z-index: -1; /* keeps it behind the content */
	border-radius: 4em;
}




.br-top-1 {
    border-top: 1px solid #ffffff1f
}
.br-right-1 {
    border-right: 1px solid #ffffff1f
}
.br-bottom-1 {
	border-bottom: 1px solid #ffffff1f}
.footer-grid div {
    margin: 0 !important;
    padding: 0px;
}
.footer-grid {
    margin: 0px;
    padding: 0px;
    /*background: #0072ff;*/
}
p strong {
    font-weight: 600; color:white;
}
.footer-grid .column {
    padding: 20px;
    padding-left: 30px;
    padding-bottom: 0px;
    min-height: 22em;
}
.neue {
    font-family: Overused Grotesk !important;
}
h5 {
    font-size: 1.4em;
    font-weight: 300
}
h5.neue {
    margin-bottom: 10px;
}
.menu-items {
    font-size: 15px;
}
.menu-items a, .column a {
    color: #f7f7f7;
    font-weight: 300;
}
.footer-grid ul.list {
    list-style: none;
    margin-left: 0px;
}
.footer-grid p {
    font-size: 15px;
    margin-bottom: 15px;
}
textarea[name="Message"] {
    height: 100px;
}
input[type], textarea, select {
    -webkit-appearance: none;
    background: transparent;
    padding: 0.46428571em;
    padding-left: 0.464286em;
    border-radius: 0px;
    border: none;
    border-bottom: 1px solid #ececec;
}
.submit-button {
    margin-top: 20px;
    float: right;
}
input[type]::placeholder, textarea::placeholder, select::placeholder {
    color: #fafafa;
    font-size: 1em;
}
.border-top {
    padding-top: 12px;
}
h2.message {
    font-size: 48px;
    line-height: 1.07143;
    letter-spacing: -2.5px;
}
.navik-header {
    background: transparent
}
.footer-grid form {
    padding-bottom: 40px;
}
.footer-grid p.lead {
    font-size: 30px;
}
.slider.testimonials {
    padding-bottom: 50px;
}
.logo img {
    transition: opacity 0.5s ease-in-out; /* Smooth transition of opacity */
}
.logo img:not([src*="logo-light.png"]) {
    opacity: 0; /* Hidden when it's not the default logo */
}
.logo img[src*="logo-dark.png"] {
    opacity: 1; /* Visible when the sticky logo is active */
}
ol.flickity-page-dots li {
    padding-top: 0px !important
}
.flickity-prev-next-button {top:100%}
.canvas-wrapper {
    position: relative;
    width: 100vw;
    height: 100vh;
    overflow: hidden;
    background: black;
}
#canvas3d {
    width: 100%;
    height: 100%;
    display: block;
    position: absolute;
    top: 0;
    left: 0;
   /* mix-blend-mode: luminosity;*/
    z-index: 20;
    pointer-events: none;
}
#app {
    height: 100vh;
    overflow-y: auto;
    background: #0a52bf;
    background: radial-gradient(circle, rgb(0, 38, 95) 0%, rgb(0, 0, 0) 50%);
    position: relative;
    max-height: 100vh; overflow: hidden;
}
.bg--black {
    background-color: #000;
    padding: 3.5rem
}

.grad-pink div {
    background: linear-gradient(to bottom, #676767, #fff);
    background-clip: text;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    color: transparent;
    display: inline-block;
}
.blue-bg {
    font-size: 18px;
    font-weight: bold;
    color: #FFFFFF;
    padding: 12px 24px;
    border: none;
    cursor: pointer;
    background: linear-gradient(120deg, #5a79ff, #6f35a1);
    border-radius: 12px;
    text-transform: none;
    transition: all 0.3s ease-in-out;
}
.blue-bg:hover {
    background: linear-gradient(120deg, #6f35a1, #5a79ff);
    transform: scale(1.05);
    color: white; cursor: auto;
}
.blue-bg:hover span {
    color: white;
}
.home-about {
    background-image: url("../images/bg-1.jpg");
    background-repeat: no-repeat;
    background-position: left center;
    background-size: contain
}
.contain {
    background-size: contain
}
.sf-bottom {
    position: relative;
    overflow: hidden;
}
.sf-bottom::after {
    content: "";
    position: absolute;
    bottom: -2px;
    left: 0;
    width: 100%;
    height: 15%;
    pointer-events: none;
    z-index: 10;
    background: linear-gradient(to bottom, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.03) 15%, rgba(0, 0, 0, 0.07) 30%, rgba(0, 0, 0, 0.15) 40%, rgba(0, 0, 0, 0.35) 55%, rgba(0, 0, 0, 0.65) 70%, rgba(0, 0, 0, 0.9) 85%, rgba(0, 0, 0, 1) 100%);
}
.sfb {
    mask-image: linear-gradient(to bottom, rgba(0, 0, 0, 1) 85%, rgba(0, 0, 0, 0) 100%);
    -webkit-mask-image: linear-gradient(to bottom, rgba(0, 0, 0, 1) 85%, rgba(0, 0, 0, 0) 100%);
}
.sf-top {
    position: relative;
    overflow: hidden;
}
.sf-top::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 15%;
    pointer-events: none;
    z-index: 12;
    background: linear-gradient(to top, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.03) 15%, rgba(0, 0, 0, 0.07) 30%, rgba(0, 0, 0, 0.15) 40%, rgba(0, 0, 0, 0.35) 55%, rgba(0, 0, 0, 0.65) 70%, rgba(0, 0, 0, 0.9) 85%, rgba(0, 0, 0, 1) 100%);
}
.custom-card {
    position: relative;
    aspect-ratio: 1 / 1;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    align-items: center;
    /*background-color: rgba(33, 37, 41, 0.6);*/
    border-radius: 1rem;
    padding: 1.5rem;
    /* border: 1px solid rgba(255, 255, 255, 0.05);*/
    box-shadow: 0 15px 35px rgba(0, 0, 0, 0.2);
    backdrop-filter: blur(6px);
    transition: all 0.3s ease;
    color: white;
    overflow: hidden;
}
/* .custom-card::before {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: 1rem;
    border: 1px solid rgba(255, 255, 255, 0.50);
   mask-image: linear-gradient(to bottom, rgba(255, 255, 255, 0.3) 0%, rgba(255, 255, 255, 0.05) 80%, transparent 100%);
    -webkit-mask-image: linear-gradient(to bottom, rgba(255, 255, 255, 0.3) 0%, rgba(255, 255, 255, 0.05) 80%, transparent 100%);
    pointer-events: none;
}*/

.service-cards .custom-card{background-size:cover; aspect-ratio:auto; display:relative;}
.service-cards .custom-card h3{ font-size: 1.4cqw; margin-bottom: 5px !important; padding-bottom: 10px;}
.service-cards .custom-card p{padding-bottom: 30px;}
.service-cards .custom-card img {width: 1.2cqw; height: auto;}
.service-cards .inline-tags {margin-bottom: 20px;}

#products .custom-card{background-size:cover !important;}
.custom-card2 {
    position: relative;
    aspect-ratio: 2 / 1;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    align-items: center;
    /*background-color: blue;*/
    border-radius: 1rem;
    padding: 1.5rem;
    /* border: 1px solid rgba(255, 255, 255, 0.05);*/
    box-shadow: 0 15px 35px rgba(0, 0, 0, 0.2);
    backdrop-filter: blur(6px);
    transition: all 0.3s ease;
    color: white;
    overflow: hidden;
}
.custom-card2::before {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: 1rem;
    border: 1px solid rgba(255, 255, 255, 0.50);
    mask-image: linear-gradient(to bottom, rgba(255, 255, 255, 0.3) 0%, rgba(255, 255, 255, 0.05) 80%, transparent 100%);
    -webkit-mask-image: linear-gradient(to bottom, rgba(255, 255, 255, 0.3) 0%, rgba(255, 255, 255, 0.05) 80%, transparent 100%);
    pointer-events: none;
}
.card-top {
    display: flex;
    justify-content: flex-start;
    align-items: flex-start;
    align-self: flex-start; /* <-- THIS overrides parent centering */
}
.card-center {
    text-align: left;
}
.card-bottom {
    width: 100%;
    display: flex;
    justify-content: space-between;
    padding: 0 0.5rem;
}
/*.custom-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 20px 40px rgba(0, 123, 255, 0.2);
    background-color: #0000ffb8;
}*/
.whiting span {
    display: inline-block;
}
/*.word {
  white-space: normal;
}*/
.word {
    display: inline-block;
}
.word span {
    display: inline-block;
}
.custom-card p { /*font-size: 1.35cqw;*/
	font-size:16px; line-height: 1.1
}
.custom-card.blue {
    background-color: rgba(8, 113, 248, 0.6);
}
.custom-card.black {
    background-color: rgba(8, 113, 248, 0.6);
}
.custom-card h3 {
    font-size: 2.5rem;
    line-height: 1.2 !important;
}
.panel .custom-card, .panel .custom-card:hover {
    box-shadow: none !important;
    transform: none !important;
}
.card-icon {
    width: 2cqw;
    max-width: 36px;
    margin-bottom: 12px !important;
}
.bg-no-repeat {
    background-repeat: no-repeat !important
}
.text-grad-down, .custom-card h3 {
    -webkit-mask-image: linear-gradient(to bottom, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 1));
    -webkit-mask-size: 100% 100%;
    -webkit-mask-repeat: no-repeat;
    mask-image: linear-gradient(to bottom, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 1));
    mask-size: 100% 100%;
    mask-repeat: no-repeat;
    line-height: normal
}
/*.btn.more {
    box-shadow: 0 20px 40px rgba(0, 123, 255, 0.2);
    background-color: rgba(8, 113, 248, 0.96);
    border-radius: 6px;
    font-size: 14px;
    font-family: Readex Pro;
    font-weight: 300;
    color: #fff;
    border: none !important;
    font-weight: 300 !important;
    border-radius: 400px;
    font-family: bes;
}
.btn.more::before {
    border: 1px solid rgba(255, 255, 255, 0.50);
    content: "";
    mask-image: linear-gradient(to bottom, rgba(255, 255, 255, 0.3) 0%, rgba(255, 255, 255, 0.05) 80%, transparent 100%);
    -webkit-mask-image: linear-gradient(to bottom, rgba(255, 255, 255, 0.3) 0%, rgba(255, 255, 255, 0.05) 80%, transparent 100%);
    position: absolute;
    inset: 0;
    border-radius: 400px;
}*/
.btn.more {
  /* preserve your existing styles */
 display: inline-flex;
  align-items: center;
  justify-content: flex-start;
  box-shadow: 0 20px 40px rgba(0, 123, 255, 0.2);
  background-color: rgba(8, 113, 248, 0.96);
  border: none !important;
  border-radius: 400px;
  font-size: 14px;
  font-family: Overused Grotesk, bes, sans-serif;
  font-weight: 300 !important;
  color: #fff;
  
  position: relative;
  padding-left: 2em;
  padding-right: 4px;
  padding-top: 8px;
  padding-bottom: 8px; min-width: 200px;
}

.btn.more::after {
content: "";
  display: inline-block;
  margin-left: 6em;
  width: 36px;
  height: 36px;
  background-color: rgba(255, 255, 255, 0.2);
  background-image: url("../images/arrow.svg");
  background-repeat: no-repeat;
  background-position: center;
  border-radius: 50%;
  flex-shrink: 0;
  margin-right: 0%;
  right: 4px;
  position: absolute;
}


/*.card-center{container-type: inline-size;}*/
.inline-tags {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    font-family: bes;
    letter-spacing: -0.5px;
}
.inline-tags li {
    display: inline-block;
    background: rgba(255, 255, 255, 0.1);
    color: white;
    padding: 0.4em 0.9em;
    border-radius: 999px;
    font-size: 0.875rem;
    line-height: 1.2;
    white-space: nowrap;
}
.bg-box {
    position: relative;
    background-color: rgba(40, 63, 88, 0.6);
    border-radius: 1rem;
    padding: 3.5rem;
    border: 1px solid rgba(255, 255, 255, 0.05);
    box-shadow: 0 15px 35px rgba(0, 0, 0, 0.2);
    backdrop-filter: blur(6px);
    transition: all 0.3s ease;
    overflow: visible;
}
/* webgl x rules */
.webgl {
    position: fixed;
    top: 0;
    left: 0;
    outline: none;
}
.section {
    height: 100vh;
    color: #ffeded;
    padding-left: 10%;
    padding-right: 10%;
}
/* .section:nth-child(odd) {
            justify-content: flex-end;
        }*/
.section {
    pointer-events: none;
}
.webgl {
    position: fixed;
    top: 0;
    left: 0;
    outline: none;
    pointer-events: none;
    z-index: 1;
}
/*  background div styles */
.background-gradient-gl {
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    background: radial-gradient(circle 1200px at center 150%, #214d8e 0%, #010815 100%);
    z-index: 0; /* Lower than canvas z-index */
}
/* end of webgl x */
.gpad {
    padding-left: 2.5%;
    padding-right: 2.5%;
}
/*.custom-card-bg {
  position: relative;
  overflow: hidden;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat; border:none;
}

.custom-card-bg::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.45);
  z-index: 1; border:none;
	
	
}*/
.glass-card::before {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: 20px;
    border: 1px solid white;
    mask-image: linear-gradient(to bottom, rgba(255, 255, 255, 0.3) 0%, rgba(255, 255, 255, 0.05) 80%, transparent 100%);
    -webkit-mask-image: linear-gradient(to bottom, rgba(255, 255, 255, 0.3) 0%, rgba(255, 255, 255, 0.05) 80%, transparent 100%);
    pointer-events: none;
}
.custom-card-bg > * {
    position: relative;
    z-index: 2;
}
.card-healthcare {
    background-image: url('../images/bg-healthcare.webp');
}
.card-manufacturing {
    background-image: url('../images/bg-manufacturing.webp');
}
.card-financial {
    background-image: url('../images/bg-financial.webp');
}
.card-retail {
    background-image: url('../images/bg-retail.webp');
}
.card-education {
    background-image: url('../images/bg-education.webp');
}
.card-logistics {
    background-image: url('../images/bg-logistics.webp');
}
/* hpanel*/
.h-wrapper {
    width: 100vw;
    max-width: 100vw !important;
    overflow-x: hidden;
    background: blue;
}
.h-container {
    width: 700%;
    height: 100%;
    display: flex;
    flex-wrap: nowrap;
    overflow-x: hidden;
    scroll-snap-type: x mandatory;
	
}
.panel {
    position: sticky;
    overscroll-behavior: none;
    scroll-snap-align: start;
    scroll-snap-type: x mandatory;
    /*width: 100%;*/
    display: flex;
    justify-content: center;
    align-items: center;
    font-weight: 600;
    font-size: 1.5em;
    text-align: center;
    color: white;
    box-sizing: border-box;
    padding: 0px;
    height: 100vh;
    max-width: 100vw;
    width: 100vw;
    overflow-y: scroll;
    background-size: 100% !important;
   /* background-position: 10vw 90% !important;*/
}



.panel .custom-card .btn.more { margin-bottom:20px;}
/* hpanel */
.tagline {
    font-family: "Overused Grotesk", sans-serif;
    font-weight: 600;
    font-style: normal;
    font-size: 5.6875vw;
    font-size: 6.5cqw;
    letter-spacing: -0.35vw;
    line-height: 0.9;
    margin-bottom: 40px;
}
.container-fluid {
    max-width: 100vw;
    padding-right: 15px;
    padding-left: 15px;
    margin-right: auto;
    margin-left: auto;
}
.lead-wrap {
    max-width: 40rem;
}
.draw {
    width: 100%;
    height: 2px;
    background-color: black;
    line-height: 0px;
    --trail-length: 30%; /* Adjust trail length */
    mask: linear-gradient(to right, transparent 0%, black var(--trail-length), black 100%);
    -webkit-mask: linear-gradient(to right, transparent 0%, black var(--trail-length), black 100%);
    clip-path: inset(0 100% 0 0);
}
hr {
    border-color: #ECECEC;
}
.hero-messages h2 {
    margin: 0;
    color: white;
    font-family: Overused Grotesk;
    font-weight: 700;
    font-size: 7vw;
    background: linear-gradient(to right, #6b46c1, #a2bdff, #eff4ff, #aa48d9, #6b46c1, #a2bdff);
    background-size: 500% 100%;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    text-fill-color: transparent;
    display: inline-block;
    text-shadow: 2px 3px 5 #000;
    animation: gradientFlow 4s infinite linear;
    letter-spacing: -0.3vw;
}
@keyframes gradientFlow {
    0% {
        background-position: 0% 50%;
    }
    20% {
        background-position: 20% 50%;
    }
    40% {
        background-position: 40% 50%;
    }
    60% {
        background-position: 60% 50%;
    }
    80% {
        background-position: 80% 50%;
    }
    100% {
        background-position: 100% 50%;
    }
}
.hero-messages p {
font-size: clamp(1.25rem, 4vw, 2.5rem);
  margin-top: 0.5rem;
  color: white;
  font-family: 'Overused Grotesk', sans-serif;
  font-weight: 400;
  line-height: 1.2;
  letter-spacing: -1px;
}

.hero-messages {
  position: relative;
  width: 100%;
  height: 100%;
  pointer-events: none;
  overflow: hidden;
}

/* Center each message vertically and animate */
.message {
  position: absolute;
  top: 50%;
  left: 5%; /* matches your `pl-5` */
  transform: translateY(-50%);
  opacity: 0;
  animation: fadeInOut 16s infinite;
  text-align: left;
	width:50%
}

/* Stagger animation start times */
.message:nth-child(1) { animation-delay: 0s; }
.message:nth-child(2) { animation-delay: 4s; }
.message:nth-child(3) { animation-delay: 8s; }
.message:nth-child(4) { animation-delay: 12s; }

/* Animation: fade in (1s), show (2s), fade out (1s) = 4s cycle per message */
@keyframes fadeInOut {
  0%   { opacity: 0; }
  6.25%  { opacity: 1; }
  18.75% { opacity: 1; }
  25%  { opacity: 0; }
  100% { opacity: 0; }
}


/* Adjust delays to stagger messages */
.message:nth-child(1) { animation-delay: 0s; }
.message:nth-child(2) { animation-delay: 4s; }
.message:nth-child(3) { animation-delay: 8s; }
.message:nth-child(4) { animation-delay: 12s; }

/* Animation: 1s fade in, 2s visible, 1s fade out, 12s invisible = 16s loop */
@keyframes fadeInOut {
  0%   { opacity: 0; }
  6.25%  { opacity: 1; }
  18.75% { opacity: 1; }
  25%  { opacity: 0; }
  100% { opacity: 0; }
}

.message h2 {
    line-height: 0.8;
	margin-bottom: -25px;
  padding-bottom: 25px;
}
/* .panel .background-image-holder {
  background-size: 150% auto !important;
  background-position: calc(50% + var(--parallax-offset, 0px)) center !important;
  transition: background-position 0.6s ease-out !important;
}

Alternative approach - simpler 
.panel .background-image-holder {
  background-size: 130% auto !important;
  background-attachment: fixed !important;
  background-position: center center !important;
}*/
/* Or if you want to match your slider's transform approach 
.panel .background-image-holder {
  background-size: 200% !important;
  background-position: calc(50% - var(--panel-index, 0) * 30px) center !important;
  transition: background-position 0.3s ease !important;
}
*/
.panel .custom-card {
    background-color: transparent !important;
    border: none;
}
.panel .custom-card::before {
    border: none;
}
.panel .custom-card h3 {
    font-size: 3.5vw;
    letter-spacing: -3px;
}
/* glowtext */
.glow-text {
    position: relative;
    font-size: 3vw;
    font-weight: 500;
    letter-spacing: -0.015em;
    color: #ffffff;
    filter: brightness(1.1);
    z-index: 1;
    line-height: normal;
    display: inline-flex;
    font-family: sfp;
}
.glow-text::before {
    content: attr(data-text);
    position: absolute;
    inset: 0;
    background: linear-gradient(90deg, #00cfff, #a600ff, #ff006e, #ff8800);
    filter: blur(20px) brightness(0.8);
    opacity: 0.7;
    border-radius: 100px;
    z-index: -1;
    pointer-events: none;
    background-size: 200% 200%;
    animation: gradientShift 12s ease-in-out infinite;
}
.glow-text::after {
    content: attr(data-text);
    position: absolute;
    inset: 0;
    font-size: inherit;
    font-weight: inherit;
    font-family: inherit;
    letter-spacing: inherit;
    background: linear-gradient(90deg, #00cfff, #a600ff, #ff006e, #ff8800);
    background-clip: text;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    mix-blend-mode: color-burn;
    filter: blur(3px) brightness(1.3);
    z-index: 0;
    pointer-events: none;
    background-size: 200% 200%;
    animation: gradientShift 6s ease-in-out infinite;
}
@keyframes gradientShift {
    0% {
        background-position: 0% 50%;
    }
    50% {
        background-position: 100% 50%;
    }
    100% {
        background-position: 0% 50%;
    }
}
/* glowtext */
.content-wrapper {
    display: flex;
    flex-direction: column;
    justify-content: center;
    height: 100%;
    min-height: 100%; /* Helps ensure full column height if needed */
}
.heading-block h2 {
    margin-bottom: 1rem;
}
.text-block p {}
.line-mask {}
.h-100 {
    height: 100vh !important
}
@font-face {
    font-display: swap;
    font-family: Mori;
    font-style: normal;
    font-weight: 400;
    src: url(https://assets.codepen.io/16327/PPMori-Regular.woff) format("woff");
}
/*[data-split="heading"]{line-height: 1.2 !important }*/
.line {
    line-height: 1;
    box-sizing: border-box;
    width: 100%;
}
.line-mask {
    padding-bottom: 20px;
    margin-bottom: -20px;
}
.grid-lines {
  background-image: 
    /* Main grid (stronger lines) */
    linear-gradient(rgba(255, 255, 255, 0.15) 1px, transparent 1px), 
    linear-gradient(90deg, rgba(255, 255, 255, 0.15) 1px, transparent 1px), 

    /* Subgrid (softer lines) */
    linear-gradient(rgba(255, 255, 255, 0.08) 0.5px, transparent 0.5px), 
    linear-gradient(90deg, rgba(255, 255, 255, 0.08) 0.5px, transparent 0.5px);
  
  /* Grid size = 4vw */
  background-size: 4vw 4vw, 4vw 4vw, 1vw 1vw, 1vw 1vw;
  
  background-position: -0.5px -0.5px, -0.5px -0.5px, -0.25px -0.25px, -0.25px -0.25px;
}


/* logo setup */
.logo-container {
    display: flex;
    justify-content: space-evenly; /* Evenly distributes logos */
    align-items: center; /* Default vertical centering */
    flex-wrap: wrap;
    gap: 20px;
    padding: 20px;
    max-width: 100vw;
    margin: 0 auto;
    box-sizing: border-box;
    background: #000; /* Matches your image background for testing */
    height: 30vh;
}
/*.logo-svg {
    height: 36px;
    width: auto;
    filter: brightness(0) invert(1); 
    display: flex;
    align-items: center; 
    margin-right: 75px;
    padding: 0;
}*/
.logo-svg img, .logo-svg svg {
    all: unset;
    height: 100%; /* Ensures the image fills the 36px height */
    width: auto;
    padding: 0 !important;
    margin: 0 !important;
    object-fit: contain;
}
/* Fine-tune vertical alignment for specific logos */
.logo-svg:nth-child(3) img { /* Amazon */
    transform: translateY(-2px); /* Adjust upward to match other logos' text baseline */
}
.logo-svg:nth-child(5) img { /* ServiceNow */
    transform: translateY(1px); /* Adjust downward if needed to align with others */
}
/* Responsive adjustments */
@media (max-width: 768px) {
    .logo-container {
        gap: 15px;
    }
    .logo-svg {
        height: 30px;
    }
    .logo-svg:nth-child(3) img {
        transform: translateY(-1px);
    } /* Adjust Amazon on mobile */
    .logo-svg:nth-child(5) img {
        transform: translateY(0.5px);
    } /* Adjust ServiceNow on mobile */
}
@media (max-width: 480px) {
    .logo-container {
        gap: 10px;
    }
    .logo-svg {
        height: 24px;
    }
    .logo-svg:nth-child(3) img {
        transform: translateY(-0.5px);
    } /* Adjust Amazon on small screens */
    .logo-svg:nth-child(5) img {
        transform: translateY(0px);
    } /* Adjust ServiceNow on small screens */
}
/*
.logo-microsoft {}
.logo-google {
   transform: translateY(3px);
}
.logo-amazon {
   transform: translateY(9px) !important;
}
.logo-blueprism {}
.logo-servicenow {
   transform: translateY(-7px) !important;
}
.logo-abbyy {
   transform: translateY(-4px) !important;
}
.logo-uipath {
    transform: translateY(-8px) !important;
}
.logo-gdx {
   transform: translateY(-8px) !important;
}*/
/* end of logo setup */
.an {
    box-sizing: border-box;
    display: block;
    width: 100%;
    text-align: left;
}
p:last-child {
    margin-bottom: inherit !important;
}
/* footer menu */
.footer-menu {
    padding: 2rem 0;
    background-color: #000;
    color: #eee;
}
.fixed-footer {
    background: #262e37;
}
.fixed-footer h2{font-family: overused grotesk; font-weight: 400; letter-spacing: -1.5px; line-height: .9; font-size: 48px;}
.footer-menu-heading {
    font-weight: normal;
    margin-bottom: 0.8rem !important;
    line-height: 1.25;
    color: #fff;
    font-size: 22px; /* match with <a> inside */
    all: initial;
    all: unset; /* reset outside interference */
    font-family: bes;
    margin-bottom: 0.8rem;
    line-height: 1.25;
    color: #fff;
    font-size: 1.4em;
    display: block;
}
.footer-menu-heading a {
    all: unset; /* prevent GSAP or global CSS from interfering */
    font-weight: normal;
    line-height: 1.25;
    color: #fff;
    font-size: 22px;
    text-decoration: none;
    display: inline-block;
    font-family: bes;
}
.footer-submenu {
    padding-left: 0;
}
.footer-submenu-item {
    margin-bottom: 0;
}
.footer-submenu-item a {
    color: #ccc;
    text-decoration: none;
    transition: color 0.3s;
}
.footer-submenu-item a:hover, .footer-submenu-item.active > a {
    color: #fff;
    text-decoration: underline;
}
/* end of footer menu**/
blockquote {
    font-family: Overused Grotesk;
    font-weight: 200;
    font-style: normal;
}
.bg--dark hr {
    border-color: #fff;
}
/* canvas #canvas3d{
      display: block;
      width: 100%;
      height: 100%;
    }
*/
/*canvas#canvas3d{
      width: 100%;
      height: 100%;
      display: block;
	 max-height: 100vh;
	 position: absolute;
  z-index: 0;
    }*/



.industriesm .custom-card1 {
	margin-top:40px;
	
	
	
}
.industriesm .custom-card1 .card-icon{height:5cqw; width:auto;}
.industriesm .glow-text{font-size:8vw;}

.industriesm   .inline-tags {
    justify-content: left;
  }

.testimonial * {color:#fff; }


section#effect4 {padding: 0 !important;}




        /* ===== SECTION ELEMENTS CSS ===== */
        
        /* Common Image Container */
        .image-effect-container {
            height: 100vh;
            width: 100%;
            position: relative;
            overflow: hidden;
            margin: 0 0;
        }
        
        .image-base {
            width: 100%;
            height: 100%;
            background-size: cover;
            background-position: center;
            background-repeat: no-repeat;
        }

        /* Effect 1: Shutter Effect */
        .shutter-container {
            background: #000;
        }
        
        .shutter-image {
            clip-path: inset(0 100% 0 0);
            transform: scale(1.2);
        }

        /* Effect 2: Parallax Zoom */
        .parallax-container {
            perspective: 1000px;
        }
        
        .parallax-image {
            transform: scale(1.3) translateZ(0);
            filter: brightness(0.8);
        }

        /* Effect 3: Reveal from Center */
        .reveal-container {
            background: black;
        }
        
        .reveal-image {
            clip-path: circle(0% at center);
            transform: scale(1.1);
        }

        /* Effect 4: Slide and Scale */
        .slide-container {
            background: black;
        }
        
        .slide-image {
            transform: translateX(-100%) scale(0.8);
            border-radius: 20px;
        }

        /* Effect 5: Rotation with Mask */
        .rotation-container {
            background: black;
        }
        
        .rotation-image {
            transform: rotate(45deg) scale(0.5);
            clip-path: polygon(20% 0%, 80% 0%, 100% 20%, 100% 80%, 80% 100%, 20% 100%, 0% 80%, 0% 20%);
            filter: grayscale(100%);
        }





/* end of effects*/

.round-bg{border: 1px solid #80808047;
    box-shadow: 0 0 30px black;}

 table.generic th {
background: #3f3f3f;
  color: #fff;
  border-radius: 4px;
  background: blue;
  font-size: 22px;
  font-weight: 500;
	 padding-left: 15px; border:none;
}

table.generic tr{font-size: 14px; font-weight: 500; color: #fff; }
table.generic tr td{
 font-size: 1.2em; border:none;

}

/*ul.list li{margin-bottom: 15px;}*/
 ul.list.large > li  { margin-bottom:35px;
}

ul.list.large strong {
  font-weight: 700;
  padding: 4px 16px;
  background: #0072ff;
  border-radius: 100px; 
}

.ida-list ul.list.large > li {min-height: 300px;}
ul.list.large li br {margin-bottom: 15px;}

sup{ font-size: 40%;
  top: -1.2em;}


.flickity-page-dots .dot{background:#e7e7e7;}
.bg--primary{background-color:blue !important;}
/*.subpage .bg--primary h3 {border-top:0px !important;}*/







/* Custom Card with Rotating Border Animation */
.custom-card {
    position: relative;
    border-radius: 20px;
    overflow: hidden;
    background: #1a1a1a;
    padding: 24px;
    height: 100%;
    display: flex;
    flex-direction: column;
}

/* Rotating gradient background 
.custom-card::before {
  content: '';
  position: absolute;
  top: -50%;
  left: -50%;
  width: 200%;
  height: 200%;
  background: conic-gradient(
    from 0deg,
    transparent 0deg,
    transparent 90deg,
    rgba(255, 255, 255, 0.8) 180deg,
    rgba(255, 255, 255, 0.4) 270deg,
    transparent 360deg
  );
  z-index: 0;
 
}*/

/* Only animate on hover 
.custom-card:hover::before {
  animation: rotate 4s linear infinite;
}*/

/* Content mask that creates the border effect 
.custom-card::after {
    content: '';
    position: absolute;
    top: 1px;
    left: 1px;
    right: 1px;
    bottom: 1px;
    background: #1a1a1a;
    border-radius: 19px;
    z-index: 1;
}*/

/* Ensure all content appears above the mask */
.custom-card .card-top,
.custom-card .card-center,
.custom-card .card-bottom {
    position: relative;
    z-index: 2;
}

/* Optional: Add subtle glow effect */
.custom-card {
    box-shadow: 
        0 0 20px rgba(255, 255, 255, 0.05),
        inset 0 0 1px rgba(255, 255, 255, 0.1);
	/*border: 1px solid #464646;*/
}

/* Animation keyframes */
@keyframes rotate {
    0% {
        transform: rotate(0deg);
    }
    100% {
        transform: rotate(360deg);
    }
}

/* Your existing card styles can remain the same */
.card-icon {
    /* Your existing icon styles */
}

.custom-card h3 {
line-height: 1 !important;
  font-size: 1.8cqw;
  font-weight: 500;
  padding: 25px;
  margin: -25px;
}

.custom-card p {
    /* Your existing paragraph styles */
}

.inline-tags {
    /* Your existing tags styles */
}



.i-image .col-md-8 {padding: 50px;
 /* background: #000000b5;*/
  /*border-radius: 3em;*/ padding-bottom:7em;}
.i-image .col-md-8 h3{margin-bottom:1em; border-top:0px !important;}
.figures-card {
  padding: 40px;
  border: 1px solid #dadada38; /* Light gray border with transparency */
  border-radius: 1rem;
  margin-bottom: 20px;
  background-color: rgba(0, 0, 0, 0.2); /* Semi-transparent black to enhance blur effect */
  backdrop-filter: blur(10px); /* Blur effect, adjustable */
  -webkit-backdrop-filter: blur(10px); /* Safari support */
}

.subpage .figures-card h3{border-top:0px !important;}


#display {
  position: absolute;
  inset: 0; height:100vh; height: 100svh;
}

#container{ position: relative;
  width: 100vmax;
  height: 100vmax;
  left: 50%;
  top: 50%;
  background: linear-gradient(to bottom, #000, #111);
  transform: translate3d(-50%, -40%, 0);}


#container canvas {
  display: block;
}
ul.stairs {
  display: flex;
  flex-direction: column;
  align-items: center;
	
}
ul.stairs li {background: linear-gradient(160deg, #4169e1 0%, #1e40af 20%, #1d4ed8 40%, #1e3a8a 60%, #0f172a 80%, #000000 100%);
  padding: 6px 20px;
  list-style: none;
  border-radius: 500px;
  display: inline;
  margin-bottom: 10px;
  position: relative; width: fit-content;}

/* box backgrounds */

.gradient-green{background: radial-gradient(circle at top right, #00dded38 30%, black 100%);}

.gradient-purple-large {background: 
  radial-gradient(ellipse 120vw 60vw at 0% 0%, #7c3aed 0%, transparent 50%), 
  radial-gradient(ellipse 120vw 60vw at 100% 0%, #ec4899 0%, transparent 50%), 
  radial-gradient(ellipse 100vw 50vw at 50% 100%, #1e40af 0%, transparent 50%), 
  #000000;}
 .gradient-agentic-ai {
            background: linear-gradient(180deg, #4a7c59 0%, #2d5a27 25%, #1a3d1a 50%, #0f2a0f 75%, #000000 100%);
           
        }

        /* Gradient 2: Ocean Blue diagonal fade from top-left to bottom-right */
        .gradient-idp {
            background: linear-gradient(160deg, #4169e1 0%, #1e40af 20%, #1d4ed8 40%, #1e3a8a 60%, #0f172a 80%, #000000 100%);
           
        }

        /* Gradient 3: Complex radial blend - purple top-left, pink top-right, blue bottom */
        .gradient-rpa {
            background: 
                radial-gradient(ellipse 800px 400px at 0% 0%, #7c3aed 0%, transparent 50%),
                radial-gradient(ellipse 800px 400px at 100% 0%, #ec4899 0%, transparent 50%),
                radial-gradient(ellipse 600px 300px at 50% 100%, #1e40af 0%, transparent 50%),
                #000000;
           
        }

        /* Gradient 4: Diagonal from top-left lime to bottom-right purple */
        .gradient-nlp {
            background: linear-gradient(135deg, #84cc16 0%, #65a30d 25%, #8b5cf6 50%, #7c3aed 75%, #6b21a8 100%);
           
        }

        /* Gradient 5: Radial from top-left purple blending to bottom-right orange */
        .gradient-conversational-ai {
            background: 
                radial-gradient(ellipse 800px 600px at 20% 30%, #a855f7 0%, rgba(168, 85, 247, 0.6) 40%, transparent 80%),
                radial-gradient(ellipse 600px 400px at 80% 70%, #ea580c 0%, #92400e 30%, rgba(146, 64, 14, 0.4) 60%, transparent 100%),
                #000000;
           
        }

        /* Gradient 6: Diagonal from top-left pink to bottom-right orange */
        .gradient-test-automation {
            background: linear-gradient(135deg, #ec4899 0%, #f472b6 25%, #f97316 50%, #ea580c 75%, #dc2626 100%);
           
        }

        /* Gradient 7: Cyberpunk Techno - Electric cyan to neon purple with dark matrix */
        .gradient-intelligent-workflow {
            background: 
                radial-gradient(ellipse 700px 500px at 25% 20%, rgba(0, 255, 255, 0.4) 0%, rgba(0, 128, 255, 0.6) 30%, rgba(0, 80, 200, 0.4) 60%, transparent 90%),
                radial-gradient(ellipse 600px 400px at 75% 80%, rgba(255, 0, 255, 0.4) 0%, rgba(128, 0, 255, 0.5) 35%, rgba(100, 0, 200, 0.3) 70%, transparent 95%),
                linear-gradient(45deg, #001122 0%, #000a1a 25%, #0a0a2e 50%, #1a0a2e 75%, #000000 100%);
           
        }



/* end of box backgrounds */

/*
.subpage h2.use-case{font-size: 24px; text-align: center; vertical-align: middle;}

.case-section h3{ border: 0px !important;}
.case-slider {border-radius: 1.5em;
  background: black; min-height: 500px; position: relative;}
.case-container {
  border-radius: 1.5em;
  background: #2f373a;
  padding: 0.13em;
}
.case-box{width:40%; border:1px; padding:24px; border-radius:1.5em; height: 100%;}


.process-details p {

  color: white;

  font-size: 0.875rem;
  line-height: 1.2;
  font-family: bes;
}*/


/* case studies */



/* Existing Case Studies CSS */
        .subpage h2.use-case {
            font-size: 24px; 
            text-align: center; 
            vertical-align: middle;
        }
        .case-section h3 { 
            border: 0px !important;
			
        }
.clear-both{clear:both !important; float: right;}
.case-section{border-radius:3em;  padding-bottom: 0px !important;}
        .case-slider {
            border-radius: 1.5em;
            background: black; 
            height: 500px; 
            position: relative;
            overflow: hidden;
            padding: 0;
            background-color: black;
            background-image: radial-gradient(#1a1a1a 1px, transparent 1px);
            background-size: 15px 15px; 
        }
        .case-slider.remove-gradient::after {
            display: none;
        }
        .case-slider::after {
            content: '';
            position: absolute;
            top: 0;
            right: 0;
            width: 40%;
            height: 100%;
            background: linear-gradient(to left, black 0%, transparent 100%);
            pointer-events: none;
            z-index: 10;
            transition: opacity 0.3s ease;
        }
        .case-boxes-container {
            position: relative;
            width: 60%;
            height: 100%;
            overflow: hidden;
        }
        .case-container {
            border-radius: 1.5em;
            background: #2f373a;
            padding: 0.13em;
        }
        .case-box {
            width: 100%; 
            border: 0px solid #444; 
            padding: 24px; 
            border-radius: 1.5em; 
            height: 500px;
            display: flex;
            flex-direction: column;
            justify-content: space-between;
            background: #3B3B3B;
            position: absolute;
            top: 0;
            left: 0;
            transition: background 0.3s ease;
            padding-top: 0px;
			 background: 
                radial-gradient(ellipse 800px 400px at 0% 0%, #7c3aed 0%, transparent 50%),
                radial-gradient(ellipse 800px 400px at 100% 0%, #ec4899 0%, transparent 50%),
                radial-gradient(ellipse 600px 300px at 50% 100%, #1e40af 0%, transparent 50%),
                #000000;
        }
        .case-box.human-interaction {
          /*  background: #0000ff !important;*/
			background: linear-gradient(160deg, #4169e1 0%, #1e40af 20%, #1d4ed8 40%, #1e3a8a 60%, #0f172a 80%, #000000 100%);
        }
        .case-box:nth-child(1) { 
            z-index: 1; 
            height: 400px;
        }
        .case-box:nth-child(2),
        .case-box:nth-child(3),
        .case-box:nth-child(4),
        .case-box:nth-child(5),
        .case-box:nth-child(6),
        .case-box:nth-child(7),
        .case-box:nth-child(8),
        .case-box:nth-child(9),
        .case-box:nth-child(10) { 
            height: 100px;
            top: 400px;
            left: 100%;
            z-index: 2;
        }
        .case-box:nth-child(2) { z-index: 2; }
        .case-box:nth-child(3) { z-index: 3; }
        .case-box:nth-child(4) { z-index: 4; }
        .case-box:nth-child(5) { z-index: 5; }
        .case-box:nth-child(6) { z-index: 6; }
        .case-box:nth-child(7) { z-index: 7; }
        .case-box:nth-child(8) { z-index: 8; }
        .case-box:nth-child(9) { z-index: 9; }
        .case-box:nth-child(10) { z-index: 10; }
        .case-box h4 {
            font-weight: 400;
            font-size: 28px;
            text-align: left;
            height: 80px;
        }
        .case-box .process {
            display: none;
        }
        .case-box .process-details {
            display: none;
        }
        .case-box.expanded .process {
            display: flex;
            flex-direction: column;
            justify-content: center;
            align-items: flex-start;
            text-align: left;
            height: 100%;
        }
        .case-box.expanded {
            background-color: #1a1a1a;
        }
        .case-box.expanded .process-details {
            display: flex;
            flex: 1;
            align-items: flex-end;
            padding-top: 10px;
        }
        .case-box1 {
            background-color: #1a1a1a !important;
        }
        .process {
            flex: 1;
            display: flex;
            align-items: center;
            text-align: center;
        }
        .process p {
            color: #ccc;
            font-size: 0.9rem;
            line-height: 1.3;
            margin: 0;
        }
        .process-details {
            flex: 1;
            display: flex;
            align-items: flex-start;
            padding-top: 10px;
        }
        .process-details p {
            color: white;
            font-size: 0.875rem;
            line-height: 1.2;
            font-family: bes;
            margin: 0;
        }
      
        .space--lg {
            padding: 60px 0;
        }
        .start-button {
          /*  background: linear-gradient(45deg, #007bff, #0056b3);*/
            color: white;
            border: none;
            padding: 0px 30px;
            border-radius: 25px;
            font-size: 1rem;
            font-weight: 400;
            cursor: pointer;
            transition: all 0.3s ease;
            margin: 20px auto;
            display: block;
            position: relative;
            z-index: 10;
            line-height: 1;
            font-family: bes;
			background: linear-gradient(45deg, #c8ff04, #ffa700);
  color: black; transform: all 0.5s
        }
        .start-button:hover {
            background: linear-gradient(45deg, #ffa700, #c8ff04);
            transform: translateY(0px);
            /*box-shadow: 0 5px 15px rgba(0, 123, 255, 0.4);*/
        }
        .start-button:active {
            transform: translateY(0);
        }
        .start-button:disabled {
            opacity: 0.6;
            cursor: not-allowed;
        }

.start-button::before {
  content: "▶";  /* Simple play icon using Unicode triangle */
  margin-right: 8px;  /* Space between icon and text */
  font-size: 1.1em;  /* Slightly larger for visibility */
  color: inherit;  /* Match button text color */
  display: inline-block;  /* Ensures proper spacing */
  transform: rotate(0deg);  /* Optional: can animate rotation if needed */
  transition: transform 0.2s ease;  /* Smooth transition for potential hover effects */
}
        .process p {
            font-size: 18px;
            font-weight: 500;
            text-align: left !important;
        }
        .progress-indicator {
            position: absolute;
            bottom: 10px;
            left: 50%;
            transform: translateX(-50%);
            display: flex;
            gap: 10px;
            z-index: 15; visibility: hidden;
        }
        .progress-dot {
            width: 4px;
            height: 4px;
            border-radius: 50%;
            background: rgba(255, 255, 255, 0.3);
            transition: all 0.3s ease;
        }
        .progress-dot.active {
            background: #007bff;
            transform: scale(1.2);
        }
        .step-icon img {
            animation: glowFlicker 2.5s infinite ease-in-out;
        }
        @keyframes glowFlicker {
            0%   { filter: drop-shadow(0 0 5px rgba(255, 255, 255, 0.3)); }
            18%  { filter: drop-shadow(0 0 8px rgba(255, 255, 255, 0.7)); }
            29%  { filter: drop-shadow(0 0 12px rgba(255, 255, 255, 1)); }
            45%  { filter: drop-shadow(0 0 4px rgba(255, 255, 255, 0.2)); }
            60%  { filter: drop-shadow(0 0 10px rgba(255, 255, 255, 0.9)); }
            76%  { filter: drop-shadow(0 0 6px rgba(255, 255, 255, 0.5)); }
            100% { filter: drop-shadow(0 0 5px rgba(255, 255, 255, 0.3)); }
        }
        .interaction-area {
            position: absolute;
            top: 0;
            right: 0;
            width: 40%;
            height: 500px;
            background-color: rgb(47, 55, 58);
            background-image: url("../images/dots.png");
            border-radius: 1.5em;
            display: flex;
            flex-direction: column;
            align-items: center;
            justify-content: center;
            z-index: 20;
            padding: 20px;
            backdrop-filter: blur(10px);
            border: 0px solid rgba(255, 255, 255, 0.1);
            opacity: 0;
            transform: translateY(-20px);
            transition: all 0.3s ease;
        }
        .interaction-area.active {
            opacity: 1;
            transform: translateY(0);
        }
        .step-icon {
            font-size: 3rem;
            margin-bottom: 15px;
            color: #007bff;
        }
        .interaction-buttons {
            display: flex;
            gap: 10px;
            margin-top: 15px;
        }
        .interaction-btn {
            padding: 8px 16px;
            border: none;
            border-radius: 20px;
            font-size: 0.9rem;
            font-weight: bold;
            cursor: pointer;
            transition: all 0.3s ease;
        }
        .approve-btn {
            background: linear-gradient(45deg, #28a745, #20c997);
            color: white;
        }
        .approve-btn:hover {
            background: linear-gradient(45deg, #20c997, #17a2b8);
            transform: translateY(-2px);
        }
        .restart-btn {
            background: linear-gradient(45deg, #dc3545, #c82333);
            color: white;
        }
        .restart-btn:hover {
            background: linear-gradient(45deg, #c82333, #bd2130);
            transform: translateY(-2px);
        }
        .step-title {
            color: white;
            font-size: 1.2rem;
            text-align: center;
            margin-bottom: 10px;
            font-weight: normal;
            font-family: bes;
        }
        .process img.process-icon {
            height: 36px;
            display: inline;
            text-align: left !important;
            margin-right: 12px; 
        }

.escalate-btn {padding: 8px 16px;
  border: none;
  border-radius: 20px;
  font-size: 0.9rem;
  font-weight: bold;
  cursor: pointer;
  transition: all 0.3s ease; background:blue;color:white;}

img.process-icon[src^="images/logo-"] {
  height: 24px !important;
}
        .process p strong {
            color: white;
            line-height: 36px;
            vertical-align: middle;
            font-weight: 600;
        }
        .step-title::after {
            content: '...';
            display: inline-block;
            margin-left: 6px;
            letter-spacing: 2px;
            color: #aaa;
            animation: typingDots 1.2s steps(4, end) infinite;
            font-weight: bold;
        }
        @keyframes typingDots {
            0%   { content: ''; }
            25%  { content: '.'; }
            50%  { content: '..'; }
            75%  { content: '...'; }
            100% { content: ''; }
        }
        @media (max-width: 1200px) {
            .case-box {
                width: 100%; height: 100%
            }
			
			h2.use-case{text-align: center;}
        }
        @media (max-width: 768px) {
            .case-box {
                width: 80%;
            }
            .case-boxes-container {
                width: 500%;
            }
            .interaction-area {
                width: 50%;
                height: 100%;
            }
        }
        @media (max-width: 576px) {
            .case-box {
                width: 90%;
            }
            .interaction-area {
                width: 60%;
                height: 100%;
            }
        }

        /* Modified Function Boxes Section CSS */
        .function-boxes-section {
            margin-top: 20px;
            padding: 20px 0;
        }
        .function-boxes-container {
            display: flex;
            justify-content: space-between;
            align-items: center;
            position: relative;
            background: #2f373a;
            border-radius: 1em;
            padding: 15px;
            height: 120px;
        }
        .function-box {
            display: flex;
            flex-direction: column;
            align-items: center;
            justify-content: center;
            width: 80px;
            height: 80px;
            background: #3B3B3B;
            border-radius: 0.5em;
            transition: all 0.3s ease;
            z-index: 2; padding:4px;
        }
        .function-box.active {
            background-color: #000;
            transform: scale(1.1);
        }
        .function-box img {
       width: 24px;
  height: 24px;
  object-fit: contain; margin-bottom: 0px;  easing:all 0.2s;
        }



.function-box span {}

.function-box.active img, .function-box.active span {filter: blur(0px)}
        .function-box span {
            font-size: 0.75rem;
            color: #ccc;
            text-align: center;
            margin-top: 8px;
            line-height: 1;
        }
        .connection-line {
            position: absolute;
            top: 50%;
            left: 20px;
			right:20px;
            width: calc(100% - 40px);
            height: 2px;
            background: #444;
            z-index: 1;
        }
        /* NEW: Progress Line */
        .progress-line {
            position: absolute;
            top: 50%;
            left: 20px;
            height: 2px;
            background: #007bff;
            width: 0;
			max-width:  calc(100% - 40px);
            z-index: 1;
            transition: width 0.3s ease;
        }
        @media (max-width: 768px) {
            .function-boxes-container {
                flex-wrap: wrap;
                height: auto;
                gap: 10px;
                justify-content: center;
            }
            .function-box {
                width: 60px;
                height: 60px;
            }
            .function-box img {
                width: 24px;
                height: 24px;
            }
            .function-box span {
                font-size: 0.65rem;
            }
            .connection-line {
                display: none;
            }
            .progress-line {
                display: none;
            }
        }
/* end of case studies*/


/*body::before {
  content: "";
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;
  background-image: 
    linear-gradient(hsla(0, 0%, 100%, 0.2), hsla(0, 0%, 100%, 0.2)), 
    linear-gradient(hsla(0, 0%, 100%, 0.2), hsla(0, 0%, 100%, 0.2));
  background-size: 1px 100%, 1px 100%;
  background-position: 33.33% 0, 66.66% 0;
  background-repeat: no-repeat;
   z-index: 1;
  pointer-events: none;
}*/



/* animated dots */

.circle-container {
  position: relative;
  width: 180px;
  height: 180px;
  display: flex;
  justify-content: center;
  align-items: center;

}

.dot {
  position: absolute;
  border-radius: 50%;
  background: #fff;
}

/* Corner decorations for all animation containers */
.corner {
  position: absolute;
  width: 16px;
  height: 16px;
  color: white;
  opacity: 0;
  z-index: 10;
  pointer-events: none;
  transition: opacity 0.3s ease;
}

.animation-container:hover .corner {
  opacity: 1;
}

.top-left {
  top: -8px;
  left: -8px;
  transition-delay: 0s;
}

.top-right {
  top: -8px;
  right: -8px;
  transform: rotate(90deg);
  transition-delay: 0.1s;
}

.bottom-left {
  bottom: -8px;
  left: -8px;
  transform: rotate(-90deg);
  transition-delay: 0.2s;
}

.bottom-right {
  bottom: -8px;
  right: -8px;
  transform: rotate(180deg);
  transition-delay: 0.3s;
}

/* 1. Pulsating Circles */
.pulse-dot {
  opacity: 0;
  transform-origin: center;
  animation: pulseFadeIn 3s infinite ease-in-out;
}
@keyframes pulseFadeIn {
  0% {
    opacity: 0;
    transform: scale(0.2);
  }
  40%,
  60% {
    opacity: 1;
    transform: scale(1);
  }
  100% {
    opacity: 0;
    transform: scale(0.2);
  }
}

/* 2. Rotating Orbits */
.orbit-container {
  position: absolute;
  width: 100%;
  height: 100%;
  border-radius: 50%;
  transform-style: preserve-3d;
  animation: rotate 8s infinite linear;
}
@keyframes rotate {
  to {
    transform: rotateZ(360deg);
  }
}

/* 3. Sequential Rings */
@keyframes expandRing {
  0% {
    transform: scale(0);
    opacity: 0;
  }
  20% {
    transform: scale(1);
    opacity: 1;
  }
  40%,
  100% {
    transform: scale(1.1);
    opacity: 0;
  }
}

/* 4. Concentric Rotations */
.concentric-container {
  position: absolute;
  width: 100%;
  height: 100%;
  transform-style: preserve-3d;
}
.concentric-ring {
  position: absolute;
  width: 100%;
  height: 100%;
  border-radius: 50%;
  transform-style: preserve-3d;
  animation: rotateRing linear infinite;
}
@keyframes rotateRing {
  to {
    transform: rotate(360deg);
  }
}

/* 5. Circular Waves */
.circular-wave-dot {
  animation: circularWave 3s infinite ease-in-out;
  transform-origin: center;
}
@keyframes circularWave {
  0% {
    transform: scale(0.7);
    opacity: 0.3;
  }
  50% {
    transform: scale(1.2);
    opacity: 1;
  }
  100% {
    transform: scale(0.7);
    opacity: 0.3;
  }
}

/* 6. Expanding Lines */
.line-container {
  position: absolute;
  width: 100%;
  height: 100%;
  animation: rotateLines 8s infinite linear;
  transform-origin: center;
}
@keyframes rotateLines {
  to {
    transform: rotate(360deg);
  }
}
.expanding-line {
  position: absolute;
  height: 1px;
  left: 50%;
  top: 50%;
  transform-origin: left center;
  background: rgba(255, 255, 255, 0.3);
  animation: expandLine 4s infinite ease-in-out;
}
@keyframes expandLine {
  0% {
    width: 0;
    opacity: 0;
  }
  20%,
  80% {
    width: 70px;
    opacity: 1;
  }
  100% {
    width: 0;
    opacity: 0;
  }
}

/* 7. Breathing Grid */
.breathing-dot {
  animation: breathe 4s infinite cubic-bezier(0.4, 0, 0.2, 1);
  transform-origin: center;
}
@keyframes breathe {
  0% {
    transform: scale(0.8);
    opacity: 0.3;
  }
  50% {
    transform: scale(1.3);
    opacity: 1;
  }
  100% {
    transform: scale(0.8);
    opacity: 0.3;
  }
}

/* 8. Ripple Effect */
.ripple-container {
  position: absolute;
  width: 100%;
  height: 100%;
}
.ripple-ring {
  position: absolute;
  border: 1px solid rgba(255, 255, 255, 0.3);
  border-radius: 50%;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  animation: ripple 4s infinite cubic-bezier(0, 0.5, 0.5, 1);
}
@keyframes ripple {
  0% {
    width: 0;
    height: 0;
    opacity: 1;
  }
  100% {
    width: 180px;
    height: 180px;
    opacity: 0;
  }
}

/* New ripple wave dot animation */
.ripple-wave-dot {
  position: absolute;
  border-radius: 50%;
  background: #fff;
  transform-origin: center;
}

@keyframes rippleWave {
  0%,
  100% {
    transform: scale(0.8);
    opacity: 0.3;
  }
  50% {
    transform: scale(1.8);
    opacity: 1;
  }
}



/* 8.5  ripple on black */


/* 8. Ripple Effect */
.bg--secondary .ripple-container {
  position: absolute;
  width: 100%;
  height: 100%;
}
.bg--secondary .ripple-ring {
  position: absolute;
  border: 1px solid rgba(0, 0, 0, 0.3);
  border-radius: 50%;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  animation: ripple 4s infinite cubic-bezier(0, 0.5, 0.5, 1);
}
@keyframes ripple {
  0% {
    width: 0;
    height: 0;
    opacity: 1;
  }
  100% {
    width: 180px;
    height: 180px;
    opacity: 0;
  }
}

/* New ripple wave dot animation */
.bg--secondary .ripple-wave-dot {
  position: absolute;
  border-radius: 50%;
  background: #000;
  transform-origin: center;
}

@keyframes rippleWave {
  0%,
  100% {
    transform: scale(0.8);
    opacity: 0.3;
  }
  50% {
    transform: scale(1.8);
    opacity: 1;
  }
}

/* 9. Fibonacci Spiral (div version) */
.fibonacci-container {
  position: absolute;
  width: 100%;
  height: 100%;
  animation: rotateSlow 30s infinite linear;
  transform-origin: center;
}
@keyframes rotateSlow {
  to {
    transform: rotate(360deg);
  }
}
.fibonacci-dot {
  position: absolute;
  border-radius: 50%;
  background: #fff;
  animation: fibPulse 3s infinite ease-in-out;
}
@keyframes fibPulse {
  0%,
  100% {
    opacity: 0.2;
    transform: scale(0.8);
  }
  50% {
    opacity: 1;
    transform: scale(1.2);
  }
}

/* 10. Halftone Gradient */
.halftone-container {
  position: absolute;
  width: 100%;
  height: 100%;
  animation: rotateSlow 20s infinite linear;
  transform-origin: center;
}
.halftone-dot {
  position: absolute;
  border-radius: 50%;
  background: #fff;
  animation: halftoneFade 4s infinite ease-in-out;
}
@keyframes halftoneFade {
  0%,
  100% {
    opacity: 0.3;
    transform: scale(0.5);
  }
  50% {
    opacity: 1;
    transform: scale(1);
  }
}

/* 11. Silver Spiral */
.silver-container {
  position: absolute;
  width: 100%;
  height: 100%;
  animation: rotateSlow 25s infinite reverse linear;
  transform-origin: center;
}
.silver-dot {
  position: absolute;
  border-radius: 50%;
  background: #fff;
  animation: silverPulse 3s infinite ease-in-out;
}
@keyframes silverPulse {
  0%,
  100% {
    opacity: 0.2;
    transform: scale(0.7);
  }
  50% {
    opacity: 1;
    transform: scale(1.3);
  }
}



/* end of animated dots */

/* pillboxes*/



.pillbox {
      display: inline-flex;
      align-items: center;
      padding: 2px 12px;
      border-radius: 999px;
      background: rgba(255, 255, 255, 0.1);
      backdrop-filter: blur(10px);
      box-shadow: inset 0 0 5px rgba(255,255,255,0.2);
      font-size: 0.85rem;
      color: #fff;
      margin: 4px;
      flex-wrap: nowrap;
    }

    .pill-label {
      margin-right: 8px;
      white-space: nowrap;
    }

    .pill-color {
      width: 12px;
      height: 12px;
      border-radius: 50%;
      margin-left: 4px;
      position: relative;
      cursor: pointer;
    }

.pill-color::after {
  content: attr(data-tooltip); font-family: BES;
  position: absolute;
  bottom: 125%;
  left: 50%;
  transform: translateX(-50%);
 /*  background: rgba(0, 0, 0, 0.75) !important; Override background */
  color: #fff !important;
  padding: 2px 12px !important;
  border-radius: 100px !important;
  font-size: 0.65rem !important;
  white-space: nowrap !important;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.2s ease !important; /* Override transition */
  z-index: 30 !important; /* Higher than [data-tooltip1]::after's z-index: 20 */ border:0px; background-color:blue;
}

    .pill-color:hover::after {
      opacity: 1;
    }

.pillboxes .ukiyo-wrapper {border-radius: 0px !important}
.pillboxes {border-top: 1px solid #161616;background: radial-gradient(ellipse 800px 400px at 0% 0%, #7c3aed 0%, transparent 50%), radial-gradient(ellipse 800px 400px at 100% 0%, #ec4899 0%, transparent 50%), radial-gradient(ellipse 600px 300px at 50% 100%, #1e40af 0%, transparent 50%), #000000;
    background-color: rgb(0, 0, 0);
}
.pillboxes h3 {border:0px !important;}

/* end of pillboxes*/

/*.has-gradient {
  background-image: linear-gradient(315deg, #00c6ff, #0072ff);
        -webkit-background-clip: text;
        background-clip: text;
        -webkit-text-fill-color: transparent;
        display: inline-block;
        position: relative;
        z-index: 1;
        margin-bottom: -25px;
        padding-bottom: 25px;
        padding-right: 25px;
        margin-right: -25px;
}*/

.has-gradient {
    background-image: linear-gradient(315deg, #00c6ff, #0072ff);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    display: inline-block;
    position: relative;
    z-index: 1;
	    margin-bottom: -25px;
        padding-bottom: 25px;
        padding-right: 25px;
        margin-right: -25px;
}



.bg--secondary .has-gradient{background-image: linear-gradient(315deg, #0f1223, #4a71ff);     -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    display: inline-block;
    position: relative;
    z-index: 1;
	    margin-bottom: -25px;
        padding-bottom: 25px;
        padding-right: 25px;
        margin-right: -25px;}

.panel{background: radial-gradient(ellipse 120vw 60vw at 0% 0%, #7c3aed 0%, transparent 50%), radial-gradient(ellipse 120vw 60vw at 100% 0%, #ec4899 0%, transparent 50%), radial-gradient(ellipse 100vw 50vw at 50% 100%, #1e40af 0%, transparent 50%), #000000; background-position:left center !important}


/* palette boxes */

.palette-box {
    position: relative;
  
    height: auto;
    border-radius: 20px;
  height: 100%;
    box-shadow: 0 10px 30px rgba(255, 255, 255, 0.1);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
    padding: 15px 25px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    backdrop-filter: blur(15px);
    border: 1px solid rgba(255, 255, 255, 0.12);
    overflow: hidden;
    /*min-width: 258px;*/
}

.palette-box h4{font-size: 1.2em; margin:0 !important}

  .card-wrapper {
            position: relative;
            width: 100%;
            height: 100%;
	
        }

.o-card-wrapper{margin-top:25% !important}
.card-wrapper .palette-box {
    position: absolute;
    cursor: pointer;
    user-select: none; background-color: black !important; min-height: 360px;
  max-width: 280px;
}

/*.card-wrapper .palette-box:not(.top-card) *  {opacity: .6 !important}*/

.card-wrapper .palette-box:not(.top-card) * {
  opacity: 0.6 !important;
  transition: opacity 0.3s ease-in-out; 
}

.palette-boxes .card-wrapper::before {
 content: "";
  position: absolute;
  top: -30px;
  right: -60px;
  width: 100px;
  height: 50px;
  background: url("../images/click.png") no-repeat center/contain;
  pointer-events: none;
}

.palette-box::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 25%;
    z-index: 0;
    border-top-left-radius: 20px;
    border-top-right-radius: 20px;
    mix-blend-mode: screen;
    pointer-events: none;
}
/*.box-1 { background-color: var(--color-aai); }
.box-2 { background-color: var(--color-idp); }
.box-3 { background-color: var(--color-rpa); }
.box-4 { background-color: var(--color-nlp); }
.box-5 { background-color: var(--color-cai); }
.box-6 { background-color: var(--color-tau); }
.box-7 { background-color: var(--color-iwf); }*/


/* Updated CSS to use background images instead of solid colors */
.box-1 { background: url('../images/bkg-aai.webp') no-repeat center/cover; }
.box-2 { background: url('../images/bkg-idp.webp') no-repeat center/cover; }
.box-3 { background: url('../images/bkg-rpa.webp') no-repeat center/cover; }
.box-4 { background: url('../images/bkg-nlp.webp') no-repeat center/cover; }
.box-5 { background: url('../images/bkg-cai.webp') no-repeat center/cover; }
.box-6 { background: url('../images/bkg-tau.webp') no-repeat center/cover; }
.box-7 { background: url('../images/bkg-iwf.webp') no-repeat center/cover; }
.box-8 { background: url('../images/bkg-sla.webp') no-repeat center/cover; }


[class^="box-"] {
    position: relative;
}
.palette-box > * {
    position: relative;
    z-index: 1;
}

.palette-box h3, .palette-box p, .palette-box .inline-tags {
    color: black;
    font-family: Overused Grotesk;
}
.palette-box .inline-tags {
    padding-left: 0px;
}
.palette-box .card-center h3 {
   line-height: .9;
  font-weight: 600;
  letter-spacing: -0.5px;
  font-size: 1.4em;
  color: white !important;
  border-bottom: 1px solid white !important;
  padding-bottom: 15px;
  border-top: 0px !important;
}
.palette-box .card-center {
    padding-bottom: 50px;
}
.palette-box p {
  padding-top: 20px;
  font-size: 1.1em;
  line-height: 1.1;
  color: white !important;
  font-weight: 500; opacity: .8;
}
.palette-box .card-bottom {
    padding: 0px;
}
.palette-box .inline-tags li {
    background: rgba(0, 0, 0, 0.2);
    color: #fff;
    border-radius: 15px;
    font-size: 0.8rem;
    border: 1px solid rgba(255, 255, 255, 0.3);
    letter-spacing: 0px;
    text-shadow: 0.5px 0.5px #acacac;
    padding: 0.3em 0.6em;
}
.palette-box .card-icon {
    width: 30px;
    height: 30px;
    object-fit: contain;
    /*filter: brightness(0) invert(0);*/
}

/* palette boxes ending*/


.dotted-bg {
   background-image: radial-gradient(rgba(255, 255, 255, 0.2) 0.5px, #fff0 -0.5px);
  background-size: 20px 20px;

}

.round-bg{ border-radius: 2em; background-color: #1a1a1a;  height: 100%}
.no-border{border:0 !important;}


/* seamless logo */

@keyframes slides {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(-100%);
  }
}

.logos {
  overflow: hidden;
  padding: 30px 0px;
  white-space: nowrap;
  position: relative;

}

.logos:before, .logos:after {
  position: absolute;
  top: 0;
  content: '';
  width: 250px;
  height: 100%;
  z-index: 2;
}

.logos::before {
  left: 0;
  background: linear-gradient(
    to left,
    rgba(0,0,0,0) 0%,       /* fully transparent */
    rgba(0,0,0,0.5) 50%,    /* semi-transparent */
    rgb(0,0,0) 100%         /* solid black */
  );
}

.logos::after {
  right: 0;
  background: linear-gradient(
    to right,
    rgba(0,0,0,0) 0%,       
    rgba(0,0,0,0.5) 50%,    
    rgb(0,0,0) 100%
  );
}


.logo_items {
  display: inline-block;
  animation: 35s slides infinite linear;
}

.logos:hover .logo_items {
  animation-play-state: paused;
}

.logo_items img{
  height: 30px;
  display: inline;
	 filter: brightness(0) invert(1); margin-left: 75px; margin-bottom: 0px
}
.logo_items img:last-child{margin-bottom: 0px;

}

/* end of seamless logo*/



.border {
  border: 1px solid #dee2e64d !important
}

.overlapping{padding-top:250px; background:red; position: relative;}
.panel1 .col-md-6 {padding: 50px;}
.panel1{background:black; border-radius: 2em; border:1px solid white;}
.spacer,
.wrapper {
  width: 100%;
  min-height: 100vh;
}


.o-wrapper {
  width: 100%;
  min-height: 100vh;
}

.panel1 {
  width: 100%;
 
  display: flex;
  justify-content: center;
  align-items: center;

  border-radius: 10px;
  background-size: cover;
  background-repeat: no-repeat;
  background-position: top center;
}

.cards {
  width: 100%;
  /*max-width: 750px;*/
  margin: 0 auto;
  padding: 0 20px;
}

.o-cards {
  width: 100%;
  /*max-width: 750px;*/
  margin: 0 auto;
  padding: 0 20px;
}


/*.o-card {
  width: 100%;
  height: auto;
  display: flex;
  justify-content: center;
  align-items: center;


}*/


.tag-container {
  position: relative;
 left:8px;
  padding: 50px;
  border-radius: 1em;

  z-index: 0;
  overflow: hidden;
	/*box-shadow: 0px 0px 20px #ffffff4d inset;*/
	 -webkit-backdrop-filter:blur(30px);
  backdrop-filter:blur(30px);
  background-color:#e6e6ff1f; bottom: 5vh;
}

.tag-container::before{content: '';
    position: absolute;
    inset: 0;
    border-radius: 1em;
    padding: 1px;
    pointer-events: none;
    z-index: -1;
    -webkit-mask:
      linear-gradient(#E6E6FF 0 0) content-box, 
      linear-gradient(#E6E6FF 0 0);
    mask:
      linear-gradient(#E6E6FF 0 0) content-box, 
      linear-gradient(#E6E6FF 0 0);
    -webkit-mask-composite: xor;
    mask-composite: exclude;
    background: conic-gradient(
      from var(--angle, 135deg),
      transparent,
      #E6E6FF99 25%,
      transparent 70%,
      transparent 100%
    );}

.panel-headline {
  position: relative;

  padding: 25px;
  border-radius: 1em;
  -webkit-backdrop-filter:blur(30px);
  backdrop-filter:blur(30px);
  background-color:#e6e6ff1f;
  z-index: 0;
  overflow: hidden;
	/*box-shadow: 0px 0px 20px #ffffff4d inset;*/
	bottom: 5vh;
}

.panel-headline::before{ content: '';
    position: absolute;
    inset: 0;
    border-radius: 1em;
    padding: 1px;
    pointer-events: none;
    z-index: -1;
    -webkit-mask:
      linear-gradient(#E6E6FF 0 0) content-box, 
      linear-gradient(#E6E6FF 0 0);
    mask:
      linear-gradient(#E6E6FF 0 0) content-box, 
      linear-gradient(#E6E6FF 0 0);
    -webkit-mask-composite: xor;
    mask-composite: exclude;
    background: conic-gradient(
      from var(--angle, 0deg),
      transparent,
      #E6E6FF99 25%,
      transparent 70%,
      transparent 100%
    );}

.panel-item, .panel-item .background-image-holder, .panel-item::before {/*border-top-left-radius: 3em; border-top-right-radius: 3em; */}

.outcome-driven-automation{background: url(../images/bg-outcome-driven-automation.webp); background-size:contain}
.agentic-ai{background: url(../images/bg-agentic-ai.webp); background-size:contain}
.consumption-based-automation{background: url(../images/bg-consumption-based-automation.webp); background-size:contain}
.next-generation-servicedesk{background: url(../images/bg-next-generation-servicedesk.webp); background-size:contain}
.professional-services{background: url(../images/bg-professional-services.webp); background-size:contain}
.feature-large .ukiyo-wrapper{border-radius:2em;}
.ukiyo-wrapper{border-radius:2em;}
.panel-wrapper {
  border-top-left-radius: 3em;
	border-top-right-radius: 3em; }
.panel-item {  
  position: relative;
  z-index: 1;  } 

.cover .ukiyo-wrapper{border-radius: 0px !important}

/*.tag-container::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  padding: 1px; /* border thickness 
  background: linear-gradient(270deg, rgba(255,255,255,0.6), rgba(255,255,255,0.1));
  -webkit-mask: 
    linear-gradient(#fff 0 0) content-box, 
    linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
          mask-composite: exclude;
  z-index: -1;
}*/

.panel-wrapper h3{margin-bottom: 25px}
	.panel-wrapper p{max-width: 380px; line-height: 1}


.custom-card a.btn {align-self: flex-start;}


/** list.box*/
.list.box {
            display: flex;
            flex-wrap: wrap;
            padding: 0;
            margin: -0.5rem;
            list-style: none;
	margin-left:-15px
        }
        
        .list.box > li {
           position: relative;
  flex: 1 1 350px;
  margin: 0.5rem;
  padding: 2.5rem 1rem 1rem 3rem;
  background-color: transparent;
  border: 1px solid rgba(255, 255, 255, 0.05);
  border-radius: 0.75rem;
  color: #e0e0e0;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  min-height: 180px;
  overflow: hidden;
  font-size: 1.2rem;
  line-height: 1.1;
  font-weight: 500;
  background: #131313; padding-bottom: 35px;
			
        }
        
        .list.box > li::before {
content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-image: radial-gradient(circle at 1px 1px, rgba(255, 255, 255, 0.25) .5px, transparent 0);
  background-size: 10px 10px;
  -webkit-mask: linear-gradient(135deg, rgba(255,255,255,1) 0%, transparent 100%);
  mask: linear-gradient(15deg, rgb(255, 255, 255) 0%, transparent 100%);
  z-index: 1;
  border-radius: inherit;
  overflow: hidden;
  left: -2px;
  top: -1px;
        }
        
        .list.box > li::after {
content: '✓';
  position: absolute;
  top: 2rem;
  left: 2.5rem;
  width: 20px;
  height: 20px;
  background: rgba(0,190,0,1.00);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
  font-weight: bold;
  color: white; margin-left: 5px;
        }
        
        .list.box h4 {
       margin: 0 0 0.75rem 0;
    margin-top: 0px;
  font-size: 1.6rem;
  font-weight: 500;
  line-height: 1.3;
  order: -1;
        }
        
        ul.list.box:last-child {
            margin-left: -15px !important;
        }
        
     
        
        .list.box h4 {
            margin: 0 0 0.75rem 0;
            font-size: 1.75rem;
            font-weight: 500;
            line-height: 1.3;
            order: -1; /* This ensures h4 appears first */
        }
        
    
        
        @media (max-width: 576px) {
            .list.box li {
                flex: 1 1 100%;
            }
        }

span.min-title::before {
content: '';
  display: inline-block;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background-color: #4f0;
  margin-right: 0.5em;
  vertical-align: middle;
  line-height: 1.2em;

  bottom: 1.5px;
  position: relative;
}
span.min-title{ line-height: 1.2em;margin-bottom: 30px;}





.bg--secondary .list.box {
  display: flex;
  flex-wrap: wrap;
  padding: 0;
  margin: -0.5rem;
  list-style: none;
  margin-left: -15px;
}

.bg--secondary .list.box > li {
  position: relative;
  flex: 1 1 350px;
  margin: 0.5rem;
  padding: 2.5rem 1rem 1rem 3rem;
  background-color: #fff;
  border: 1px solid rgba(0, 0, 0, 0.1);
  border-radius: 0.75rem;
  color: #333;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  min-height: 180px;
  overflow: hidden;
  font-size: 1.2rem;
  line-height: 1.4;
  font-weight: 500;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.04);
}

.bg--secondary .list.box > li::before {
  content: '';
  position: absolute;
  top: -1px;
  left: -2px;
  right: 0;
  bottom: 0;
  background-image: radial-gradient(circle at 1px 1px, rgba(0, 0, 0, 0.35) 0.5px, transparent 0);
  background-size: 10px 10px;
-webkit-mask: linear-gradient(15deg, rgba(255, 255, 255, 0.6) 0%, transparent 100%);
  mask: linear-gradient(15deg, rgba(255, 255, 255, 0.6) 0%, transparent 100%);
  z-index: 1;
  border-radius: inherit;
  overflow: hidden;
}

.bg--secondary .list.box > li::after {
  content: '✓';
  position: absolute;
  top: 2rem;
  left: 2.5rem;
  width: 20px;
  height: 20px;
  background: #00aa00;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
  font-weight: bold;
  color: #fff;
  box-shadow: 0 0 4px rgba(0, 170, 0, 0.3);
}

.bg--secondary .list.box h4 {
  margin: 0 0 0.75rem 0;
  font-size: 1.75rem;
  font-weight: 500;
  line-height: 1.3;
  order: -1;
  color: #111;
}

.bg--secondary ul.list.box:last-child {
  margin-left: -15px !important;
}

@media (max-width: 576px) {
  .bg--secondary .list.box li {
    flex: 1 1 100%;
  }
}

.bg--secondary span.min-title::before {
  content: '';
  display: inline-block;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background-color: #4f0;
  margin-right: 0.5em;
  vertical-align: middle;
  line-height: 1.2em;
  bottom: 1.5px;
  position: relative;
}

.bg--secondary span.min-title {
  line-height: 1.2em;
  margin-bottom: 30px;
  color: #222 !important;
}

.bg--secondary .gray-box {
  background: #f0f0f0;
}


/* end of list.box*/



/**** orbital ****/
#orbital .spacer {
	height: 100vh;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 2rem;
	opacity: .7;
}
#orbital {
	height: 150vh;
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	font-family: overused grotesk;
	font-weight: 500
}
#orbital .solar-system {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	width: 70vmin;
	height: 70vmin;
}
#orbital .orbit-outer, #orbital .orbit-inner {
	position: absolute;
	top: 50%;
	left: 50%;
	border-radius: 50%;
	transform: translate(-50%, -50%);
}
#orbital .orbit-outer {
	width: 100%;
	height: 100%;
	border: 2px solid rgba(78,205,196,.3);
}
#orbital .orbit-inner {
	width: 50%;
	height: 50%;
	border: 2px solid rgba(255,107,107,.3);
}
#orbital .sun {
	position: absolute;
	top: 50%;
	left: 50%;
	width: 10vmin;
	height: 10vmin;
	max-width: 120px;
	max-height: 120px;
	border-radius: 500px;
	transform: translate(-50%, -50%);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 1.5rem;
	font-weight: 500;
	color: #fff;
	box-shadow: 0 0 50px rgba(255,215,0,.8);
	z-index: 10;
	border: 1px solid rgba(255,255,255,.2);
	text-align: center;
}
#orbital .planet {
	position: absolute;
	width: 12vmin;
	height: 12vmin;
	border-radius: 15px;
	display: flex;
	align-items: center;
	justify-content: center;
	font-weight: 500;
	font-size: .9rem;
	color: white;
	box-shadow: 0 8px 25px rgba(0,0,0,.4);
	backdrop-filter: blur(10px);
	border: 1px solid rgba(255,255,255,.2);
	transform-origin: center center;
	top: 50%;
	left: 50%;
	flex-direction: column;
	cursor: pointer;
}
#orbital .planet-sign {
	margin-bottom: 20px;
}
#orbital .planet-sign img {
	width: 24px;
}
/* tooltip1 inside planets (right side now) */
#orbital .planet .tooltip1 {
	position: absolute;
	top: 50%;
	left: 100%;
	transform: translateY(-50%);
	width: 300px;
	padding: 15px;
	border-radius: 12px;
	box-shadow: 0 20px 40px rgba(0,0,0,.3);
	opacity: 0;
	pointer-events: none;
	transition: opacity .25s ease, transform .25s ease;
	z-index: 20000;
	margin-left: 12px; /* spacing between planet and tooltip */
	
	/* Blur fix */
	background-color: rgba(0, 0, 0, 1); /* must be transparent */
	backdrop-filter: blur(30px);
	-webkit-backdrop-filter: blur(30px); /* safari fix */
}


	#orbital .planet:hover{z-index: 2000}	
#orbital .planet .tooltip1::after {
content: "";
  position: absolute;
  top: 50%;
  left: -16px;
  transform: translateY(-50%);
  border-width: 8px;
  border-style: solid;
  border-color: transparent rgba(255, 255, 255, 0.16) transparent transparent;

}
#orbital .planet:hover .tooltip1 {
	opacity: 1;
	transform: translateY(-50%) translateX(5px);
	pointer-events: auto;
}
#orbital .tooltip1 h3 {
	color: #fff;
  font-size: 1.5rem;
  margin-bottom: 6px;
  font-weight: 500;
  font-family: overused grotesk;
  letter-spacing: -1px;
}
#orbital .tooltip1 .description {
	font-size: 1rem;
	line-height: 1.3;
	margin-bottom: 8px;
	opacity: .9;
}
#orbital .tooltip1 .features strong {
	color: #45b7d1;
	display: block;
	margin-bottom: 5px;
	font-size: .85rem;
}
#orbital .tooltip1 .features ul {
	list-style: none;
	padding: 0;
	margin: 0;
}
#orbital .tooltip1 .features li {
	padding: 2px 5px;
	line-height: 1;
	opacity: .8;
	display: inline-block;
	border-radius: 50px;
	border: 1px solid gray;
	margin: 2px;
	font-size: .75rem;
}
#orbital .progress-indicator {
	position: absolute;
	top: 50%;
	right: 30px;
	width: 4px;
	height: 200px;
	background: rgba(255,255,255,.2);
	border-radius: 2px;
	transform: translateY(-50%);
	z-index: 1000;
}
#orbital .progress-fill {
	width: 100%;
	background: linear-gradient(to top, #4ecdc4, #45b7d1);
	border-radius: 2px;
	height: 0%;
}

.scene-title h2{padding:35px; margin:-25px;}
#orbital .scene-title {
  position: absolute;
  top: 5%;
  left: 50%;
  transform: translateX(-50%);
  font-size: 3rem;
  font-weight: bold;
  text-align: center;
  background: linear-gradient(45deg, #4ecdc4, #45b7d1, #f9ca24);
    background-size: auto;
    background-clip: border-box;
  background-size: 200% 200%;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  animation: gradientShift 3s ease infinite;
  z-index: 1000;
}
@keyframes gradientShift {
0%, 100% {
background-position:0% 50%
}
50% {
background-position:100% 50%
}
}
#orbital .planet-label {
	font-size: .8rem;
	text-align: center;
	line-height: 1.1;
}
#orbital .planet-name {
	display: block;
	font-weight: bold;
}
#orbital .planet-type {
	display: block;
	opacity: .8;
	font-size: .7rem;
}
#orbital .orbit-outer::after, #orbital .orbit-inner::after {
	content: '';
	position: absolute;
	top: -1px;
	left: -1px;
	right: -1px;
	bottom: -1px;
	border-radius: 50%;
	background: conic-gradient(transparent 270deg, rgba(75,255,60,.75) 360deg);
	mask: radial-gradient(circle, transparent 70%, black 30%);
	animation: spin 20s linear infinite;
	pointer-events: none;
}
#orbital .orbit-inner::after {
	background: conic-gradient(transparent 270deg, rgba(255,215,0,.75) 360deg);
	animation: spin 15s linear infinite reverse;
}
@keyframes spin {
to {
transform:rotate(360deg)
}
}

@media(max-width:768px) {
#orbital .planet {
	width: 50px;
	height: 50px;
	font-size: .7rem;
}
#orbital .sun {
	width: 80px;
	height: 80px;
	font-size: 1.2rem;
}
#orbital .scene-title {
	font-size: 2rem;
}
#orbital .solar-system {
	width: 95vmin;
	height: 95vmin;
}
#orbital .planet .tooltip1 {
	width: 200px;
	padding: 12px;
}
}




/**** end of orbital */


/***** ida heading animation ********/
.presents{opacity: 0; font-size: 7rem; letter-spacing: -1px}
  /* ===== Scoped container ===== */
  #video-animation {
    --videoOpacity: .8;
    margin: 0;
    padding: 0;
    background: #000;
    overflow: hidden;
    height: 100vh;
    width: 100vw;
    position: relative;
  }
	
  /* Fix for video not covering viewport */
  #video-animation .bg-video {
    position: absolute;
    top: 50%;
    left: 50%;
    min-width: 100%;
    min-height: 100%;
    width: auto;
    height: auto;
    transform: translateX(-50%) translateY(-50%);
    object-fit: cover;
    opacity: var(--videoOpacity);
    z-index: 0;
    pointer-events: none;
  }

  /* Ensure container is properly sized */
  #video-animation {
    position: relative;
    width: 100vw;
    height: 100vh;
    overflow: hidden;
  }

  /* ===== Loader ===== */
  #video-animation .loader {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    background: #000;
    z-index: 10;
  }
  #video-animation .spinner {
    width: 44px;
    height: 44px;
    border-radius: 50%;
    border: 4px solid rgba(255, 255, 255, .2);
    border-top-color: #fff;
    animation: spin 1s linear infinite;
  }
  @keyframes spin {
    to { transform: rotate(360deg); }
  }

  /* ===== SVG camera animation ===== */
  #video-animation .camera-container {
    position: absolute;
    inset: 0;
    width: 100vw;
    height: 100vh;
    transform-origin: center center;
    opacity: 0;
    z-index: 2;
  }
  #video-animation .section {
    height: 100vh;
    width: 100vw;
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
  }
  #video-animation .svg-container {
    width: 80%;
    max-width: 1215.24px;
    height: auto;
  }
  #video-animation .cls-1 {
    fill: none;
    stroke: #fff;
    stroke-miterlimit: 10;
    stroke-width: 4px;
  }

  /* ===== Text animation ===== */
  #video-animation .text-wrapper {
    position: absolute;
    inset: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    transform-origin: center center;
    z-index: 3;
    text-align: center;
    pointer-events: none;
  }
  #video-animation .text-container {
    font-size: 3rem;
    color: #fff;
  }
  #video-animation .ida-text {
    font-size: 10vw;
    font-weight: 700;
    text-rendering: optimizeSpeed;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    letter-spacing: -5px;
    line-height: .85;
    opacity: 0;
    visibility: hidden;
  }
  #video-animation .subtext {
    font-size: 2.5rem;
    margin-top: 20px;
    opacity: 0;
    visibility: hidden;
  }

  /* Cinematic sections */
  #video-animation .cinematic-section {
    opacity: 0;
    visibility: hidden;
    position: absolute;
    inset: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    z-index: 4;
    transform: scale(0.9);
    filter: blur(10px);
  }
  
  #video-animation .big-title {
    font-size: 3vw !important;
    font-weight: 800;
    color: white;
    margin-bottom: 1rem;
    text-align: center; letter-spacing: -0.01vw
  }
  
  #video-animation .cinematic-section p {
    font-size: 2.5rem;
    color: rgba(255, 255, 255, 0.9);
    margin: 0;
    opacity: 0;
    transform: translateY(20px);
  }

  /* Prevent FOUC */
  #video-animation .presents {
    opacity: 0;
    visibility: hidden;
  }

  /* SplitText pieces default (avoid FOUC) */
  #video-animation .char, #video-animation .word {
    display: inline-block;
    opacity: 0;
    filter: blur(12px);
    transform: translateY(20px);
    will-change: transform, opacity, filter;
  }
.status{display: none;}
  /* Controls */
  .controls {
    position: fixed;
    bottom: 20px;
    right: 20px;
    z-index: 100;
    display: flex;
    gap: 10px;
	  display: none;
  }
  
  .controls button {
    background: rgba(0, 0, 0, 0.7);
    color: white;
    border: 1px solid rgba(255, 255, 255, 0.3);
    padding: 8px 15px;
    border-radius: 4px;
    cursor: pointer;
    font-size: 14px;
    transition: all 0.3s ease;
  }
  
  .controls button:hover {
    background: rgba(0, 0, 0, 0.9);
    border-color: rgba(255, 255, 255, 0.7);
  }

  /* Status indicator */
  .status {
    position: fixed;
    top: 20px;
    left: 20px;
    color: white;
    background: rgba(0, 0, 0, 0.7);
    padding: 10px 15px;
    border-radius: 4px;
    z-index: 100;
    font-size: 14px;
  }


/***** end of ida heading animation ********/

/*****  observer slider ****/
#observer-slides * {
  box-sizing: border-box;
  user-select: none;
}
#observer section{margin:0; padding:0 !important}

#observer-slides a {
  color: white;
  text-decoration: none;
}

#observer-slides .spacer {
  height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  color: white;
  font-size: 2rem;
  text-align: center;
}

#observer-slides .spacer.top {
  background: linear-gradient(45deg, #667eea, #764ba2);
}

#observer-slides .spacer.bottom {
  background: linear-gradient(45deg, #ff6b6b, #4ecdc4);
}

#observer-slides {
  margin: 0;
  padding: 0;
  background: black;
  text-align: center; font-weight: 600;
}
#observer-slides p{ font-size: 32px;
  font-weight: 400;
  
  line-height: 1;
}
#observer-slides h2 {
  font-size: clamp(1.8rem, 4vw, 10rem);
font-weight: 600;
  text-align: center;
  margin-right: -0.5em;
  width: 90vw;
  max-width: 1200px;
  text-transform: none; margin-bottom: 0px;
}

#observer-slides .header {
  position: absolute;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 5%;
  width: 100%;
  z-index: 3;
  height: 7em;
  font-size: clamp(0.66rem, 2vw, 1rem);
  letter-spacing: 0.5em;
}

#observer-slides .sections-container {
  position: relative;
  height: 500vh; /* Make it tall enough for all sections */
  width: 100%;
}

#observer-slides .sections-wrapper {
  position: sticky;
  top: 0;
  height: 100vh;
  width: 100%;
}

#observer-slides section {
  height: 100%;
  width: 100%;
  position: absolute;
  top: 0;
  visibility: hidden; padding: 0px !important; padding:0px !important
}

#observer-slides section .outer,
#observer-slides section .inner {
  width: 100%;
  height: 100%;
  overflow-y: hidden; margin-top:0px!important
}
#observer .inner{margin-top:0px !important}
#observer-slides section .bg {
  display: flex;
  align-items: center;
  justify-content: center;
  position: absolute;
  height: 100%;
  width: 100%;
  top: 0;
  background-size: cover;
  background-position: center;
	flex-direction: column;
}

#observer-slides section .bg h2 {
  z-index: 999;
}

#observer-slides section .bg .clip-text {
  overflow: hidden;
}
#observer-slides .o-content {max-width: 60vw}
#observer-slides .o-content .inline-tags{justify-content: center;}
#observer-slides .first .bg {
  background-image: linear-gradient(180deg, rgba(0, 0, 0, 0.6) 0%, rgba(0, 0, 0, 0.1) 100%), url("../images/slide-orchestra.webp");
}

#observer-slides .second .bg {
  background-image: linear-gradient(180deg, rgba(0, 0, 0, 0.6) 0%, rgba(0, 0, 0, 0.1) 100%), url("../images/slide-desert.webp");
}

#observer-slides .third .bg {
  background-image: linear-gradient(180deg, rgba(0, 0, 0, 0.6) 0%, rgba(0, 0, 0, 0.1) 100%), url("../images/slide-outcome.webp");
}

#observer-slides .fourth .bg {
  background-image: linear-gradient(180deg, rgba(0, 0, 0, 0.6) 0%, rgba(0, 0, 0, 0.1) 100%), url("../images/slide-enterprise-it.webp");
}

#observer-slides .fifth .bg {
  background-image: linear-gradient(180deg, rgba(0, 0, 0, 0.6) 0%, rgba(0, 0, 0, 0.1) 100%), url("../images/mid-agentic-ai3.webp");
  background-position: 50% 45%;
}

#observer-slides h2 * {
  will-change: transform;
}



/*** end of observer slider ******/


.blue-globe{background: url("../images/blue-globe.webp"); background-size: contain; background-repeat:no-repeat; background-position: -15vw center;}

/*ul.list.large > li{border: 1px solid #ffffff30;
  padding: 40px; list-style: none; min-height: 420px;
  border-radius: 1em;
}*/


.bg--secondary p{color:black;}
.bg--secondary h2, .bg--secondary h3{color:black;}
.bg--secondary .dot {background:black !important}

.bg--secondary .expanding-line {


  background: rgba(0, 0, 0, 0.3);

}
.bg--secondary ul {color:black !important;}
.cta-container  {
  margin-left:2em; margin-right: 2em;
}




/* ida presentation animation */
.ida-uk {
	background: linear-gradient( 135deg, #000000 0%, #1a0033 25%, #2d1b69 50%, #4a0e4e 75%, #000000 100% );
	width: 100vw;
	height: 100vh;
	position: relative; overflow: hidden;
}

.ida-uk h3{border:0px !important}
.ida-uk .orbital-lines {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	pointer-events: none;
}
.ida-uk .orbital-line {
	position: absolute;
	border: 2px solid #00d4ff;
	border-radius: 50%;
	left: 0;
	top: 50%;
	transform: translateY(-50%);
	opacity: 0.3;
}
.ida-uk .orbital-line-1 {
	width: 60vw;
	height: 60vw;
	left: -30vw;
}
.ida-uk .orbital-line-2 {
	width: 100vw;
	height: 100vw;
	left: -50vw;
}
.ida-uk .orbital-line-3 {
	width: 140vw;
	height: 140vw;
	left: -70vw;
}
.ida-uk .slide-box {
	position: absolute;
	z-index: 10;
	transform: translate(-50%, -50%);
	width: 300px;
	height: 100px;
}
.ida-uk .box-wrapper {
	position: relative;
	width: 100%;
	height: 100%;
	box-sizing: content-box !important;
}
.ida-uk .box-frame {
	position: absolute;
	right: 0;
	top: 0;
	width: 300px;
	height: 100px;
	border-radius: 100vh;
	border: 2px solid #000000;
	background-color: rgba(0,0,0,0.05);
	overflow: hidden;
	box-sizing: content-box;
}
.ida-uk .pillbox1 {
	position: absolute;
	right: 2px;
	top: 2px;
	bottom: 2px;
	width: 150px;
	border-radius: 100vh;
	background-color: #000;
	color: white;
	display: flex;
	align-items: center;
	justify-content: center;
	font-weight: bold;
	font-size: 14px;
	padding: 15px;
	text-align: center;
	line-height: 1;
	font-weight: 500;
	font-size: 1.3rem;
	letter-spacing: -0.5px;
}
.ida-uk .box-content {
	margin-left: 154px;
	font-size: 11px;
	text-align: center;
	padding: 0 8px;
	color: #fff;
	height: 100%;
	display: flex;
	align-items: center;
	z-index: -1;
	position: relative;
}
.ida-uk .box-content span {
	line-height: 1.1;
}
.ida-uk .orbit-horizontal {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	display: flex;
	align-items: flex-start;
	z-index: 5;
}
.ida-uk .orbit-title-tagline {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	width: 25vw;
	margin-left: 2vw;
	opacity: 0;
	align-self: center;
}
.ida-uk #section-business, .ida-uk #section-service {
	position: relative;
	width: 20vw;
	padding: 10px;
	font-size: 1rem;
	opacity: 0;
}
	
	.ida-uk #section-business h4, .ida-uk #section-service h4 {font-size: 1.8vw; margin-bottom: 10px;}
	.ida-uk #section-business ul, .ida-uk #section-service ul {font-size: 1.3vw; line-height: 1.2;}
	
.ida-uk #section-business {
	left: 1vw;
	right: 2vw;
}
.ida-uk #section-service {
	right: 0vw;
	left: 5vw;
}
.ida-uk .orbit-title {
	font-size: 1.5rem;
	font-weight: bold;
	margin-bottom: 5px;
	text-align: left;
}
.ida-uk .orbit-tagline {
	font-size: 1rem;
	text-align: left;
}
.ida-uk .orbit-section {
	width: 250px;
	font-size: 11px;
	line-height: 1.4;
}
.ida-uk .orbit-section ul {
	margin-top: 5px;
	padding-left: 20px;
}
.ida-uk .guides::before, .ida-uk .guides::after, .ida-uk .guides span {
	content: "";
	position: absolute;
	top: 0;
	bottom: 0;
	width: 1px;
	background: #4a90e2;
	z-index: 9999;
}
.ida-uk .stacked-logos {
	display: flex;
	flex-direction: column;
	justify-content: space-around;
	width: 15vw;
	position: absolute;
	right: 50px;
	align-items: flex-end;
	height: 80vh;
    top: 10vh;
}
.ida-uk .stacked-logos img {
	opacity: 0;
	filter: brightness(0) invert(1);
	height: 32px;
	margin: 0;
}
.ida-uk .orbit-title h3 {
	font-weight: 400;
	line-height: 0.9;
}
	
	
	/* MEDIA QUERIES */
@media (max-width: 1200px) {
	.ida-uk #section-business, .ida-uk #section-service {padding: 0px;}
}

@media (max-width: 768px) {
}

@media (max-width: 600px) {
}

@media (max-width: 480px) {
}

@media (max-width: 360px) {
}
	

#outcome-grid .container-outcome {
	background: linear-gradient( 135deg, #000000 0%, #1a0033 25%, #2d1b69 50%, #4a0e4e 75%, #000000 100% );
	margin: 0 auto;
	position: relative;
}

#outcome-grid header {
	text-align: center;
	margin-bottom: 40px;
	padding: 20px;
	opacity: 0; /* Added for animation */
}

#outcome-grid h1 {
	font-size: 2.5rem;
	color: #2c3e50;
	margin-bottom: 10px;
}

#outcome-grid .subtitle {
	font-size: 1.2rem;
	color: #fff;
	
	margin: 0 auto;
}

#outcome-grid .grid {
	display: grid;
	grid-template-columns: repeat(5, 1fr);
	grid-template-rows: repeat(2, 1fr);
	grid-auto-rows: minmax(180px, auto);
	gap: 60px;
	margin-bottom: 40px;
	position: relative;
	z-index: 2;
	opacity: 0; /* Added for animation */
}

#outcome-grid .card {
	border-radius: 12px;
	padding: 25px;
	box-shadow: 0 10px 20px rgba(0, 0, 0, 0.1);
	display: flex;
	flex-direction: column;
	transition: transform 0.3s ease, box-shadow 0.3s ease;
	color: white;
	position: relative;
	overflow: hidden;
	aspect-ratio: 1 / 1;
	border-radius: 100vh;
	border: 3px solid cyan;
	background-color: black !important;
	opacity: 0; /* Added for animation */
}

#outcome-grid .card::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: linear-gradient(135deg, rgba(255,255,255,0.2) 0%, rgba(255,255,255,0) 100%);
	z-index: 1;
}

/* Added glow effects for animation */
#outcome-grid .card.glow {
	box-shadow: 0 0 20px 5px rgba(0, 255, 255, 0.6), 0 10px 20px rgba(0, 0, 0, 0.1);
	border-color: cyan;
}

#outcome-grid .card.alert-glow {
	box-shadow: 0 0 30px 8px rgba(255, 0, 0, 0.8), 0 10px 20px rgba(0, 0, 0, 0.1);
	border-color: red;
}

#outcome-grid .card-content {
	position: relative;
	z-index: 2;
	height: 100%;
	display: flex;
	flex-direction: column;
}

#outcome-grid .card-top {
	display: flex;
	align-items: center;
	margin-bottom: 15px;
	align-self: center !important;
	margin: 0;
}

#outcome-grid .card-top img {
	object-fit: fill;
	margin: 0;
}

#outcome-grid .card-icon {
	width: 2cqw;
	height: 2cqw;
	margin-right: 0px;
	max-width: 100%;
}

#outcome-grid .process {
	font-size: 0.8cqw;
	font-weight: 400;
	margin-bottom: 12px;
	line-height: 1.2;
	margin: 0;text-align: center;
  margin: auto;
}

#outcome-grid .service {
	font-size: 1.1cqmin;
	font-weight: 500;
	opacity: 0.9;
	margin-bottom: 0px;
	display: flex;
	align-items: self-end;
	flex-grow: 1;
	padding: 0;
	text-align: right;
	align-self: center; height: 0px;
}

#outcome-grid .box-label {
	display: inline-block;
	padding: 5px 12px;
	border-radius: 20px;
	font-size: 0.85rem;
	font-weight: 500;
	background: rgba(255, 255, 255, 0.3);
	margin-top: auto;
}

/* SVG Background - Responsive */
#outcome-grid .svg-background {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	width: 95%;
	height: auto;
	z-index: 0;
	opacity: 0.3;
}

/* Added for SVG path animation */
#outcome-grid .svg-background path {
	stroke-dasharray: 1000;
	stroke-dashoffset: 1000;
}

#outcome-grid h3 {
	font-size: 3.5cqw !important; font-weight: 200 !important; letter-spacing: -0.001vw !important; border: 0 !important;
}
		
		

.alert-check {
  height: 100vh;
  width: 100%;
  position: relative;
}

/* Modified for animation */
.alert-check .alert-icon,
.alert-check .check-icon {
  position: absolute;
  top: 35%;
  left: 50%;
  transform: translate(-50%, -50%);
  opacity: 0;
}

.alert-check .alert-icon img,
.alert-check .check-icon img {
  width: 180px;
  position: relative;
  mix-blend-mode: color-burn;
  display: block;
}
	
/* MEDIA QUERIES */
@media (max-width: 1200px) {
	#outcome-grid .grid {
		gap: 40px;
	}
	#outcome-grid .svg-background {
		width: 95;
	}
	
	
}

@media (max-width: 768px) {
	body {
		padding: 15px;
	}
	#outcome-grid .grid {
		gap: 30px;
	}
	#outcome-grid .svg-background {
		width: 80%;
	}
	#outcome-grid h3 {
		font-size: 2rem !important; font-weight: 200 !important; letter-spacing: 1.5px !important;
	}
	#outcome-grid .subtitle {
		font-size: 1rem;
	}
}

@media (max-width: 600px) {
	#outcome-grid .grid {
		gap: 20px;
	}
	#outcome-grid .card {
		padding: 15px;
	}
	#outcome-grid .card-icon {
		width: 32px;
		height: 32px;
	}
	#outcome-grid .process {
		font-size: 0.7em;
	}
	#outcome-grid .service {
		font-size: 0.65rem;
	}
	#outcome-grid .svg-background {
		width: 75%;
	}
}

@media (max-width: 480px) {
	body {
		padding: 10px;
	}
	#outcome-grid .grid {
		gap: 15px;
	}
	#outcome-grid .card {
		padding: 12px;
	}
	#outcome-grid .card-icon {
		width: 28px;
		height: 28px;
	}
	#outcome-grid .process {
		font-size: 0.65em;
	}
	#outcome-grid .service {
		font-size: 0.6rem;
	}
	#outcome-grid .svg-background {
		width: 70%;
	}
	#outcome-grid h1 {
		font-size: 1.5rem;
	}
	#outcome-grid .subtitle {
		font-size: 0.9rem;
	}
}

@media (max-width: 360px) {
	#outcome-grid .grid {
		gap: 10px;
	}
	#outcome-grid .card {
		padding: 10px;
	}
	#outcome-grid .card-icon {
		width: 24px;
		height: 24px;
	}
	#outcome-grid .process {
		font-size: 0.6em;
	}
	#outcome-grid .service {
		font-size: 0.55rem;
	}
	#outcome-grid .svg-background {
		width: 65%;
	}

}


/* end of ida presentation animation */
.category-name{font-weight: 400 !important;text-transform: capitalize; line-height: 0 !important;
  padding-bottom: 50px;}
.summary-title{margin-top:0px !important;}
.summary-image{border-radius:1em; border:0px; height:300px; overflow:hidden;box-shadow: 0px 0px 6px #00000091; }
#NewsPostDetailContent a.btn.more{ display:flex;}
.summary-image img{
  position: relative;}
.NewsDetailField img {width:100%; border-radius:1em;}
#NewsPostDetailCategory {text-transform: capitalize;}
#NewsPostDetailAuthor {display:none;}
img.img-fluid{width:100%}

.NewsDetailField img::before {content:"";mask-image: linear-gradient(135deg, black 0%, transparent 10%);
    mask-repeat: no-repeat;
    mask-position: top left;
    mask-size: 100% 100%;
    pointer-events: none;
    border: 1px solid #ffffff4a;}

h4.summary-category {
  margin: 0;
    margin-top: 0px;
    margin-bottom: 0px;
  margin-bottom: 15px;
  font-size: 16px;
  text-transform: capitalize;
  padding: 0;
}

.news-categories ul li  { border:1px solid gray; padding: 8px 24px; border-radius:100vh;margin-bottom:15px; }
.news-categories ul li a {color:white; font-size:18px; text-transform:capitalize; display:block;}








/* CSS-only smooth easing for panel animations */

/* Enable smooth scrolling globally */
html {
   /* scroll-behavior: smooth;*/
}

/* hero home */



#app1 {

  height: 100vh;
  height: 100svh; /* fix your syntax */
  position: relative;
 /* background: radial-gradient(circle at 1px 1px, rgba(255, 255, 255, 0.25) .5px, transparent 0);
  background-size: 25px 25px;*/
}

.hero1 {

}



#canvas1 {
  position:absolute; mix-blend-mode:overlay;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  overflow: hidden;
	

}


/* end of hero home*/




/* pulse agent */



    #pulse-agent {
      font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, Cantarell, sans-serif;
      background: #000000;
      
      color: #ffffff;
      display: flex;
      align-items: center;
      padding: 60px 0;
      position: relative;
    }

    #pulse-agent .chat-container {
      background: #1a1a1a;
      border-radius: 24px;
      box-shadow: 0 20px 60px rgba(0, 0, 0, 0.8);
      overflow: hidden;
      height: 700px;
      display: flex;
      flex-direction: column;
      width: 100%;
    }

    #pulse-agent .chat-header {
      background: linear-gradient(160deg, #4169e1 0%, #1e40af 20%, #1d4ed8 40%, #1e3a8a 60%, #0f172a 80%, #000000 100%);
      padding: 24px;
      color: white;
      flex-shrink: 0;
      position: relative;
    }

    #pulse-agent .header-content {
      display: flex;
      align-items: center;
      gap: 16px;
    }

    #pulse-agent .restart-btn {
      position: absolute;
      top: 50%;
      right: 24px;
      transform: translateY(-50%);
      width: 36px;
      height: 36px;
      background: rgba(255, 255, 255, 0.2);
      border: none;
      border-radius: 50%;
      display: flex;
      align-items: center;
      justify-content: center;
      cursor: pointer;
      transition: all 0.3s ease;
      backdrop-filter: blur(10px);
    }

    #pulse-agent .restart-btn:hover {
      background: rgba(255, 255, 255, 0.3);
      transform: translateY(-50%) rotate(180deg);
    }

    #pulse-agent .restart-btn svg {
      width: 18px;
      height: 18px;
      stroke: white;
      stroke-width: 2;
      fill: none;
    }

    #pulse-agent .avatar {
      width: 48px;
      height: 48px;
      border-radius: 50%;
      background: white;
      display: flex;
      align-items: center;
      justify-content: center;
      font-weight: bold;
      color: #667eea;
      font-size: 20px;
      box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);
      flex-shrink: 0;
    }

    #pulse-agent .header-info h2 {
      font-size: 20px;
      font-weight: 600;
      margin-bottom: 4px;
    }

    #pulse-agent .header-info p {
      font-size: 14px;
      opacity: 0.9;
      margin: 0;
    }

    #pulse-agent .status-indicator {
      width: 8px;
      height: 8px;
      background: #4ade80;
      border-radius: 50%;
      display: inline-block;
      margin-right: 6px;
      animation: pulse-status 2s infinite;
    }

    @keyframes pulse-status {
      0%, 100% { opacity: 1; }
      50% { opacity: 0.5; }
    }

    #pulse-agent .chat-messages {
      flex: 1;
      overflow-y: auto;
      padding: 24px;
      min-height: 0;
    }

    #pulse-agent .p-message-wrapper {
      margin-bottom: 20px;
      opacity: 0;
      transform: translateY(20px);
    }

    #pulse-agent .p-message-wrapper:nth-child(odd) {
      display: flex;
      justify-content: flex-start;
    }

    #pulse-agent .p-message-wrapper:nth-child(even) {
      display: flex;
      justify-content: flex-end;
    }

    #pulse-agent .p-message {
      display: flex;
      gap: 12px;
      max-width: 75%;
    }

    #pulse-agent .p-message-wrapper:nth-child(even) .p-message {
      flex-direction: row-reverse;
    }

    #pulse-agent .p-message-avatar {
      width: 40px;
      height: 40px;
      border-radius: 50%;
      display: flex;
      align-items: center;
      justify-content: center;
      font-weight: 600;
      font-size: 16px;
      flex-shrink: 0;
    }

    #pulse-agent .p-message-wrapper:nth-child(odd) .p-message-avatar {
      background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
      color: white;
    }

    #pulse-agent .p-message-wrapper:nth-child(even) .p-message-avatar {
      background: linear-gradient(135deg, #f093fb 0%, #f5576c 100%);
      color: white;
    }

    #pulse-agent .p-message-content {
      padding: 16px 20px;
      border-radius: 18px;
      line-height: 1.6;
      font-size: 15px;
      word-wrap: break-word;
    }

    #pulse-agent .p-message-wrapper:nth-child(odd) .p-message-content {
      background: #2a2a2a;
      color: #ffffff;
      border-bottom-left-radius: 4px;
    }

    #pulse-agent .p-message-wrapper:nth-child(even) .p-message-content {
      background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
      color: white;
      border-bottom-right-radius: 4px;
    }

    #pulse-agent .claim-number {
      display: inline-block;
      background: rgba(102, 126, 234, 0.3);
      color: #a5b4fc;
      padding: 4px 12px;
      border-radius: 8px;
      font-weight: 600;
      margin: 0 4px;
    }

    #pulse-agent .typing-indicator {
      display: flex;
      gap: 12px;
      align-items: center;
      opacity: 0;
      margin-bottom: 20px;
    }

    #pulse-agent .typing-avatar {
      width: 40px;
      height: 40px;
      border-radius: 50%;
      background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
      color: white;
      display: flex;
      align-items: center;
      justify-content: center;
      font-weight: 600;
      font-size: 16px;
      flex-shrink: 0;
    }

    #pulse-agent .typing-dots {
      display: flex;
      gap: 6px;
      padding: 16px 20px;
      background: #2a2a2a;
      border-radius: 18px;
      border-bottom-left-radius: 4px;
    }

    #pulse-agent .p-dot {
      width: 8px;
      height: 8px;
      background: #667eea;
      border-radius: 50%;
      animation: pulse-typing 1.4s infinite;
    }

    #pulse-agent .p-dot:nth-child(2) { animation-delay: 0.2s; }
    #pulse-agent .p-dot:nth-child(3) { animation-delay: 0.4s; }

    @keyframes pulse-typing {
      0%, 60%, 100% { transform: translateY(0); opacity: 0.5; }
      30% { transform: translateY(-10px); opacity: 1; }
    }

    #pulse-agent .chat-messages::-webkit-scrollbar { width: 8px; }
    #pulse-agent .chat-messages::-webkit-scrollbar-thumb {
      background: #667eea;
      border-radius: 4px;
    }
    

/** end of pulse agent */

.action-button-wrapper{display: block; margin-top:20px; clear: both;}

video::-webkit-media-controls {
  background-color: transparent !important;
}

.form-email input{color: white !important;}
