/* common to all */
*, *::before, *::after {
    box-sizing: border-box;
}
* {
    box-sizing: border-box; /* Prevents padding from adding to width */
    margin: 0;
    padding: 0;
}
html, body {
    width: 100%;

}

body {
    width: 100%;
    justify-content: center!important; /* Centers horizontally */
    align-items: center!important;     /* Centers vertically */
    font-family: 'Inter', sans-serif;
    /* font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;*/
    line-height: 1.6;
    color: #333;
    background-color: #fff;
    overflow-x: hidden;
}

.bannersection{
  background: linear-gradient(135deg, #9D00FF 0%, #1A0033 100%);
  text-align: center;
  color: #FFFFFF; 
width:100%;
margin:0 auto;
scroll-margin-top: 50px;
padding: 20px;
}

.contentsection {
    width: 90%;
    margin:0 auto;
    scroll-margin-top: 50px;
    padding: 20px;
}

.actionbuttondiv {
    text-align: center;
    padding: 20px;
}

.grid-item img {
    margin: 0 auto 8px auto;
}
.grid-item .logo-text {
    margin-bottom: 5px;
}
footer {
    margin-top: 50px;
}
footer p {
    margin: 0;
}

.left { text-align: left; }
.center { text-align: center; }
.right { text-align: right; }
.justify-center { justify-content: center !important; }
.mirror-horizontal { transform: scaleX(-1); }


 .title-top {
    width: 100%;
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    align-items: center;
    padding-top: 20px; padding-bottom: 20px;
     padding-left: 40px; padding-right: 40px;
}

.logo-title-group {
    display: flex !important;
    flex-direction: row;
    align-items: center;
    gap: 15px;
}

.title-name{
    font-size: 32px;
    font-weight: 500;  
}

.title-logo{
    height: 50px;
    width: auto;
}

.title-logo-rotate {
    transform: rotate(-35deg) scaleX(-1);
    height: 50px;
    width: auto;
}

.titlepara {
    line-height: 1.2;
}

/* Syntro - Kept at 600 weight, but moved to a deeper "Syntropic" Navy if you want more CFO trust */
.title-span1 {
    font-family: 'Montserrat', sans-serif;
    letter-spacing: 0.1em; 
    font-size: 32px; 
    font-weight: 500; 
    color: #9D00FF; /* Keep your purple, or try #1A365D for a Navy look */
}

/* Fin - BUMPED to 800 weight to compensate for the light Gold color */
.title-span2 {
    font-family: 'Montserrat', sans-serif;
    letter-spacing: 0.1em; 
    font-size: 32px; 
    font-weight: 600; /* Heavier weight makes the gold "pop" against the purple */
    color: #D4AA04;
}

/* Tagline - Increased letter-spacing for an "Orchestrated" look */
.tagline {
    width: 100%;
    text-align: center;
    font-size: 20px; /* Reduced slightly to create a better hierarchy with the 32px logo */
    color: white;
    letter-spacing: 2.5px; /* Spacing out the letters creates a "high-end" feel */
    text-transform: uppercase; /* Optional: All caps taglines often look cleaner in banners */
    opacity: 0.9; /* Slight softening helps the main logo stand out */
}

.bannerslogan { 
    width:100%;
    text-align:center;
    line-height: 1.1;
    color: white;
    font-size:50px;
}

.title-span3{
    font-size: 22px; 
    color:#2D2D2D;
    display:block; 
    margin-top:10px;
}



/* Menu (The fix for bullets and vertical layout) */
.menu{

}
.nav {
    display: flex !important;
    flex-direction: row;
    list-style: none !important;
    list-style-type: none !important;
    gap: 20px;
}

.nav-item {
    margin-left: 1.5rem;
    list-style: none;
}

.nav-link {
    text-decoration: none;
    color: #1A1A1A;
    font-weight: 500;
    padding: 5px 0;
    transition: color 0.3s ease;
}

.nav-link:hover, .nav-link:focus {
    color: #9D00FF;
    text-decoration: none;
}

/* 3. SECTION - Intro */
.banner_row {
    display: flex;
    align-items: center;
    padding: 0 20px;
    gap: 20px;
}
.banner-text{
        flex: 1;
}

.banner-image{
  flex: 1;          /* Tells the DIV to grow and fill available space */
  min-width: 0;     /* Prevents the container from pushing past its parent */
  overflow: hidden; /* Optional: clips any image overflow */
}
.banner-image img {
     /*
   width: 100%;     
  height: 100%;     
    object-fit: cover; 
    */
    max-width: 400px;
    height:auto;
  display: block;   
  
}
    
.align-row {
    display: flex;
    align-items: center;
    padding: 0 20px;
    gap: 20px;
}

.align-image, .align-text{
    flex: 1;
    text-align: left;
    
}

.align-image-display {
    max-width: 100%;
    height: auto;
    margin:0 auto;
    /*
    box-sizing: border-box;
    border-radius: 9px;
    box-shadow: 0 20px 25px -5px rgba(0,0,0,0.1);
    */
}
.accela-image-display {
    max-width: 50%;
    height: auto;
    margin:0 auto;
    /*
    box-sizing: border-box;
    border-radius: 9px;
    box-shadow: 0 20px 25px -5px rgba(0,0,0,0.1);
    */
}
.diagnosys-row {
    display: flex;
    flex-direction: row;
    /*  gap: 20px; align-items: flex-start;  Keeps columns pinned to the top */
    width: 100%;
    gap: 20px;
    align-items: center;
    justify-content: center;
    text-align: center;
    margin: 0 auto;
}

.diagnosys-column-left, .diagnosys-column-right, .diagnosys-column-center, {
    display: flex;
    flex-direction: column;
    box-sizing: border-box;
    row-gap: 20px; 
    flex: 1; 
    align-items: center;
    justify-content: center;
    text-align: center;
    margin: 0 auto;
}

/* Middle column is has thin image */
.diagnosys-column-center {
    flex: 0.3; 
}

/* Image Styling */
.diagnosys-image {
    width:82px; height:auto;
    display: block;
    flex-shrink: 0;
    border-radius: 3px;
    /*
    transition: transform 0.3s ease;
    transform: rotate(0deg); 
    */
    
}

/* Sticky Note Fragments */
.diagnosys-note {
    background-color: #fffeee;
    padding: 15px;
    border-radius: 4px;
    box-shadow: 2px 3px 5px rgba(0, 0, 0, 0.2);
    transform: rotate(1deg);
    transition: transform 0.2s ease-in-out, box-shadow 0.2s ease-in-out;
    align-self: flex-start; /* Ensures notes align left within column */
    position: relative;
    text-align: left;
    /*
    font-family: 'Patrick Hand SC', sans-serif; 
    font-size: 14px; 
    font-weight:normal;
    color: #333333;  
    */
}

.diagnosys-note:hover {
    transform: rotate(-1deg) scale(1.05);
    box-shadow: 4px 6px 12px rgba(0, 0, 0, 0.3);
    z-index: 10;
    cursor: pointer;
}
.whiteboard {
  min-width: 200px;
  min-height: 150px;
  background-color: #ffffff;
  border: 10px solid #cccccc; 
  border-radius: 8px;
    padding-left:40px;
    padding-right:40px;
    padding-top:30px;
    padding-bottom:15px;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1), 0 0 10px rgba(0, 0, 0, 0.05) inset;
}


