/* =========================================
   BASE LAYOUT & TYPOGRAPHY
========================================= */
.t4-main-body {
    padding-top: 0 !important;
    padding-bottom: 0 !important;
}

/* Logo */
.navbar-brand.logo-control img.logo-img {
    max-height: 118px;
}

/* Header transparent spacing */


/* Headings */
/* Headings ONLY in the masthead */
.t4-masthead h1,
.t4-masthead h2,
.t4-masthead h3,
.t4-masthead .t4-masthead-title,
.t4-masthead .t4-masthead-description {
    font-family: "EB Garamond", serif;
    color: #fff;
}



h2, .heading2 h3, .heading h3 span {
    text-transform: uppercase !important;
}

.heading h3 span {
    font-size: 0.8em;
}

.heading h4, .heading2 h2 {
    font-size: 3.5em;
    text-transform: capitalize !important;
}

/* Buttons */
.btn,
.blog-list .item-readmore a {
    --t4-btn-font-size: 1rem;
}

.t4-wrapper .btn,
.t4-wrapper .blog-list .item-readmore a,
.blog-list .item-readmore .t4-wrapper a {
    margin-top: 2rem;
}

/* =========================================
   HERO SECTION
========================================= */
.hero-content {
    display: flex;
    justify-content: flex-end;
    align-items: center;
    height: 100%;
    padding-right: 5%;
}

.hero-content-inner {
    text-align: left;
    max-width: 500px;
    line-height: 45px;
}

/* Responsive hero text */
@media (max-width: 991px) {
    .hero-content {
        justify-content: center;
        padding-right: 0;
    }

    .item.container .row {
        justify-content: center !important;
    }
}

.item.container .row {
    justify-content: flex-end !important;
}

/* Center button in module */
#Mod151 .text-uppercase {
    display: flex !important;
    justify-content: center !important;
    width: 100%;
}



/* =========================================
   STATS BLOCKS
========================================= */
.acm-stats.style-1 .stats-count,
.stats-title.h6 {
    color: #E8893C !important;
}