/* 5. Solutions & Feature Lists (from PDF pages 5/6) #f3fafe; */
.solutiondiv {
    background-color: white;
    text-align: center;
}
.service-box {background-color: white;}
.service-box h3 { color: #0f172a; font-size: 1.8rem; }
.service-box p { color: #475569; line-height: 1.6; font-size: 1.1rem; }

.feature-list, .stream-list { list-style: none; padding: 0; }

.feature-list li, .stream-list li {
    padding-left: 30px;
    position: relative;
    color: #1e293b;
}

.stream-list li::before, .feature-list li::before {
  content: "\2022";  /* The Unicode character for a solid bullet */
  color: #9fc5e8;       /* Your desired blue color */
  font-weight: bold; /* Makes the dot appear more solid */
  display: inline-block; 
  width: 1em;        /* Creates space for the dot */
  margin-left: -1em; /* Positions it to the left of the text */
}

/* Following for putting blue circle anywhee in a div */
.decorative-circle {
  width: 26px;
  height: 26px;
  background-color: gray;
  border-radius: 50%; /* Makes the square a circle */
  margin: 0 auto;
  display: block;    /* Ensures margin: auto works */
}

.circle-blue1{
    margin-bottom:20px;
    background-color: #3498db;
}

.circle-blue2{
    margin: 20px auto; 
    background-color: #9FC5E8;
}
    

.tech-container {
    position: relative; /* CRITICAL: This is the reference point for the overlay */
    text-align: center; /* Centers the image if it's smaller than the container */
    color: white; /* Makes text visible on a dark background */
}

.tech-container img {
    /* Ensures the image fills the container width */
    width: 100%;
    height: auto;
    display: block;
}

.text-overlay {
    position: absolute; 
    top: 20%; /* Start placing from 50% down from the top */
    left: 20%; /* Start placing from 50% across from the left */
    transform: translate(-50%, -50%); /* CRITICAL: Centers the block perfectly */
    padding: 20px;
    background-color: rgba(0, 0, 0, 0.6); /* Semi-transparent background for readability */
    width: 80%; /* Ensure the text container doesn't get too wide */
    text-align: left; /* Keep the text readable inside the overlay box */
}


/* 6. Button Styles (AmberGold, Nebula, Obsidian) */
.nebulabutton-light, .ambergoldbutton, .nebulabutton, .obsidianbutton {
    padding: 25px 60px;
    border-radius: 8px;
    cursor: pointer;
    display: inline-block;
    color: #ffffff;
    text-decoration: none;
    transition: all 0.3s ease;
    font-weight: 500;
}

.ambergoldbutton {
    background: radial-gradient(circle at center, #d49a46 0%, #a76d16 50%, #4a2f0a 100%);
    border: 1px solid rgba(255, 255, 255, 0.15);
    box-shadow: 0 4px 15px rgba(74, 47, 10, 0.5);
}

.ambergoldbutton:hover {
    filter: brightness(1.15);
    transform: translateY(-2px);
    box-shadow: 0 8px 25px rgba(167, 109, 22, 0.4);
}
.nebulabutton-light {
    background: radial-gradient(circle at center, #A5DEFF, #40A9FF);
     border: 1px solid #3598E6;
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.1);
    color: black;
}

.nebulabutton-light:hover {
    filter: brightness(1.05); 
    transform: translateY(-2px) scale(1.02);
    box-shadow: 0 8px 20px rgba(64, 169, 255, 0.4);
}


.nebulabutton {
    background: radial-gradient(circle at center, #69bff8, #002E5D);
    border: none;
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.15);
}

.nebulabutton:hover {
    box-shadow: 0 8px 20px rgba(0, 46, 93, 0.4);
    transform: translateY(-2px) scale(1.02);
    filter: brightness(1.1);
}

.obsidianbutton {
    background: linear-gradient(180deg, #2d2d2d 0%, #121212 100%);
    border: 1px solid rgba(255, 255, 255, 0.1);
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.4);
}

.obsidianbutton:hover {
    background: linear-gradient(180deg, #3d3d3d 0%, #1a1a1a 100%);
    box-shadow: 0 6px 20px rgba(0, 0, 0, 0.6);
    transform: translateY(-1px);
}

/* 7. Stacked Cards & Grid Containers (PDF pages 7/8) */
.stackedcard-container {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    gap: 10px;
    padding: 10px 20px;
    align-items: flex-start;
}

.stackedcard {
    flex: 1 1 calc(33.333% - 20px);
    background-color: #f9f9f9;
    padding: 10px;
    box-shadow: 0 4px 6px rgba(0,0,0,0.1);
    box-sizing: border-box;
    border-top: 1px solid #727272;
}

.stackedcard-title {
    color: #565656;
    font-size: 1.2em;
    font-weight: 300;
    text-align: center;
    padding: 3px 0 2px 0;
    border-bottom: 1px solid #727272;
}

.grid-container {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(80px, 100px));
    gap: 15px;
    max-width: 1200px;
    justify-content: center;
}

.grid-item {
    background-color: #f9f9f9;
    padding: 10px;
    text-align: center;
    box-shadow: 0 4px 6px rgba(0,0,0,0.1);
    box-sizing: border-box;
}

.grid-item img {
    max-width: 100%;
    height: auto;
    display: block;
}

.grid-item .logo-text {
    font-size: 0.75rem;
    color: #666;
}

/* 8. Footer (PDF page 9) */
footer {
    background-color: #f4f4ff;
    padding: 30px 20px;
    text-align: center;
    border-top: 1px solid #eee;
}

footer p {
    font-size: 0.85rem;
    color: #606060;
}

.cell2 {
    flex: 1;
    text-align: center;
    box-sizing: border-box;
}

/* 9. Mobile Handling @media (max-width: 768px) */
@media (max-width: 768px) {
    .stackedcard, .logo  {
        margin-top: 0px !important;
    }
    .title-top, .banner_row, .diagnosys-row, .align-row, .container2a {
        flex-direction: column;
    }
    .stackedcard-container, .feature-row, .stream-row {
        flex-direction: column;
        gap: 15px;
        padding: 20px; /* Ensures padding is correct on mobile stack */
    }
    .menu{
        margin-top:20px;
        border-top: 1px solid #9fc4e7;
    }
    .titlepara, .nav {
        text-align: center !important;
        align-items: center !important;
    }

    .stackedcard {
        flex: none;
        max-width: 100%;
        border-top: none !important;
        border-radius: 8px;
    }
    .logo {
        place-self: center;
    }
    .img_mshrink {
        width: 50%;
        border-radius: 15px;
        aspect-ratio: auto;
    }
    .feature-list li, .stream-list li {
        text-align: left;
    }
    .heroslogan { font-size: 2.5rem; 
    }
    .accela-image-display {
    max-width: 100%;
    height: auto;
    }

.banner-image img {
    /* width: 100%;      Scales image to the container's width */
     max-width: 200px;
     height: auto;     
}
    .nebulabutton-light, .ambergoldbutton, .nebulabutton, .obsidianbutton {
    padding: 20px 40px;
    }
.bannerslogan { 
    font-size:35px;
}

    .tagline{
    font-size: 16px; 
    }

}