.orange-text { color: #E8893C; font-weight: 700; }
.turquoise-text { color: #64BCCC; font-weight: 700; }

.acm-stats.style-1 .row > div + div {
    border-left: 1px solid #E8893C;
}

/* =========================================
   MISC FIXES
========================================= */
.t4-header.t4-sticky {
    z-index: 9999 !important;
}

body.dark-active .bg-white {
    background-color: rgba(255, 255, 255, 0.8) !important;
}

.advantage h5 {
    color: #E8893C;
}

/* SPB Articles */
.spb-article {
    background-color: #fff;
    border-radius: 12px; margin-top:50px;
    box-shadow: 0 2px 10px rgba(0,0,0,0.05);
}

.spb-article .article-title {
    font-family: "EB Garamond", serif;
    font-size: 2.5rem;
    margin-bottom: 1rem;
    color: #222;
    text-align: center;
}

.spb-article .article-date {
    text-align: center;
    font-style: italic;
    color: #888;
}

.spb-article .article-content {
    font-size: 1.1rem;
    line-height: 1.7;
    color: #444;
}

/* Hide author */
.sppb-meta-author { display: none !important; }

/* =========================================
   FEATURES BLOCKS
========================================= */
.features-intro.style-2 .features-item {
    display: flex;
    flex-direction: column !important;
}

.features-intro.style-2 .features-item .feature-title {
    order: -2 !important;
    margin-bottom: 15px;
}

.features-intro.style-2 .features-item .feature-media {
    order: -1 !important;
    margin-bottom: 15px;
}

.features-intro.style-2 .features-item .feature-text,
.features-intro.style-2 .features-item .feature-desc {
    order: 0;
}

/* =========================================
   LIST STYLES
========================================= */
.to-list ul, .to-list2 ul {
    list-style: none;
    padding-left: 5px;
    line-height: 2.2;
}

.to-list ul li::before { content: '✓'; position: absolute; left: 0; color: #E8893B; font-weight: bold; }
.to-list2 ul li::before { content: '✓'; position: absolute; left: 0; color: #43B4BC; font-weight: bold; }

.to-list ul li, .to-list2 ul li { position: relative; padding-left: 25px; }

.to-highlight { color:#64BBCB; }

/* Buttons */
.btn.btn-outline-warning {
    border-color: #FF9800;
    color: #FF9800;
    border-radius: 50px;
}

/* =========================================
   SCROLLING BANNER
========================================= */
.scroll-banner {
    width: 80%;
    margin: 0 auto;
    overflow: hidden;
    background: transparent;
    padding: 10px 0;
    white-space: nowrap;
}
.scroll-text {
    display: inline-block;
    padding-left: 100%;
    animation: scroll-left 30s linear infinite;
    color: #fff;
    font-weight: 600;
    font-size: 1.5em;
}
.scroll-items {
    display: inline-block;
    padding-left: 100%;
    animation: scroll-left 30s linear infinite;
}

.scroll-items .item {
    display: inline-flex;
    align-items: center;
    margin-right: 50px; /* spacing between logos */
}

.scroll-items .item img {
    height: 120px; /* adjust logo size */
    margin-right: 10px; /* space between logo and text */
}

.scroll-items .item span {
    font-size: 18px;
    color: #fff;
}

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

/* =========================================
   HERO IMAGE & AVATAR
========================================= */
.hero-image {
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 40px 0;
    position: relative;
    z-index: auto;
}

.enhanced-float {
    animation: floatIn 1.2s ease-out forwards;
    opacity: 0;
}

@keyframes floatIn {
    0% { opacity: 0; transform: translateY(30px) scale(0.95); }
    100% { opacity: 1; transform: translateY(0) scale(1); }
}

/* Avatar & AI Waveform */
.customer-call-visual { position: relative; display: inline-block; z-index: auto; }

.customer-avatar svg {
    width: 180px;
    height: 180px;
    display: block;
}

.ai-waveform-overlay {
    position: absolute;
    bottom: -20px;
    left: 50%;
    transform: translateX(-50%);
    width: 180px;
    z-index: auto;
}

.waveform-bars {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    height: 40px;
    width: 100%;
}

.waveform-bars span {
    width: 6px;
    border-radius: 3px;
    background: #43B4BC;
    display: block;
    opacity: 0.85;
    animation: waveMotion 1s infinite ease-in-out;
}

.waveform-bars span:nth-child(1) { height: 10px; animation-delay: 0s; }
.waveform-bars span:nth-child(2) { height: 22px; animation-delay: 0.1s; }
.waveform-bars span:nth-child(3) { height: 14px; animation-delay: 0.2s; }
.waveform-bars span:nth-child(4) { height: 28px; animation-delay: 0.3s; }
.waveform-bars span:nth-child(5) { height: 18px; animation-delay: 0.4s; }
.waveform-bars span:nth-child(6) { height: 28px; animation-delay: 0.5s; }
.waveform-bars span:nth-child(7) { height: 14px; animation-delay: 0.6s; }
.waveform-bars span:nth-child(8) { height: 22px; animation-delay: 0.7s; }
.waveform-bars span:nth-child(9) { height: 10px; animation-delay: 0.8s; }
.waveform-bars span:nth-child(10){ height: 16px; animation-delay: 0.9s; }

@keyframes waveMotion {
    0%, 100% { transform: scaleY(0.4); }
    50% { transform: scaleY(1); }
}

.ai-badge {
    margin-top: 10px;
    background: #43B4BC;
    color: #fff;
    padding: 6px 12px;
    border-radius: 20px;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 13px;
    font-weight: 600;
    box-shadow: 0 0 12px rgba(67,180,188,0.6);
}

/* Responsive */
@media (max-width: 600px) {
    .customer-avatar svg { width: 140px; height: 140px; }
    .ai-waveform-overlay { width: 140px; bottom: -16px; }
}

/* =========================================
   INTERACTIVE WAVEFORM & STATUS
========================================= */
.interactive-waveform-wrapper {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 12px;
    padding: 10px 0;
}

.interactive-waveform {
    display: flex;
    align-items: flex-end;
    justify-content: center;
    gap: 6px;
    height: 60px;
}

.wave-bar {
    width: 6px;
    height: 10px;
    background: #43B4BC;
    border-radius: 4px;
    animation: waveAnim 1.6s ease-in-out infinite;
    animation-delay: var(--delay);
    box-shadow: 0 0 10px rgba(67,180,188,0.6);
    opacity: 0.9;
    transform-origin: bottom center;
}

@keyframes waveAnim {
    0%,100%{ transform: scaleY(0.3); }
    50%{ transform: scaleY(1); }
}

.interactive-waveform:hover .wave-bar { animation-duration: 1.1s; }

.waveform-status {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 14px;
    font-weight: 600;
    color: #43B4BC;
}

.status-dot {
    width: 10px;
    height: 10px;
    background: #43B4BC;
    border-radius: 50%;
    animation: pulse 1s infinite ease-in-out;
}

@keyframes pulse {
    0%,100%{ transform: scale(0.7); opacity:0.7; }
    50%{ transform: scale(1.2); opacity:1; }
}

@media (max-width:600px){
    .interactive-waveform { height:45px; gap:4px; }
    .wave-bar { width:5px; }
    .waveform-status { font-size:12px; }
    .status-dot { width:8px; height:8px; }
}

/* =========================================
   SP PAGE BUILDER MODAL FIX (always on top)
========================================= */
.sppb-modal {
    z-index: 99999 !important;
}
.hero-phases {
    display: flex;
    align-items: center;
    gap: 1.5rem;
    justify-content: center;
    padding: 2rem 1rem;
}

/* Phase badges */
.phase-badge {
    background: #ffffff;
    border-radius: 16px;
    padding: 1rem 1.5rem;
    text-align: center;
    min-width: 160px;
    box-shadow: 0 0 25px rgba(143, 204, 185, 0.3);
    transition: all 0.3s ease;
}

/* Labels */
.hero-phases {
    display: flex;
    align-items: center;
    gap: 1.5rem;
    justify-content: center;
    padding: 2rem 1rem;
}

/* Phase badges */
.phase-badge {
    background: #43B4BC;
    border-radius: 16px;
    padding: 1rem 1.5rem;
    text-align: center;
    min-width: 160px;
    box-shadow: 0 0 25px rgba(143, 204, 185, 0.3);
    transition: all 0.3s ease;
}

/* Labels */
.phase-badge .phase-label {
    display: block;
    font-size: 0.85rem;
    font-weight: 600;
    color: #fff;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.phase-badge .phase-module {
    display: block;
    margin-top: 4px;
    font-size: 1.1rem;
    font-weight: 700;
    color: #fff;
}

/* Active step highlights */
.phase-badge.active {
    background: #43B4BC;
    color: #fff;
    box-shadow: 0 0 25px rgba(143, 204, 185, 0.3);
}

.phase-badge.active .phase-label,
.phase-badge.active .phase-module {
    color: #fff !important;
}

/* Arrow between badges */
.phase-arrow {
    font-size: 1.8rem;
    font-weight: 700;
    color: #fff;
    user-select: none;
}

/* On hover (optional – subtle polish) */
.phase-badge:hover {
    transform: translateY(-4px);
    box-shadow: 0 0 25px rgba(143, 204, 185, 0.3);
}

/* Mobile responsiveness */
@media (max-width: 600px) {
    .hero-phases {
        flex-direction: column;
        gap: 1rem;
    }

    .phase-arrow {
        transform: rotate(90deg);
    }
}


.visual-placeholder {
    background: transparent;
    border-radius: 20px;
    padding: 2.5rem 2rem;
    max-width: 700px;
    text-align: center;
    box-shadow: 0 0 25px rgba(143, 204, 185, 0.3);
    border: 1px solid #43B4BC;
}

.placeholder-label {
    font-size: 1.4rem;
    font-weight: 700;
    color: #fff;
    margin-bottom: 0.75rem;
    letter-spacing: 0.3px;
}

.placeholder-description {
    font-size: 1rem;
    line-height: 1.55;
    color: #fff;
    margin: 0;
    max-width: 600px;
    margin-left: auto;
    margin-right: auto;
}

/* Hover polish (optional) */
.visual-placeholder:hover {
    box-shadow: 0 0 25px rgba(143, 204, 185, 0.3);
    transform: translateY(-3px);
    transition: all 0.3s ease;
}

/* Mobile responsiveness */
@media (max-width: 600px) {
    .visual-placeholder {
        padding: 2rem 1.5rem;
    }

    .placeholder-label {
        font-size: 1.2rem;
    }

    .placeholder-description {
        font-size: 0.95rem;
    }
}
/* Ensure button layout supports arrow on right */
.sppb-panel-heading {
    display: flex !important;
    align-items: center;
    justify-content: space-between;
}

/* Add arrow after each accordion button, pointing down initially */
.sppb-panel-heading::after {
    content: "▾"; /* down arrow */
    font-size: 3rem;
    color: #43B4BC; /* your brand color */
    margin-left: auto;
    transition: transform 0.3s ease;
}

/* Rotate arrow when accordion is open */
.sppb-panel-heading[aria-expanded="true"]::after {
    transform: rotate(180deg); /* points up */
}
/* Timeline container */
.timeline-items {
    position: relative;
    margin: 2rem 0;
    padding-left: 30px;
}

/* Vertical line */
.timeline-items::before {
    content: "";
    position: absolute;
    left: 33px;
    top: 0;
    bottom: 0;
    width: 2px;
    background: #43B4BC;
}

/* Each item */
.timeline-item {
    position: relative;
    margin-bottom: 2.5rem;
}

/* Marker (dot) */
.timeline-marker {
    position: absolute;
    left: -3px;
    top: 4px;
    width: 14px;
    height: 14px;
    border-radius: 50%;
    background: #43B4BC;
    border: 3px solid #ffffff;
    box-shadow: 0 0 10px rgba(143, 204, 185, 0.4);
}

/* Content area */
.timeline-content {
    padding-left: 25px;
}

.timeline-content h4 {
    margin: 0 0 0.3rem;
    font-size: 1.2rem;
    font-weight: 700;
    color: #43B4BC;
}

.timeline-content p {
    margin: 0;
    color: #fff;
    line-height: 1.5;
}

/* Optional hover effect */
.timeline-item:hover .timeline-marker {
    transform: scale(1.15);
    box-shadow: 0 0 15px rgba(143, 204, 185, 0.6);
    transition: all 0.25s ease;
}

/* Mobile adjustments */
@media (max-width: 600px) {
    .timeline-items {
        padding-left: 25px;
    }

    .timeline-marker {
        left: -5px;
    }

    .timeline-content {
        padding-left: 20px;
    }
}
/* JT Filter Buttons Styling */
ul.simplefilter239 {
    display: flex;           /* Display all buttons in one row */
    flex-wrap: wrap;         /* Wrap if necessary on very small screens */
    gap: 5px;                /* Space between buttons */
    padding: 0;
    margin: 0 0 20px 0;
    list-style: none;
}

ul.simplefilter239 li {
    background-color: #43B4BC;   /* Your website color */
    color: #fff;                  /* Text color */
    padding: 6px 12px;            /* Smaller padding to make buttons compact */
    font-size: 14px;              /* Smaller font size */
    border-radius: 4px;           /* Rounded corners */
    cursor: pointer;
    text-align: center;
    white-space: nowrap;          /* Prevent text from wrapping */
    transition: background-color 0.3s, transform 0.2s, box-shadow 0.2s;
    border: 2px solid transparent; /* Default border */
}

ul.simplefilter239 li:hover {
    background-color: #2b7f84;    /* Slightly darker on hover */
    transform: translateY(-2px);  /* Lift effect */
    border: 2px solid #8FCCB9;    /* Highlight border on hover */
    box-shadow: 0 2px 5px rgba(143, 204, 185, 0.5); /* Subtle glow */
}

ul.simplefilter239 li.active,
ul.simplefilter239 li.fltr-controls.active {
    background-color: #1f5e63;    /* Active button color (darker shade) */
    border: 2px solid #8FCCB9;    /* Highlight border for active state */
    box-shadow: 0 2px 5px rgba(143, 204, 185, 0.5); /* Glow for active button */
}

ul.simplefilter239 li.fltr-controls239 {
    background-color: #43B4BC;    /* Ensure non-active buttons use your color */
    border: 2px solid transparent; /* Non-active default border */
}
/* Rounded Outline Button for JT Readmore */
a.jt-readmore.btn-primary {
    background-color: transparent !important;
    border: 1px solid #43B4BC !important;
    color: #43B4BC !important;
    padding: 8px 20px;
    font-size: 14px;
    font-weight: 600;
    border-radius: 999px; /* makes it fully round */
    display: inline-flex;
    align-items: center;
    gap: 6px;
    transition: all 0.25s ease;
    text-decoration: none !important;
}

/* Icon styling */
a.jt-readmore.btn-primary i {
    font-size: 14px;
}

/* Hover effect */
a.jt-readmore.btn-primary:hover {
    background-color: #43B4BC !important;
    color: #fff !important;
    transform: translateY(-2px);
}

/* Active click */
a.jt-readmore.btn-primary:active {
    background-color: #2b7f84 !important;
    border-color: #2b7f84 !important;
    transform: translateY(0);
}

/* Focus outline */
a.jt-readmore.btn-primary:focus {
    outline: 2px solid #8FCCB9 !important; /* highlight color */
    outline-offset: 3px;
}
body, html {
    overflow-x: hidden; /* hides horizontal scroll */
}
.item-page.layout-default.no-sidebar .bottom-article-info, .item-page.layout-default.no-sidebar .full-image {
    display: none;
}
.article-item .article-intro-img{
    display:none;
}
/* Responsive + centered YouTube iframe */
.article-content iframe {
    display: block;
    margin: 0 auto;
    max-width: 100%;
}

.article-content p {
    text-align: center; /* ensures parent doesn't mess with centering */
}
.blog-articles{
    display: block !important;
    margin: 0 auto;
    width: 100%;
    max-width: 100%;
}
.t4-footnav {
    padding-top: 75px;
}

.starfield-section {
    position: relative !important;
    overflow: visible !important;
    z-index: 1 !important;
}


.starfield-section .starfield-canvas {
    position:absolute;
    top:0; left:0;
    width:100% !important;
    height:100% !important;
    pointer-events:auto !important;
}

/* All content must appear above the canvas 
.starfield-section > * {
    position: relative;
    z-index: 2;
}*/
