/* 
Theme Name: Onyx 
Theme URI: https://github.com/elementor/hello-theme/
Description: Onyx is a child theme of Hello Elementor
Author: Spire Communications
Author URI: https:/spirecommunicaitons.com/
Template: hello-elementor
Version: 1.0.1
Text Domain: hello-elementor-child
License: GNU General Public License v3 or later.
License URI: https://www.gnu.org/licenses/gpl-3.0.html
Tags: flexible-header, custom-colors, custom-menu, custom-logo, editor-style, featured-images, rtl-language-support, threaded-comments, translation-ready
*/



/* new css */


:root {
  --onyx-depth: #111111;
  --onyx-50: rgba(17,17,17,0.5);
  --onyx-25: rgba(17,17,17,0.25);
  --gray: #4C4C4C;
  --pure: #ffffff;
  --pure-60: rgba(255,255,255,0.6);
  --pure-40: rgba(255,255,255,0.4);
  --crimson: #fe3619;
  --gray-light: #dbdbdb;
  --pub-bg: #252525;
  --font-hero: 90px;
  --font-section: 60px;
  --font-card-lg: 60px;
  --font-card-md: 54px;
  --font-card-sm: 46px;
  --font-heading: 36px;
  --font-caption: 28px;
  --font-body: 24px;
  --font-badge: 20px;
  --font-eighteen: 18px;
  --font-sixteen: 16px;
  --container-margin: 60px;
  --section-gap: 60px;
  --padding-sm: 30px;
  --padding-md: 45px;
  --padding-lg: 60px;
    --radius: 15px;
  --radius-pill: 999px;
  --urbanist: 'Urbanist', sans-serif;
  --outfit: 'Outfit', sans-serif;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
a { text-decoration: none; color: inherit; }
ul { list-style: none; }

@font-face {
    font-family: 'Urbanist';
    src: url(../fonts/Urbanist-VariableFont_wght.ttf);
}

@font-face {
    font-family: 'Outfit';
    src: url(../fonts/Outfit-Regular.ttf);
}



/* footer css */
.footer {
    background: var(--white);
    margin: 15px;
    margin-top: 0;
}

.footer__main {
    max-width: 1512px;
    width: 100%;
    margin: 0 auto;
    display: flex;
    justify-content: space-between;
    gap: 40px;
    align-items: start;
    padding: var(--padding-sm) var(--padding-lg);
}

.footer__links-wrapper {
    display: flex;
    gap: 80px;
}

.footer__col-title {
    font-size: var(--font-body);
    font-weight: 600 !important;
    color: var(--onyx-depth);
    margin-bottom: 10px;
    letter-spacing: -0.1px;
    font-family: var(--urbanist);
}

.footer__links {
    display: flex;
    flex-direction: column;
    gap: 5px;
}

.footer__links li {
  line-height: 1.2;
}

.footer__links a {
    font-size: var(--font-badge);
    color: var(--onyx-50);
    transition: color 0.2s ease;
    white-space: nowrap;
    font-family: var(--outfit);
}

.footer__links a:hover {
    color: #555;
}

.footer__spacer {
}

.footer__contact {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    text-align: right;
    gap: 4px;
}

.footer__phone {
    font-size: var(--font-caption);
    font-family: var(--outfit);
    font-weight: 700;
    color: var(--crimson);
    letter-spacing: -0.5px;
    margin-bottom: 12px;
    line-height: 1;
}

.footer__company-name {
    font-size: var(--font-body);
    font-weight: 400;
    color: var(--onyx-50);
    line-height: 1.6;
    font-family: var(--outfit);
}

.footer__address {
    font-size: var(--font-body);
    font-weight: 400;
    color: var(--onyx-50);
    font-family: var(--outfit);
    line-height: 1.6;
}

.footer__logo {
    display: flex;
    justify-content: flex-end;
}

.footer__logo img {
    width: 280px;
}

.footer__logo-text {
    font-size: clamp(48px, 7vw, 88px);
    font-weight: 700;
    color: var(--onyx-depth);
    letter-spacing: -3px;
    line-height: 1;
    font-family: var(--urbanist);
    position: relative;
}

.footer__bottom {
    max-width: 1512px;
    margin: 0 auto;
    display: flex;
    align-items: center;
    justify-content: space-between;
    align-items: flex-end;
    padding: 0 var(--padding-lg);
}

.footer__copyright {
    font-size: var(--font-sixteen);
    color: var(--onyx-50);
    font-family: var(--outfit);
}

.footer ul {
    margin: 0;
    padding: 0;
}

/* Tablet */
@media (max-width: 1024px) {
    .footer__main {
        gap: 40px;
    }
    .footer__spacer { display: none; }
    .footer__links-wrapper { gap: 48px; }
}

@media (max-width: 900px) {
    .footer-top { grid-template-columns: 1fr 1fr; }
    .footer-contact { text-align: left; }
    .footer-logo { text-align: left; }
    .footer-col.third-column {
        display: none;
    }
}
/* Mobile */
@media (max-width: 680px) {
    .footer__main {
        gap: 40px;
        flex-direction: column;
        padding: 0;
    }
    .footer__contact {
        align-items: flex-start;
        text-align: left;
    }
    .footer__logo {
        justify-content: flex-start;
    }
    .footer__bottom {
        padding: 16px 24px;
        flex-direction: column-reverse;
        gap: 8px;
        text-align: center;
        align-items: center;
    }
    .footer__links-wrapper { gap: 40px; }
}

@media (max-width: 640px) {
    footer { padding: 30px 20px 20px; }
    .footer-top { grid-template-columns: 1fr 1fr; gap: 24px; }
    .footer-contact { grid-column: 1 / -1; }
}

@media (max-width: 420px) {
    .footer__links-wrapper {
        flex-direction: column;
        gap: 32px;
    }
}
/* footer css */

/* CTA css */


.cta-btn.book-meeting {
    padding: 5px 22px 5px 5px;
    background: var(--pure);
    border: 1px solid var(--onyx-50);
}

.cta-btn.book-meeting .icon {
    width: 39px;
    height: 39px;
}

.cta-btn.book-meeting .icon::before {
    background: var(--onyx-depth);
}

.cta-btn.book-meeting .icon::after {
    color: var(--pure);
}

.cta-btn.book-meeting:hover .icon {
    background: var(--onyx-depth);
}

.cta-btn.crimson-btn {
    padding: 8px 25px 8px 5px;
    background: var(--crimson);
    border: 1px solid var(--crimson);
}

.cta-btn.crimson-btn .icon {
    width: 44px;
    height: 44px;
}

.cta-btn.crimson-btn .icon::before {
    background: var(--pure);
}

.cta-btn.crimson-btn .icon::after {
    color: var(--onyx-depth);
}

.cta-btn.crimson-btn:hover .icon {
    background: var(--pure)
}

.cta-btn.crimson-btn .text {
    color: #fff;
}

.cta-btn.onyx-btn {
    padding: 8px 25px 8px 5px;
    background: var(--onyx-depth);
    border: 1px solid var(--pure-40);
}

.cta-btn.onyx-btn .icon {
    width: 44px;
    height: 44px;
}

.cta-btn.onyx-btn .icon::before {
    background: var(--pure);
}

.cta-btn.onyx-btn .icon::after {
    color: var(--onyx-depth);
}

.cta-btn.onyx-btn:hover .icon {
    background: var(--pure)
}

.cta-btn.onyx-btn .text {
    color: #fff;
}

.cta-btn {
    font-family: var(--urbanist);
    display: inline-flex;
    align-items: center;
    gap: 16px;
    padding: 12px 28px;
    border-radius: 50px;
    border: none;
    cursor: pointer;
    font-size: var(--font-badge);
    box-sizing: border-box;
    width: fit-content;
}

/* ICON CONTAINER (fixed size always) */
.icon {
    border-radius: 50%;
    background: transparent;
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
}

/* BULLET (17px exact) */
.icon::before {
    content: "";
    width: 17px;
    height: 17px;
    background: #000;
    border-radius: 50%;
    position: absolute;
    transition: opacity 0.3s ease, transform 0.3s ease;
}

/* ARROW (hidden initially) */
.icon::after {
    content: "→";
    font-size: 30px;
    position: absolute;
    opacity: 0;
    transform: translateX(-8px);
    transition: opacity 0.3s ease, transform 0.3s ease;
}

.cta-btn:hover .icon::before {
    opacity: 0;
    transform: scale(0.5); /* no layout impact */
}

.cta-btn:hover .icon::after {
    opacity: 1;
    transform: translateX(0);
}

/* TEXT */
.text {
    color: #000;
    white-space: nowrap;
}
/* CTA css */

/* blog-list css */
.blog-list {
    margin: 0 15px;
}
.blog-list .hero {
    background: var(--onyx-depth);
    width: 100%;
    height: 952px;
    border-radius: 0 0 var(--radius) var(--radius);
    padding: var(--padding-lg);
    position: relative;
}

.blog-list .hero-main {
    max-width: 1512px;
    width: 100%;
    margin: auto;
    padding-top: 180px;
    text-align: center;
}

.blog-list .hero-flex {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 40px;
    max-width: 1512px;
    width: 100%;
    margin: auto;
}

.blog-list .hero-left {
    width: 50%;
}

.blog-list .hero-right {
    width: 50%;
    font-family: var(--urbanist);
}

.blog-list .hero-title {
    font-family: var(--urbanist);
    font-size: var(--font-hero);
    color: var(--pure);
    font-weight: 400;
    line-height: 1.05;
    letter-spacing: -1px;
}

.blog-list .hero-explore {
    margin-top: 40px;
    display: flex;
    align-items: center;
    gap: 10px;
    color: var(--pure);
    font-size: var(--font-body);
    font-family: var(--urbanist);
    cursor: pointer;
    opacity: 0.85;
    transition: opacity .2s;
}

.blog-list .hero-explore:hover { opacity: 1; }

.blog-list .explore-icon {
    width: 34px;
    height: 34px;
    background: var(--crimson);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 30px;
    color: var(--pure);
    flex-shrink: 0;
}

.blog-list .pub-content {
    width: 100%;
    border-radius: var(--radius);
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
}

.blog-list .pub-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 25px;
}

.blog-list .pub-header span {
    color: var(--gray-light);
    font-size: var(--font-badge);
    font-family: var(--outfit);
}

.blog-list .pub-content span {
    color: var(--pure);
    font-size: var(--font-badge);
    font-family: var(--outfit);
}

.blog-list .pub-nav {
    display: flex;
    gap: 8px;
}

.blog-list .pub-nav button {
    width: 36px;
    height: 36px;
    border: 2px solid var(--gray-border);
    border-radius: 50%;
    background: var(--pure);
    cursor: pointer;
    font-size: 16px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--onyx-depth);
    transition: all .2s;
    flex-shrink: 0;
    padding: 0;
}

.blog-list .pub-nav button:hover {
    background: var(--gray-light);
    color: var(--pure);
    border-color: var(--onyx-depth);
}

.blog-list .pub-nav button.disabled {
    opacity: 0.4;
    cursor: not-allowed;
}

.blog-list .pub-nav button.disabled:hover {
    background: var(--pure);
    color: var(--onyx-depth);
    border-color: var(--gray-border);
}

.blog-list .pub-slides-container {
    position: relative;
    width: 100%;
    overflow: hidden;
    border-radius: var(--radius);
}

.blog-list .pub-slides {
    display: flex;
    transition: transform .4s ease-in-out;
}

.blog-list .pub-slide {
    width: 100%;
    flex-shrink: 0;
}

.blog-list span.pub-tag {
    display: inline-block;
    border: 1px solid var(--onyx-25);
    border-radius: var(--radius-pill);
    padding: 10px 20px;
    font-size: var(--font-badge);
    color: var(--onyx-50);
    background: var(--pure);
    margin-bottom: 10px;
    width: fit-content;
    font-family: var(--outfit);
}

.blog-list .pub-title {
    font-size: var(--font-heading);
    font-family: var(--urbanist);
    font-weight: 700;
    line-height: 1.35;
    color: var(--pure);
    min-height: 200px;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
    display: none;
}

.blog-list .pub-footer {
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: var(--font-badge);
    color: var(--gray-light);
    font-family: var(--urbanist);
    gap: 20px;
}

.blog-list .pub-time {
    display: flex;
    align-items: center;
    gap: 4px;
}

.blog-list .blog-section {
    padding: var(--section-gap) var(--container-margin);
    max-width: 1512px;
    width: 100%;
    margin: auto;
    padding-bottom: 0;
}

.blog-list .filter-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 28px;
}

.search-results .blog-list .filter-row {
  gap: 20px;
}

.blog-list .filter-label {
    font-size: var(--font-body);
    font-family: var(--urbanist);
    font-weight: 500;
    color: var(--onyx-depth);
}

.blog-list .filter-select {
    border: 1px solid var(--onyx-25);
    border-radius: 30px;
    padding: 8px 36px 8px 16px;
    font-size: 13px;
    font-family: var(--urbanist);
    color: var(--onyx-depth);
    appearance: none;
    background: var(--pure) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24'%3E%3Cpath fill='%23333' d='M7 10l5 5 5-5z'/%3E%3C/svg%3E") no-repeat right 12px center;
    cursor: pointer;
    outline: none;
}

.blog-list .blog-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
}

.blog-list .blog-card {
    border: 1px solid var(--onyx-25);
    border-radius: var(--radius);
    padding: var(--padding-sm);
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    min-height: 180px;
    background: var(--pure);
    transition: box-shadow .2s;
    cursor: pointer;
}

.blog-list .blog-card:hover { box-shadow: 0 4px 20px rgba(0,0,0,0.08); }

.blog-list .blog-card.featured {
    background: var(--onyx-depth);
    border-color: var(--onyx-depth);
    color: var(--pure);
}

.blog-list .blog-card.featured .card-tag {
    border-color: var(--gray-light);
    color: var(--gray-light);
}

.blog-list .blog-card.featured .card-date {
    color: var(--gray-light);
}

.blog-list .blog-card.featured .card-read {
    display: flex;
    align-items: center;
    gap: 4px;
    color: var(--gray-light);
}

.blog-list .blog-card.search-card {
    background: var(--crimson);
    border-color: var(--crimson);
    color: var(--pure);
    min-height: 200px;
    justify-content: flex-start;
    gap: 16px;
    position: relative;
    overflow: hidden;
    padding: var(--padding-lg);
    border-radius: var(--radius);
}

.blog-list .search-card-title {
    font-size: var(--font-heading);
    font-family: var(--urbanist);
    line-height: 1.2;
    color: var(--pure);
}

.blog-list .search-card-icon {
    position: absolute;
    top: 16px;
    right: 50px;
    width: 86px;
    height: 86px;
    opacity: 0.9;
}

.search-results .blog-list .search-input-row {
    margin-top: auto;
    border-bottom: 1px solid rgba(12,12,12,0.4);
    display: flex;
    align-items: center;
    padding-bottom: 6px;
    border-radius: 0;
    background: transparent;
}

.blog-list .search-input-row input {
    background: transparent;
    border: none;
    outline: none;
    color: var(--pure);
    font-size: 20px;
    font-family: var(--urbanist);
    flex: 1;
    width: 100%;
}

.blog-list .search-input-row input::placeholder { color: var(--pure); }

.blog-list .search-input-row svg { opacity: 1; flex-shrink: 0; }

.blog-list .card-top { display: flex; flex-direction: column; }

.blog-list .card-tag {
    display: inline-block;
    border: 1px solid var(--onyx-25);
    border-radius: var(--radius-pill);
    padding: 8px 16px;
    font-size: var(--font-badge);
    font-family: var(--outfit);
    color: var(--onyx-50);
    width: fit-content;
}

.blog-list .card-title {
    font-size: var(--font-card-sm);
    font-family: var(--urbanist);
    font-weight: 700;
    line-height: 1.4;
    color: var(--onyx-depth);
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
    height: 100px;
}

.blog-list .blog-card.featured .card-title {
    color: var(--pure);
}

.blog-list .card-bottom {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-top: 16px;
}

.blog-list .card-date {
    font-size: var(--font-badge);
    font-family: var(--outfit);
    color: var(--onyx-50);
}

.blog-list .card-read {
    display: none;
    font-size: var(--font-sm);
    font-family: var(--urbanist);
    color: var(--gray-light);
    align-items: center;
    gap: 4px;
}

.blog-list .blog-card.featured .card-read { display: flex; }

.blog-list .load-more-row {
    display: flex;
    justify-content: center;
    margin-top: 36px;
}

.blog-list .load-more-btn {
    border: 1px solid var(--onyx-25);
    border-radius: var(--radius-pill);
    padding: 12px 28px;
    font-size: var(--font-badge);
    font-family: var(--urbanist);
    font-weight: 500;
    background: var(--pure);
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 8px;
    color: var(--onyx-depth);
    transition: background .2s;
}

.blog-list .load-more-btn:hover { background: var(--gray-light); }

.blog-list .newsletter {
    background: var(--onyx-depth);
    width: 100%;
    border-radius: var(--radius);
}

.blog-list .newsletter-container {
    max-width: 1512px;
    width: 100%;
    background: var(--onyx-depth);
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    padding: var(--padding-lg) var(--container-margin);
    margin: auto;
    gap: 40px;
    flex-wrap: wrap;
    border-radius: var(--radius);
}

.blog-list .newsletter-left .nl-logo {
    width: 52px;
    margin-bottom: 12px;
    opacity: 0.85;
}

.blog-list .newsletter-right {
    flex: 1;
    max-width: 500px;
}

.blog-list .newsletter-right h2 {
    font-family: var(--urbanist);
    font-size: var(--font-card-md);
    color: var(--pure);
    font-weight: 400;
    line-height: 1.2;
    margin-bottom: 20px;
}

.blog-list .nl-input-row {
    border-bottom: 1px solid var(--pure-40);;
    padding: 20px 0;
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 24px;
}

.blog-list .nl-input-row input {
    background: transparent;
    border: none;
    outline: none;
    color: var(--pure-60);
    font-size: var(--font-badge);
    font-family: var(--urbanist);
    flex: 1;
}

.blog-list .nl-input-row input::placeholder { color: var(--pure-60); }

.blog-list .nl-input-row img {
    width: 34px;
    height: 34px;
}

.blog-list .nl-input-row button:hover { color: var(--pure); }

.blog-list .nl-privacy {
    font-size: var(--font-badge);
    color: var(--pure-60);
    font-family: var(--urbanist);
    margin-bottom: 60px;
}

.blog-list .nl-privacy a {
    color: var(--pure);
    text-decoration: none;
    font-family: var(--urbanist);
}

.blog-list .nl-subscribe-btn {
    margin-top: 65px;
    background: var(--pure);
    color: var(--onyx-depth);
    border: none;
    border-radius: var(--radius-pill);
    padding: 12px 28px;
    font-size: var(--font-badge);
    font-weight: 500;
    font-family: var(--urbanist);
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 20px;
    transition: opacity .2s;
}

.blog-list .nl-subscribe-btn:hover { opacity: 0.85; }

.blog-list .nl-subscribe-btn .dot {
    width: 8px; height: 8px;
    background: var(--onyx-depth);
    border-radius: 50%;
}

.onyx-mark {
    display: block;
    width: 86px;
    height: 86px;
}


@media (max-width: 900px) {
    .blog-list .blog-grid { grid-template-columns: repeat(2, 1fr); }
    .blog-list .hero-flex { flex-direction: column-reverse; margin-top: 50px; }
    .blog-list .hero-left {
        width: 100%;
    }
    .blog-list .hero-explore {
        justify-content: flex-end;
    }
    .blog-list .hero-right { flex: unset; width: 100%; max-width: 100%; }
}

@media (max-width: 640px) {
    nav { padding: 0 20px; }
    .nav-links { display: none; }
    .blog-list .hero { padding: var(--padding-lg) }
    .blog-list .blog-grid { grid-template-columns: 1fr; }
    .blog-list .blog-card.search-card { grid-column: span 1 !important; }
    .blog-list .newsletter { padding: var(--padding-lg); flex-direction: column; }
    .blog-list .newsletter-container { padding: 0; flex-direction: column; align-items: flex-start;}
}

/* blog-list css */


/* css for blog detail */
.blog-list.blog-detail * {
  font-weight: normal !important;
}
.single-post .blog-list .blog-title {
  font-family: var(--urbanist);
  font-size: var(--font-caption);
  font-weight: 500;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--pure);
  display: block;
  position: relative;
  z-index: 2;
}
.single-post .blog-detail .hero-title {
    visibility: visible;
    font-family: var(--urbanist);
    font-size: var(--font-section);
    color: var(--pure);
    font-weight: 400;
    line-height: 1.05;
    margin: var(--padding-sm) auto;
}
.hero-breadcrumb ul,
.hero-breadcrumb li {
    list-style-type: none;
}

.hero-breadcrumb ul {
  display: flex;
  color: var(--pure);
  gap: 5px;
  font-size: var(--font-badge);
  font-family: var(--outfit);
}

.single-post .blog-detail span.pub-tag {
  border: 1px solid var(--pure-60);
  color: var(--crimson);
  background: transparent;
  border-radius: var(--radius-pill);
}

.single-post .blog-detail .pub-title {
    color: var(--crimson);
}

.single-post .blog-detail .pub-footer,
.single-post .blog-detail .pub-footer span {
    color: var(--pure);
    font-size: var(--font-badge);
}

.single-post .blog-detail .pub-date-time {
    display: flex;
    gap: 50px;
}

.single-post .blog-detail .pub-author {
    color: var(--pure);
    font-size: var(--font-badge);
    font-family: var(--outfit);
}

.single-post .blog-detail .nl-privacy {
    /* border-top: 2px solid var(--gray-light); */
    padding-top: 24px;
}

.single-post .blog-detail .newsletter h2 {
    margin-bottom: 180px;
}

/* ── Inner two-column grid ── */
.single-post .blog-detail__inner {
    margin: 0 auto;
    display: grid;
    grid-template-columns: 300px 1fr;
    gap: 50px;
    align-items: start;
}

/* ============================================================.blog-detail__rating-label

    LEFT SIDEBAR
============================================================ */
.single-post .blog-detail .blog-section {
    font-family: var(--urbanist);
}

.single-post .blog-detail__sidebar {
    /* position: sticky; */
    /* top: 100px; */
    display: flex;
    flex-direction: column;
    gap: 0;
}

.single-post .blog-detail__share-label {
    font-size: var(--font-badge);
    color: var(--onyx-depth);
    font-family: var(--outfit);
    margin-bottom: 14px;
}

.single-post .blog-detail__share-icons {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 80px;
}

.single-post .blog-detail__share-btn {
    width: 44px;
    height: 44px;
    border-radius: var(--radius-pill);
    border: 1.5px solid var(--onyx-25);
    background: var(--pure);
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: border-color 0.2s ease, color 0.2s ease;
    text-decoration: none;
    color: var(--onyx-50);
    flex-shrink: 0;
}
.single-post .blog-detail__share-btn:hover {
    border-color: var(--crimson);
    color: var(--crimson);
}
.single-post .blog-detail__share-btn svg {
    width: 15px;
    height: 15px;
    stroke: currentColor;
    fill: none;
    stroke-width: 1.8;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.single-post .blog-detail__divider {
    border: none;
    border-top: 1px solid var(--onyx-25);
    margin-bottom: 28px;
}

.single-post .blog-detail__toc-label {
    font-size: var(--font-heading);
    font-weight: 500;
    color: var(--onyx-depth);
    margin-bottom: 16px;
}

.single-post .blog-detail__toc-list {
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: 10px;
    margin-bottom: 32px;
    padding: 0;
}

.single-post .blog-detail__toc-item {
    font-size: var(--font-body);
    font-weight: 400;
    color: var(--onyx-50);
    line-height: 1.4;
    cursor: pointer;
    transition: color 0.2s ease;
}
.single-post .blog-detail__toc-item:hover { color: var(--onyx-depth); }
.single-post .blog-detail__toc-item.is-active {
    color: var(--crimson);
    font-weight: 500;
}

.single-post .blog-detail__tags-label {
    font-size: var(--font-badge);
    color: var(--onyx-depth);
    font-family: var(--outfit);
    margin-bottom: 16px;
}

.single-post .blog-detail__tags {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.single-post .blog-detail__tag {
    display: inline-flex;
    align-items: center;
    padding: 8px 16px;
    border-radius: var(--radius-pill);
    border: 1.5px solid var(--crimson);
    font-size: var(--font-eighteen);
    line-height: 1.3;
    color: var(--crimson);
    background: transparent;
    cursor: default;
    transition: background 0.2s ease, color 0.2s ease;
    text-decoration: none;
}
.single-post .blog-detail__tag:hover {
    background: var(--crimson);
    color: var(--pure);
}


.blog-detail-slider .swiper {
  width: 100%;
  height: 100%;
}

.blog-detail-slider .swiper-slide {
  text-align: center;
  font-size: 18px;
  background: #444;
  display: flex;
  justify-content: flex-start;
  align-items: center;
}

.blog-detail-slider .swiper-slide img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.blog-detail-slider .mySwiper {
  position: relative;
}

.blog-detail-slider .swiper-slide::before {
  content: '';
  position: absolute;
  inset: 0;
  background: var(--onyx-depth);
  transform: translateY(-100%);
  transition: transform 300ms ease-out;
  border-radius: inherit;
  z-index: 0;
}
.blog-detail-slider .swiper-slide:hover::before {
    transform: translateY(0);
}
.blog-detail-slider .swiper-slide {
  border: 1px solid var(--onyx-25);
  border-radius: var(--radius);
  padding: var(--padding-sm);
  display: flex;
  flex-direction: column;
  height: auto;
  gap: 20px;
  position: relative;
  overflow: hidden;
  cursor: pointer;
  background: var(--pure);
}
.blog-detail-slider .swiper-slide p.card-title,
.blog-detail-slider .swiper-slide .card-title {
    font-size: var(--font-body);
    font-family: var(--outfit);
    height: auto;
    line-height: 1.2;
    margin-bottom: 15px;
}
.blog-detail-slider .swiper-slide p.card-content,
.blog-detail-slider .swiper-slide .card-content {
    font-size: var(--font-badge);
    font-family: var(--outfit);
    color: var(--onyx-50);
    line-height: 1.4;
}
.blog-detail-slider .swiper-slide:hover p.card-title,
.blog-detail-slider .swiper-slide:hover .card-title {
    color: var(--pure);
    transition: color 300ms ease-out;
    z-index: 9;
}
.blog-detail-slider .swiper-slide:hover p.card-content,
.blog-detail-slider .swiper-slide:hover .card-content,
.blog-detail-slider .swiper-slide:hover .card-date {
    color: var(--pure-60);
    transition: color 300ms ease-out;
    z-index: 9;
}
.ptnr-page .blog-detail-slider .swiper-slide:hover p.card-title,
.ptnr-page .blog-detail-slider .swiper-slide:hover .card-title {
  position: relative;
  z-index: 9;
}
.ptnr-page .blog-detail-slider .swiper-slide:hover p.card-content,
.ptnr-page .blog-detail-slider .swiper-slide:hover .card-content {
  position: relative;
  z-index: 9;
}
.swiper-button-prev,
.swiper-button-next {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 40px;
  height: 40px;
  background: #000;
  color: #fff;
  border-radius: 50%;
}

.swiper-button-prev,
.swiper-button-next {
  top: -60px;
  transform: none;
}

.swiper-button-prev {
  right: 60px;
  left: auto;
}

.swiper-button-next {
  right: 0;
}
/* ============================================================
    RIGHT CONTENT AREA
============================================================ */
.single-post .blog-detail__content {
    min-width: 0;
}

.single-post .blog-detail__body {
    display: flex;
    flex-direction: column;
    margin-bottom: 40px;
}

/* Body copy → font-xs (15px), gray */
.single-post .blog-detail__p {
    font-size: var(--font-body);
    font-weight: 400;
    color: var(--onyx-50);
    line-height: 1.6;
}

.single-post .blog-detail__section-divider {
    border: none;
    border-top: 1px solid var(--gray-light);
    margin: 0 0 36px;
}

/* Section heading → font-md (26px), onyx-depth */
.single-post .blog-detail__h2 {
    font-size: var(--font-card-sm);
    font-weight: 800;
    color: var(--onyx-depth);
    line-height: 1.25;
    margin-bottom: 28px;
    letter-spacing: -0.3px;
}

/* ── Author card ── */
.single-post .blog-detail__author-card {
    display: flex;
    align-items: stretch;
    border: 1px solid var(--gray-light);
    border-radius: 12px;
    overflow: hidden;
    margin: 48px 0 56px;
    background: var(--pure);
}

.single-post .blog-detail__author-img-placeholder {
    width: 160px;
    min-height: 170px;
    background: var(--gray-light);
    flex-shrink: 0;
}

.single-post .blog-detail__author-info {
    padding: 28px 28px 24px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 6px;
}

/* Author name → font-sm (18px), crimson */
.single-post .blog-detail__author-name {
    font-size: var(--font-sm);
    font-weight: 700;
    color: var(--crimson);
    margin-bottom: 4px;
}

/* Author title → font-xs (15px), gray */
.single-post .blog-detail__author-title {
    font-size: var(--font-xs);
    font-weight: 400;
    color: var(--gray);
    margin-bottom: 20px;
}

.single-post .blog-detail__author-socials {
    display: flex;
    gap: 10px;
}

.single-post .blog-detail__author-social-btn {
    width: 38px;
    height: 38px;
    border-radius: 50%;
    border: 1.5px solid var(--gray-light);
    background: var(--pure);
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: border-color 0.2s ease, background 0.2s ease, color 0.2s ease;
    text-decoration: none;
    color: var(--gray);
}
.single-post .blog-detail__author-social-btn:hover {
    border-color: var(--crimson);
    background: #fff5f3;
    color: var(--crimson);
}
.single-post .blog-detail__author-social-btn svg {
    width: 15px;
    height: 15px;
    stroke: currentColor;
    fill: none;
    stroke-width: 1.8;
    stroke-linecap: round;
    stroke-linejoin: round;
}

/* ── Rate this Article ── */
/* Label → font-sm (18px) */
.single-post .blog-detail__rating-label {
    font-size: var(--font-caption);
    color: var(--onyx-depth);
    margin-bottom: 16px;
    font-family: var(--urbanist);
}

.single-post .blog-detail__rating-divider {
    border: none;
    border-top: 1px solid var(--gray-light);
    margin-bottom: 20px;
}

.single-post .blog-detail__rating-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    flex-wrap: wrap;
}

/* Count text → font-xs (15px), gray */
.single-post .blog-detail__rating-count {
    font-size: var(--font-xs);
    font-weight: 400;
    color: var(--gray);
}

.single-post .blog-detail__stars {
    display: flex;
    align-items: center;
    gap: 6px;
}

.single-post .blog-detail__star {
    width: 26px;
    height: 26px;
    cursor: pointer;
    transition: transform 0.15s ease;
}
.single-post .blog-detail__star:hover { transform: scale(1.2); }

.single-post .blog-detail__star svg {
    width: 26px;
    height: 26px;
    stroke: var(--gray-light);
    fill: none;
    stroke-width: 1.5;
    transition: stroke 0.2s ease, fill 0.2s ease;
}
.single-post .blog-detail__star:hover svg,
.single-post .blog-detail__star.is-filled svg {
    stroke: var(--crimson);
    fill: var(--crimson);
}

/* ============================================================
    RELATED ARTICLES CAROUSEL/SLIDER
============================================================ */

/* Container for the entire carousel section */
.related-articles {
    background: var(--pure);
    padding: var(--section-gap) var(--padding-lg);
}

.related-articles .container {
    max-width: 1512px;
    margin: 0 auto;
    padding: 0;
}

/* Top bar with title and navigation buttons */
.related-articles .top-bar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 40px;
}

.related-articles .top-bar h2 {
    font-size: var(--font-card-sm);
    color: var(--onyx-depth);
    font-family: var(--urbanist);
    margin: 0;
}

/* Navigation buttons container */
.related-articles .nav {
    display: flex;
    gap: 12px;
    justify-content: flex-end;
    align-items: flex-end;
    margin: initial;
    position: relative;
    right: 50px;
}

/* Individual navigation buttons */
.related-articles .nav-btn {
    width: 40px;
    height: 40px;
    border: 1px solid var(--gray-light);
    background: var(--pure);
    border-radius: 100%;
    cursor: pointer;
    font-size: 20px;
    color: var(--onyx-depth);
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.3s ease;
    font-weight: bold;
}

.related-articles .nav-btn:hover {
    background: var(--onyx-depth);
    color: var(--pure);
    border-color: var(--onyx-depth);
}

/* Slider wrapper - hides overflow to show only 3 cards */
.single-post .blog-detail-slider {
    overflow: hidden;
    background: var(--pure);
    width: 100%;
    position: relative;
}

/* Track contains all cards - this element gets translated */
.single-post .blog-detail-slider .track {
    display: flex;
    gap: 24px;
    transition: transform 0.5s ease-in-out;
    will-change: transform;
    padding: 0;
    margin: 0;
}

/* Individual card styling within the slider */
/* Each card takes up calc(33.333% of slider - gap adjustment) */
.single-post .blog-detail-slider .blog-card {
    flex: 0 0 calc(33.333% - 16px);
    min-width: calc(33.333% - 16px);
    height: auto;
}

/* Card top section - contains tag and title */
.blog-card .card-top {
    display: flex;
    flex-direction: column;
    gap: 12px;
    margin-bottom: 16px;
}

/* Card tag styling */
.blog-card .card-tag {
    display: inline-block;
    font-size: var(--font-badge);
    font-family: var(--outfit);
    color: var(--onyx-50);
    border: 1px solid var(--onyx-25);
    padding: 6px 12px;
    border-radius: var(--radius-pill);
    width: fit-content;
}

/* Card title styling */
.blog-card .card-title {
    font-size: var(--font-body);
    color: var(--onyx-depth);
    font-family: var(--urbanist);
    line-height: 1.4;
    font-weight: 500;
}

/* Card bottom section - contains date */
.blog-card .card-bottom {
    display: flex;
    align-items: flex-end;
}

/* Card date styling */
.blog-card .card-date {
    font-size: var(--font-badge);
    color: var(--onyx-50);
    font-family: var(--urbanist);
}

/* ============================================================
    RESPONSIVE
============================================================ */
@media (max-width: 1512px) {
    .hero-main,
    .hero-flex,
    .blog-section,
    .newsletter-container {
        width: 90%
    }
    
  .single-post .blog-detail-slider .blog-card {
        flex: 0 0 calc(50% - 12px);
        min-width: calc(50% - 12px);
    }
}

@media (max-width: 900px) {
  .single-post .blog-detail__inner {
        grid-template-columns: 1fr;
        gap: 50px;
    }
  .single-post .blog-detail__sidebar {
        position: static;
        grid-template-columns: 1fr 1fr;
        column-gap: 40px;
    }
  .single-post .blog-detail__share-label,
  .single-post .blog-detail__share-icons,
  .single-post .blog-detail__divider:first-of-type {
        grid-column: 1 / -1;
    }
    
  .single-post .blog-detail-slider .blog-card {
        flex: 0 0 calc(50% - 12px);
        min-width: calc(50% - 12px);
    }
}

@media (max-width: 640px) {
  .single-post .blog-detail__sidebar { grid-template-columns: 1fr; }
  .single-post .blog-detail__h2 { font-size: var(--font-card-sm); } /* 18px on small screens */
  .single-post .blog-detail__author-card { flex-direction: column; }
  .single-post .blog-detail__author-img-placeholder { width: 100%; min-height: 180px; }
  .single-post .blog-detail__author-info { padding: 20px; }
  .single-post .blog-detail__rating-row { flex-direction: column; align-items: flex-start; gap: 12px; }
    
    .related-articles .top-bar h2 {
        font-size: var(--font-heading);
    }
    
  .single-post .blog-detail-slider .blog-card {
        flex: 0 0 100%;
        min-width: 100%;
    }
    
    .related-articles .nav-btn {
        width: 36px;
        height: 36px;
        font-size: 18px;
    }
  }


  /* ================================
   WORDPRESS CONTENT FIX
================================ */

/* Paragraphs */
.single-post .blog-detail__body p {
    font-size: var(--font-body);
    font-weight: 400;
    color: var(--onyx-50);
    line-height: 1.6;
    font-family: var(--outfit);
    margin-bottom: 10px;
}

ul.wp-block-list,
ul.wp-block-list li {
  list-style-type: disc;
}


/* Headings */
.single-post .blog-detail__body h1,
.single-post .blog-detail__body h2,
.single-post .blog-detail__body h3,
.single-post .blog-detail__body h4 {
    font-family: var(--urbanist);
    color: var(--onyx-depth);
    margin-top: 30px;
    margin-bottom: 15px;
    line-height: 1.3;
}

.single-post .blog-detail__body h2 {
    font-size: var(--font-card-sm);
    font-weight: 800;
}

.single-post .blog-detail__body h3 {
    font-size: var(--font-heading);
}

/* Lists */
.single-post .blog-detail__body ul,
.single-post .blog-detail__body ol {
    padding-left: 20px;
    margin-bottom: 10px;
}

.single-post .blog-detail__body li {
    margin-bottom: 8px;
    color: var(--onyx-50);
}

/* Links */
.single-post .blog-detail__body a {
    color: var(--crimson);
    text-decoration: underline;
}

/* Images */
.single-post .blog-detail__body img {
    width: 100%;
    border-radius: var(--radius);
    margin: 30px 0;
}

/* Blockquote */
.single-post .blog-detail__body blockquote {
    border-left: 4px solid var(--crimson);
    padding-left: 20px;
    margin: 30px 0;
    font-style: italic;
    color: var(--onyx-depth);
}

/* Table */
.single-post .blog-detail__body table {
    width: 100%;
    border-collapse: collapse;
    margin: 30px 0;
}

.single-post .blog-detail__body th,
.single-post .blog-detail__body td {
    border: 1px solid var(--gray-light);
    padding: 10px;
}


  /* Risk adjustment */


   /* ============================================================
       ALL CSS IS SCOPED UNDER .onx-ra-page
       This prevents any leakage into or out of Elementor's styles.
       Add class="onx-ra-page" to the Elementor Custom HTML widget
       wrapper or the section container.
  ============================================================ -*/
  
    /* ── FONT FACES ── */
    @font-face {
      font-family: 'Urbanist';
      src: url('../fonts/Urbanist-VariableFont_wght.ttf') format('truetype');
      font-weight: 100 900;
      font-style: normal;
      font-display: swap;
    }
    
    @font-face {
      font-family: 'Urbanist';
      src: url('../fonts/Urbanist-Italic-VariableFont_wght.ttf') format('truetype');
      font-weight: 100 900;
      font-style: italic;
      font-display: swap;
    }

    /* ── RESET scoped ── */
    .onx-ra-page *, .onx-ra-page *::before, .onx-ra-page *::after {
      box-sizing: border-box;
      margin: 0;
      padding: 0;
    }

    /* ── TOKENS ── */
    .onx-ra-page {
      --onyx-depth:     #111111;
      --pure:           #ffffff;
      --gray-light:     #dbdbdb;
      --crimson:        #fe3619;
      --gray:           #4C4C4C;
      --pub-bg:         #252525;
      --onx-border:     rgba(255,255,255,0.08);
      --onx-sans:       'Urbanist', sans-serif;
      --onx-display:    'Urbanist', sans-serif;
      --onx-radius:     10px;
      --onx-radius-lg:  16px;
      --onx-max-w:      1100px;
      --onx-gap:        32px;
      --font-xs:        15px;
      --font-sm:        18px;
      --font-md:        26px;
      --font-lg:        36px;
      --font-xl:        60px;
      font-family: var(--onx-sans);
      color: var(--onyx-depth);
      background: var(--pure);
      font-size: var(--font-xs);
      line-height: 1.7;
      -webkit-font-smoothing: antialiased;
    }

    .onx-ra-page a {
      text-decoration: none;
      color: inherit;
    }

    /* ── UTILITIES ── */
    .onx-ra-page .onx-container {
      max-width: 1200px;
      margin: 0 auto;
    
    }

    .onx-ra-page .onx-eyebrow {
      font-family: var(--onx-sans);
      font-size: var(--font-xs);
      font-weight: 600;
      text-transform: uppercase;
      letter-spacing: 2px;
      color: var(--crimson);
    }

    .onx-ra-page .onx-h1 {
      font-family: var(--onx-display);
      font-size: clamp(var(--font-lg), 5.5vw, var(--font-xl));
      font-weight: 800;
      line-height: 1.07;
      letter-spacing: -1.5px;
    }

    .onx-ra-page .onx-h2 {
      font-family: var(--onx-display);
      font-size: clamp(var(--font-md), 3.5vw, 28px);
      font-weight: 600;
      line-height: 1.15;
      letter-spacing: -0.8px;
      
    }

    .onx-ra-page .onx-h3 {
      font-family: var(--onx-display);
      font-size: var(--font-sm);
      font-weight: 500;
      letter-spacing: -0.3px;
      line-height: 1.3;
    }

    .onx-ra-page .onx-body {
      font-size: 15.5px;
      color: var(--onx-gray-3);
      line-height: 1.8;
      margin: 0px;
    }

    .onx-ra-page .onx-body-sm {
      font-size: var(--font-xs);
      color: var(--gray);
      line-height: 1.75;
    }

    /* ── BUTTONS ── */
    .onx-ra-page .onx-btn {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      font-family: var(--onx-sans);
      font-size: var(--font-xs);
      font-weight: 600;
      border-radius: 7px;
      padding: 13px 24px;
      cursor: pointer;
      transition: all 0.2s ease;
      border: none;
      white-space: nowrap;
    }

    .onx-ra-page .onx-btn-primary {
      background: var(--crimson);
      color: var(--pure);
    }
    .onx-ra-page .onx-btn-primary:hover {
      background: var(--crimson);
      transform: translateY(-1px);
      box-shadow: 0 4px 12px rgba(254,54,25,0.2);
    }

    .onx-ra-page .onx-btn-ghost {
      background: transparent;
      color: var(--onyx-depth);
      border: 1.5px solid var(--gray-light);
    }
    .onx-ra-page .onx-btn-ghost:hover {
      border-color: var(--onyx-depth);
      background: var(--onyx-depth);
      color: var(--pure);
      
    }

    .onx-ra-page .onx-footer-cta .onx-btn-ghost {
      color: var(--pure);
      border-color: rgba(255,255,255,0.3);
    }
    .onx-ra-page .onx-footer-cta .onx-btn-ghost:hover {
      background: rgba(255,255,255,0.1);
      border-color: var(--pure);
      color: var(--pure);
    }

    .onx-ra-page .onx-btn-ghost-white {
      background: transparent;
      color: var(--pure);
      border: 1.5px solid rgba(255,255,255,0.25);
    }
    .onx-ra-page .onx-btn-ghost-white:hover {
      background: rgba(255,255,255,0.1);
      border-color: rgba(255,255,255,0.5);
    }

    .onx-ra-page .onx-link-arrow {
      font-size: var(--font-xs);
      font-weight: 600;
      color: var(--onyx-depth);
      display: inline-flex;
      align-items: center;
      gap: 6px;
      transition: gap 0.2s;
    }
    .onx-ra-page .onx-link-arrow:hover { gap: 10px; }

    .onx-ra-page .onx-link-arrow-white {
      color: var(--pure);
    }

    /* ================================================================
       SECTION 1 — GLOBAL NAV
    ================================================================ */
    .onx-ra-page .onx-nav {
      position: sticky;
      top: 0;
      z-index: 200;
      background: var(--pure);
      border-bottom: 1px solid var(--gray-light);
      height: 62px;
      display: flex;
      align-items: center;
    }

    .onx-ra-page .onx-nav__inner {
      display: flex;
      align-items: center;
      justify-content: space-between;
      width: 100%;
    }

    .onx-ra-page .onx-nav__logo {
      display: flex;
      align-items: center;
      gap: 8px;
      font-family: var(--onx-display);
      font-weight: 800;
      font-size: 19px;
      letter-spacing: -0.5px;
    }

    .onx-ra-page .onx-nav__logo-mark {
      width: 30px;
      height: 30px;
      background: var(--onyx-depth);
      border-radius: 7px;
      display: flex;
      align-items: center;
      justify-content: center;
    }
    .onx-ra-page .onx-nav__logo-mark svg {
      width: 16px;
      height: 16px;
      fill: white;
    }

    .onx-ra-page .onx-nav__links {
      display: flex;
      align-items: center;
      gap: 26px;
      list-style: none;
      font-size: var(--font-xs);
      font-weight: 500;
      color: var(--gray);
    }
    .onx-ra-page .onx-nav__links li a:hover { color: var(--onyx-depth); }

    .onx-ra-page .onx-nav__cta {
      background: var(--onyx-depth);
      color: var(--pure);
      border-radius: 7px;
      padding: 9px 20px;
      font-size: var(--font-xs);
      font-weight: 600;
    }
    .onx-ra-page .onx-nav__cta:hover { background: var(--pub-bg); }

    /* ================================================================
       SECTION 2 — HERO
    ================================================================ */
    .onx-ra-page .onx-hero {
      background: var(--pure);
      position: relative;
      overflow: hidden;
      padding: 100px 0 90px;
    }

    /* Geometric accent lines */
    .onx-ra-page .onx-hero::before {
      content: '';
      position: absolute;
      top: -120px;
      right: -120px;
      width: 600px;
      height: 600px;
      border-radius: 50%;
      border: 1px solid rgba(232,92,45,0.15);
      pointer-events: none;
    }
    .onx-ra-page .onx-hero::after {
      content: '';
      position: absolute;
      top: -60px;
      right: -60px;
      width: 380px;
      height: 380px;
      border-radius: 50%;
      border: 1px solid rgba(232,92,45,0.1);
      pointer-events: none;
    }

    .onx-ra-page .onx-hero__breadcrumb {
      font-size: var(--font-xs);
      color: var(--gray);
      margin-bottom: 24px;
      display: flex;
      align-items: center;
      gap: 8px;
    }
    .onx-ra-page .onx-hero__breadcrumb a { color: var(--gray); }
    .onx-ra-page .onx-hero__breadcrumb a:hover { color: var(--onyx-depth); }
    .onx-ra-page .onx-hero__breadcrumb span { color: var(--gray); }

    .onx-ra-page .onx-hero__eyebrow {
      color: var(--crimson);
      margin-bottom: 20px;
    }

    .onx-ra-page .onx-hero__title {
      color: var(--onyx-depth);
      max-width: 720px;
      margin-bottom: 28px;
    }

    .onx-ra-page .onx-hero__body {
      color: var(--gray);
      max-width: 600px;
      font-size: var(--font-sm);
      line-height: 1.75;
      margin-bottom: 40px;
    }

    .onx-ra-page .onx-hero__actions {
      display: flex;
      align-items: center;
      gap: 14px;
      flex-wrap: wrap;
    }

    /* Orange dot accent */
    .onx-ra-page .onx-hero__dot {
      position: absolute;
      bottom: -2px;
      left: 50%;
      transform: translateX(-50%);
      width: 6px;
      height: 6px;
      border-radius: 50%;
      background: var(--crimson);
    }

    /* ================================================================
       SECTION 3 — THE PROBLEM
    ================================================================ */
    .onx-ra-page .onx-problem {
      padding: 60px 0 0 0;
      background: var(--pure);
    }

    .onx-ra-page .onx-problem__inner {
      display: block;
  max-width: 1200px;
    }
.onx-ra-page .onx-problem__left {
  margin-bottom: 20px;
}

.onx-ra-page .onx-problem__title {
  max-width: 1200px;
}

.onx-ra-page .onx-problem__right {
  max-width: 1200px;
}
  
    /* ================================================================
       SECTION 4 — HOW ONYXOS ENABLES THIS
    ================================================================ */
    .onx-ra-page .onx-approach {
      padding: 60px 0 0 0;
      background: var(--pure);
    }

    .onx-ra-page .onx-approach__header {
      max-width: 1200px;
      margin-bottom: 16px;
    }

    .onx-ra-page .onx-approach__label { margin-bottom: 14px; }

    .onx-ra-page .onx-approach__title { margin-bottom: 20px; }

    .onx-ra-page .onx-approach__body {
      font-size: var(--font-xs);
      color: var(--gray);
      line-height: 1.8;
      margin-bottom: 10px;
      max-width: 1200px;
    }

    /* ================================================================
       SECTION 5 — KEY CAPABILITIES (5 TILES)
    ================================================================ */
    .onx-ra-page .onx-capabilities {
      padding: 60px 0 0 0;
      background: var(--pure);
    }

    .onx-ra-page .onx-capabilities__header {
      margin-bottom: 48px;
    }

    .onx-ra-page .onx-capabilities__eyebrow {
      color: var(--crimson);
      margin-bottom: 14px;
    }

    .onx-ra-page .onx-capabilities__title {
      color: var(--onyx-depth);
    }

    .onx-ra-page .onx-cap-grid {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 2px;
    }

    .onx-ra-page .onx-cap-tile {
      background: var(--pure);
      padding: 36px 36px 40px;
      position: relative;
      transition: box-shadow 0.25s, transform 0.25s, border 0.25s;
      cursor: default;
      border: 1px solid var(--gray-light);
    }
    .onx-ra-page .onx-cap-tile:hover {
      box-shadow: 0 6px 20px rgba(0,0,0,0.08);
      transform: translateY(-2px);
      border-color: var(--gray-light);
    }

    .onx-ra-page .onx-cap-tile--span {
      grid-column: 1 / -1;
    }

    .onx-ra-page .onx-cap-tile__num {
      font-family: var(--onx-display);
      font-size: var(--font-xs);
      font-weight: 700;
      color: var(--crimson);
      letter-spacing: 2px;
      text-transform: uppercase;
      margin-bottom: 20px;
    }

    .onx-ra-page .onx-cap-tile__title {
      font-family: var(--onx-display);
      font-size: var(--font-sm);
      font-weight: 700;
      color: var(--onyx-depth);
      margin-bottom: 14px;
      letter-spacing: -0.3px;
    }

    .onx-ra-page .onx-cap-tile__body {
      font-size: var(--font-xs);
      color: var(--gray);
      line-height: 1.75;
      max-width: 480px;
    }

    .onx-ra-page .onx-cap-tile__accent {
      position: absolute;
      top: 0;
      left: 0;
      width: 3px;
      height: 0;
      background: var(--crimson);
      transition: height 0.3s ease;
    }
    .onx-ra-page .onx-cap-tile:hover .onx-cap-tile__accent {
      height: 100%;
    }

    /* ================================================================
       SECTION 6 — KEY OUTCOMES
    ================================================================ */
    .onx-ra-page .onx-outcomes {
      padding: 60px 0 0 0;
      background: var(--pure);
    }

    .onx-ra-page .onx-outcomes__header {
      margin-bottom: 48px;
    }

    .onx-ra-page .onx-outcomes__eyebrow { margin-bottom: 14px; }
    .onx-ra-page .onx-outcomes__title { color: var(--onyx-depth); }

    .onx-ra-page .onx-outcome-grid {
      display: grid;
      grid-template-columns: repeat(2, 1fr);
      gap: 20px;
    }

    .onx-ra-page .onx-outcome-card {
      background: var(--pure);
      border: 1px solid var(--gray-light);
      border-radius: var(--onx-radius-lg);
      padding: 32px 30px;
      transition: box-shadow 0.2s, transform 0.2s, border 0.2s;
    }
    .onx-ra-page .onx-outcome-card:hover {
      box-shadow: 0 8px 20px rgba(0,0,0,0.06);
      transform: translateY(-2px);
      border-color: var(--crimson);
    }

    .onx-ra-page .onx-outcome-card__icon {
      width: 44px;
      height: 44px;
      border-radius: 10px;
      background: rgba(254,54,25,0.1);
      display: flex;
      align-items: center;
      justify-content: center;
      margin-bottom: 20px;
    }
    .onx-ra-page .onx-outcome-card__icon svg {
      width: 20px;
      height: 20px;
      stroke: var(--crimson);
      fill: none;
      stroke-width: 2;
      stroke-linecap: round;
      stroke-linejoin: round;
    }

    .onx-ra-page .onx-outcome-card__title {
      font-family: var(--onx-display);
      font-size: var(--font-sm);
      font-weight: 700;
      color: var(--onyx-depth);
      margin-bottom: 10px;
    }

    .onx-ra-page .onx-outcome-card__body {
      font-size: var(--font-xs);
      color: var(--gray);
      line-height: 1.7;
    }

    /* ================================================================
       SECTION 7 — PLATFORM CALLOUT
    ================================================================ */
    .onx-ra-page .onx-platform {
      padding: 60px 0 0 0;
      background: var(--pure);
    }

    .onx-ra-page .onx-platform__inner {
      background: var(--gray-light);
      border: 1px solid var(--gray-light);
      border-radius: 20px;
      padding: 64px 60px;
      display: grid;
      grid-template-columns: 1fr auto;
      gap: 60px;
      align-items: center;
      position: relative;
      overflow: hidden;
    }

    .onx-ra-page .onx-platform__inner::before {
      content: '';
      position: absolute;
      right: -80px;
      top: -80px;
      width: 350px;
      height: 350px;
      border-radius: 50%;
      border: 1px solid rgba(232,92,45,0.2);
      pointer-events: none;
    }

    .onx-ra-page .onx-platform__eyebrow {
      color: var(--crimson);
      margin-bottom: 16px;
    }

    .onx-ra-page .onx-platform__title {
      color: var(--onyx-depth);
      margin-bottom: 18px;
    }

    .onx-ra-page .onx-platform__body {
      font-size: var(--font-xs);
      color: var(--gray);
      line-height: 1.8;
      max-width: 560px;
    }

    .onx-ra-page .onx-platform__action {
      flex-shrink: 0;
      display: flex;
      flex-direction: column;
      align-items: center;
      gap: 14px;
    }

    /* ================================================================
       SECTION 8 — CASE STUDY
    ================================================================ */
    .onx-ra-page .onx-casestudy {
      padding: 60px 0;
      background: var(--pure);
    }

    .onx-ra-page .onx-casestudy__inner {
      display: block;        /* remove 2-column layout */
      max-width: 1200px;
    }

    .onx-ra-page .onx-casestudy__eyebrow { margin-bottom: 16px; }
    .onx-ra-page .onx-casestudy__title { margin-bottom: 20px; }
    .onx-ra-page .onx-casestudy__body {
      font-size: var(--font-xs);
      color: var(--gray);
      line-height: 1.8;
      margin-bottom: 28px;
    }

    .onx-ra-page .onx-stats-grid {
      display: flex;
      gap: 40px;
      align-items: flex-start;
      margin-bottom: 30px;
    }

    .onx-ra-page .onx-stat {
      background: transparent;
      border: none;
      padding: 0;
      text-align: left;
      flex: 1;
      min-width: 0;
    }
    .onx-ra-page .onx-stat:first-child { border-radius: 0; }
    .onx-ra-page .onx-stat:last-child  { border-radius: 0; }

    .onx-ra-page .onx-stat__num {
     font-size: var(--font-md);
  font-weight: 600;
  color: var(--crimson);
  margin-bottom: 6px;
    }

    .onx-ra-page .onx-stat__label {
      font-size: var(--font-xs);
  color: var(--onyx-depth);
    }

    /* ================================================================
       SECTION 9 — FOOTER CTA
    ================================================================ */
    .onx-ra-page .onx-footer-cta {
      background: var(--onyx-depth);
      padding: 60px 0;
      text-align: center;
      position: relative;
      overflow: hidden;
    }

    .onx-ra-page .onx-footer-cta::before {
      content: '';
      position: absolute;
      inset: 0;
      background: radial-gradient(ellipse at center, rgba(254,54,25,0.08) 0%, transparent 65%);
      pointer-events: none;
    }

    .onx-ra-page .onx-footer-cta__eyebrow { margin-bottom: 18px; }

    .onx-ra-page .onx-footer-cta__title {
      color: var(--pure);
      margin-bottom: 20px;
      max-width: 1200px;
      margin-left: auto;
      margin-right: auto;
    }

    .onx-ra-page .onx-footer-cta__body {
      color: var(--gray-light);
      font-size: var(--font-xs);
      line-height: 1.75;
      max-width: 1200px;
      margin: 0 auto 40px;
    }

    .onx-ra-page .onx-footer-cta__actions {
      display: flex;
      justify-content: center;
      align-items: center;
      gap: 14px;
      flex-wrap: wrap;
    }

    /* ================================================================
       RESPONSIVE
    ================================================================ */
    @media (max-width: 1024px) {
      .onx-ra-page .onx-container { padding: 0 32px; }
      
      .onx-ra-page .onx-problem__inner,
      .onx-ra-page .onx-casestudy__inner {
        grid-template-columns: 1fr;
        gap: 40px;
      }
      
      .onx-ra-page .onx-cap-grid { grid-template-columns: 1fr; }
      .onx-ra-page .onx-outcome-grid { grid-template-columns: 1fr; }
    }

    @media (max-width: 900px) {
      .onx-ra-page .onx-container { padding: 0 24px; }

      .onx-ra-page .onx-nav__links { display: none; }
      .onx-ra-page .onx-nav__cta { padding: 8px 14px; font-size: var(--font-xs); }

      .onx-ra-page .onx-hero { padding: 70px 0 60px; }
      .onx-ra-page .onx-hero__actions { flex-direction: column; align-items: flex-start; }
      .onx-ra-page .onx-hero__actions .onx-btn { width: 100%; justify-content: center; }

      .onx-ra-page .onx-problem__inner,
      .onx-ra-page .onx-casestudy__inner {
        grid-template-columns: 1fr;
        gap: 30px;
      }

      .onx-ra-page .onx-cap-grid { grid-template-columns: 1fr; }
      .onx-ra-page .onx-cap-tile--span { grid-column: 1 / -1; }

      .onx-ra-page .onx-outcome-grid { grid-template-columns: 1fr; }

      .onx-ra-page .onx-platform__inner {
        grid-template-columns: 1fr;
        padding: 40px 32px;
        gap: 32px;
      }
      .onx-ra-page .onx-platform__action { align-items: flex-start; width: 100%; }
      .onx-ra-page .onx-platform__action .onx-btn { width: 100%; justify-content: center; }

      .onx-ra-page .onx-stats-grid { flex-direction: column; gap: 20px; }
      .onx-ra-page .onx-stat { border-radius: 0 !important; }
      .onx-ra-page .onx-stat:first-child { border-radius: 0 !important; }
      .onx-ra-page .onx-stat:last-child  { border-radius: 0 !important; }

      .onx-ra-page .onx-problem,
      .onx-ra-page .onx-approach,
      .onx-ra-page .onx-capabilities,
      .onx-ra-page .onx-outcomes,
      .onx-ra-page .onx-platform,
      .onx-ra-page .onx-casestudy,
      .onx-ra-page .onx-footer-cta { padding: 60px 0 0 0; }
    }

    @media (max-width: 560px) {
      .onx-ra-page .onx-container { padding: 0 16px; }
      
      .onx-ra-page .onx-h1 { font-size: var(--font-lg); line-height: 1.15; }
      .onx-ra-page .onx-h2 { font-size: var(--font-md); line-height: 1.2; }
      .onx-ra-page .onx-h3 { font-size: var(--font-xs); }
      
      .onx-ra-page .onx-hero { padding: 50px 0 40px; }
      .onx-ra-page .onx-hero__body { font-size: var(--font-xs); }
      
      .onx-ra-page .onx-cap-tile { padding: 24px 20px; }
      .onx-ra-page .onx-cap-tile__title { font-size: var(--font-sm); }
      
      .onx-ra-page .onx-outcome-card { padding: 24px 20px; }
      
      .onx-ra-page .onx-platform__inner { padding: 32px 20px; }
      
      .onx-ra-page .onx-stat { padding: 24px 20px; }
      .onx-ra-page .onx-stat__num { font-size: var(--font-md); }
      
      .onx-ra-page .onx-btn { padding: 12px 20px; font-size: var(--font-xs); width: 100%; justify-content: center; }
      
      .onx-ra-page .onx-footer-cta__actions { flex-direction: column; width: 100%; }
      .onx-ra-page .onx-footer-cta__actions .onx-btn { width: 100%; }
      
      .onx-ra-page .onx-problem,
      .onx-ra-page .onx-approach,
      .onx-ra-page .onx-capabilities,
      .onx-ra-page .onx-outcomes,
      .onx-ra-page .onx-platform,
      .onx-ra-page .onx-casestudy,
      .onx-ra-page .onx-footer-cta { padding: 60px 0 0 0; }
    }
    
    @media (max-width: 400px) {
      .onx-ra-page .onx-h1 { font-size: var(--font-md); }
      .onx-ra-page .onx-h2 { font-size: var(--font-sm); }
      .onx-ra-page .onx-nav__logo { font-size: var(--font-xs); }
      .onx-ra-page .onx-nav__logo-mark { width: 26px; height: 26px; }
    }
    /* ===== ROOT SCOPE ===== */
.onyx-simple-hero {
  width: 100%;
  font-family: 'Urbanist', sans-serif;
  background: var(--onyx-depth);
  color: var(--pure);
}

/* Breadcrumb */
.onyx-simple-hero .onyx-breadcrumb {
  font-size: var(--font-xs);
  color: var(--gray);
  margin-bottom: 20px;
}

/* Eyebrow */
.onyx-simple-hero .onyx-eyebrow {
  font-size: var(--font-xs);
  letter-spacing: 2px;
  color: var(--crimson);
  font-weight: 600;
  margin-bottom: 16px;
}
/* TITLE (THIS IS IMPORTANT PART) */
.onyx-simple-hero .onyx-title {
  font-size: var(--font-lg);
  line-height: 1.35;
  font-weight: 500;          /* NOT bold */
  margin-bottom: 20px;
  max-width: 900px;
  color: var(--pure);
}

/* DESCRIPTION */
.onyx-simple-hero .onyx-desc {
  font-size: var(--font-sm);
  line-height: 1.7;
  color: var(--gray-light);
  margin-bottom: 28px;
  max-width: 900px;
}

/* ACTIONS */
.onyx-simple-hero .onyx-actions {
  display: flex;
  gap: 30px;
  align-items: center;
}

/* LINKS */
.onyx-simple-hero .onyx-link-light {
  color: var(--gray-light);
  font-size: var(--font-xs);
  text-decoration: none;
  transition: color 0.2s ease, opacity 0.2s ease;
}

.onyx-simple-hero .onyx-link-light:hover {
  color: var(--pure);
  
}

.onyx-simple-hero .onyx-link-dark {
  color: var(--crimson);
  font-size: var(--font-xs);
  text-decoration: none;
  transition: text-decoration 0.2s ease;
}

.onyx-simple-hero .onyx-link-dark:hover {
  text-decoration: underline;
}
.onyx-hero-inner {
    width: 1200px;
    margin: auto;
    padding: 50px 0px;
}
/* Responsive styles for hero section */
@media (max-width: 1024px) {
  :root {
    --container-margin: 48px;
    --section-gap:      45px;
    --font-hero:        72px;
    --font-section:     45px;
    --font-card-lg:     46px;
    --font-card-md:     40px;
    --font-card-sm:     34px;
    --font-heading:     28px;
    --font-caption:     22px;
    --font-body:        18px;
    --font-badge:       16px;
    --padding-lg:       48px;
    --padding-md:       36px;
  }
  .onyx-simple-hero {
    padding-left: 80px;
  }
}

@media (max-width: 900px) {
  .onyx-simple-hero {
    padding: 100px 40px;
  }
  
  .onyx-simple-hero .onyx-title {
    font-size: var(--font-lg);
  }
  
  .onyx-simple-hero .onyx-desc {
    font-size: var(--font-sm);
  }
}

@media (max-width: 560px) {
  .onyx-simple-hero {
    padding: 80px 20px;
  }
  
  .onyx-simple-hero .onyx-title {
    font-size: var(--font-md);
    line-height: 1.25;
  }
  
  .onyx-simple-hero .onyx-desc {
    font-size: var(--font-xs);
  }
  
  .onyx-simple-hero .onyx-actions {
    flex-direction: column;
    align-items: flex-start;
    gap: 16px;
  }
  
  .onyx-simple-hero .onyx-breadcrumb {
    font-size: var(--font-xs);
  }
}

@media (max-width: 400px) {
  .onyx-simple-hero {
    padding: 80px 16px;
  }
  
  .onyx-simple-hero .onyx-title {
    font-size: var(--font-md);
  }
  
  .onyx-simple-hero .onyx-desc {
    font-size: var(--font-xs);
  }
}


/* test */



/* PARTNER */


/* ── FONT FACES ── */
@font-face {
  font-family: 'Urbanist';
  src: url('../fonts/Urbanist-VariableFont_wght.ttf') format('truetype');
  font-weight: 100 900;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'Urbanist';
  src: url('../fonts/Urbanist-Italic-VariableFont_wght.ttf') format('truetype');
  font-weight: 100 900;
  font-style: italic;
  font-display: swap;
}
@font-face {
  font-family: 'Outfit';
  src: url('../fonts/Outfit-Regular.ttf') format('truetype');
  font-weight: 100 900;
  font-style: normal;
  font-display: swap;
}


/* ─── TOKENS ─────────────────────────────────────────────────────────── */

/* ─── RESET ──────────────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; -webkit-font-smoothing: antialiased; }
body {
  font-family: var(--urbanist);
  background: var(--pure);
  color: var(--onyx-depth);
  font-size: var(--font-body);
  line-height: 1.7;
}
a { color: inherit; text-decoration: none; }
img { display: block; max-width: 100%; }

/* ─── UTILITIES ──────────────────────────────────────────────────────── */
.ptnr-page {
  overflow-x: hidden;
  font-family: var(--urbanist);
  color: var(--onyx-depth);
  background: var(--pure);
  margin: 0 15px;
}

.ptnr-container {
  width: 100%;
  max-width: 1512px;
  margin: 0 auto;
}
.ptnr-hero-inner {
  text-align: center;
}
.ptnr-eyebrow {
  /* display: inline-block;
  font-family: var(--urbanist);
  font-size: var(--font-caption);
  font-weight: 600;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--crimson);
  margin-bottom: var(--space-s); */
  font-family: var(--urbanist);
  font-size: var(--font-badge);
  color: var(--onyx-50);
  text-transform: uppercase;
  letter-spacing: 1px;
  margin-bottom: 15px;
  display: inline-block;
  padding: 8px 16px;
  border: 1px solid var(--onyx-25);
  border-radius: var(--radius-pill);
}
.ptnr-section-rule {
  width: 36px;
  height: 2px;
  background: var(--crimson);
  margin-bottom: var(--space-m);
  display: none;
}

/* ─── NAV placeholder ────────────────────────────────────────────────── */
.ptnr-nav {
  position: sticky;
  top: 0;
  z-index: 100;
  background: rgba(255,255,255,0.92);
  backdrop-filter: blur(14px);
  border-bottom: 1px solid var(--rule);
  padding: 0 var(--space-m);
  height: 60px;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.ptnr-nav-logo {
  font-family: var(--urbanist);
  font-weight: normal;
  font-size: var(--font-badge);
  letter-spacing: -0.02em;
  color: var(--onyx-depth);
}
.ptnr-nav-logo span { color: var(--crimson); }

/* ─── HERO ───────────────────────────────────────────────────────────── */
.ptnr-hero {
  padding: var(--padding-lg);
  background: var(--onyx-depth);
  position: relative;
  overflow: hidden;
  width: 100%;
  min-height: 952px;
  margin: auto;
  padding-top: 210px;
  border-radius: 0 0 var(--radius) var(--radius);
}
.ptnr-hero-inner {
  position: relative;
  max-width: 1200px;
}
.ptnr-hero .ptnr-eyebrow {
  color: var(--pure);
  font-size: var(--font-caption);
  font-family: var(--urbanist);
  line-height: 1;
  padding: 0;
  margin: 0;
  border: 0;
}
.ptnr-hero-headline {
  font-family: var(--urbanist);
  font-size: var(--font-card-md);
  font-weight: normal;
  line-height: 1.1;
  letter-spacing: -2px;
  color: var(--pure);
  margin: var(--padding-sm) 0;
  margin-top: 10px;
}
.ptnr-hero-subhead {
  font-family: var(--outfit);
  font-size: var(--font-body);
  font-weight: normal;
  color: var(--pure-60);
  max-width: 100%;
  width: 100%;
  line-height: 1.7;
}

/* ─── SECTION SHARED ─────────────────────────────────────────────────── */
.ptnr-section {
  padding: var(--section-gap);
}
.ptnr-section:first-of-type { border-top: none; }
.ptnr-section-header {
  margin-bottom: 30px;
  max-width: 100%;
  width: 100%;
}
.ptnr-section-title {
  font-family: var(--urbanist);
  font-size: var(--font-card-sm);
  letter-spacing: -1.5px;
  color: var(--onyx-depth);
  margin-bottom: 24px;
  line-height: 1.15;
  font-weight: normal;
}
.ptnr-section-intro {
  font-family: var(--outfit);
  font-size: var(--font-body);
  color: var(--onyx-50);
  line-height: 1.7;
  margin-top: 0;
}

/* ─── LOGO GRID ──────────────────────────────────────────────────────── */
.ptnr-logo-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 30px;
  margin-bottom: var(--space-l);
}

.ptnr-logo-grid--5col {
  grid-template-columns: repeat(5, 1fr);
}

/* CARD */
.ptnr-logo-card {
  position: relative;
  text-align: center;
  cursor: pointer;
  flex: 0 0 calc(33.333% - 20px);
}
section#implementation-integration,
section#reseller-consulting {
  padding-top: 0;
}

/* LOGO BOX (placeholder for actual logo image) */
.logo-box {
  height: 90px;
  padding: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--pure);
  overflow: hidden;
}

.logo-box img {
  max-width: 150px;
  max-height: 100%;
  object-fit: contain;
}

/* NAME BELOW */
.logo-name {
  margin-top: 10px;
  font-family: var(--urbanist);
  font-size: var(--font-badge);
  font-weight: normal;
  color: var(--onyx-depth);
  display: none;
}

/* HOVER TEXT */
.logo-hover {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 120px;
  background: var(--onyx-depth);
  color: var(--pure);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 15px;
  font-family: var(--urbanist);
  font-size: var(--font-sixteen);
  line-height: 1.5;
  text-align: center;
  border-radius: var(--radius);
  opacity: 0;
  transform: translateY(10px);
  transition: all 0.25s ease;
  pointer-events: none;
}

/* HOVER EFFECT */
.ptnr-logo-card:hover .logo-hover {
  opacity: 1;
  transform: translateY(0);
  background: #1d1d1d;
  color: var(--pure-60);
  top: -10%;
}

.ptnr-logo-card:hover .logo-box {
  border-color: var(--crimson);
  box-shadow: 0 0 0 3px var(--accent-glow);
}

/* Legacy logo chip styles for other sections */
.ptnr-logo-chip {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0.75rem 1.4rem;
  background: var(--pure);
  border: 1px solid var(--gray-light);
  border-radius: var(--radius-m);
  font-size: var(--font-xs);
  font-weight: normal;
  color: var(--onyx-depth);
  letter-spacing: 0.01em;
  cursor: default;
  transition: border-color 0.2s, box-shadow 0.2s, transform 0.2s var(--ease-out);
  overflow: hidden;
}
.ptnr-logo-chip::after {
  content: attr(data-oneliner);
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0.5rem 0.9rem;
  background: var(--onyx-depth);
  color: var(--pure);
  font-size: var(--font-xs);
  font-weight: normal;
  line-height: 1.4;
  text-align: center;
  opacity: 0;
  transform: translateY(4px);
  transition: opacity 0.22s, transform 0.22s var(--ease-out);
}
.ptnr-logo-chip:hover {
  border-color: var(--crimson);
  box-shadow: 0 0 0 3px var(--accent-glow);
  transform: translateY(-1px);
}
.ptnr-logo-chip:hover::after {
  opacity: 1;
  transform: translateY(0);
}
/* Featured / large chips for Technology section */
.ptnr-logo-chip--featured {
  background: linear-gradient(135deg, rgba(254,54,25,0.05) 0%, var(--pure) 100%);
  border-color: var(--accent-border);
  color: var(--crimson);
  font-weight: normal;
}

/* ─── PULL QUOTE ─────────────────────────────────────────────────────── */
.ptnr-pull-quote {
  margin-top: 40px !important;
  padding: var(--padding-sm);
  border-left: 4px solid var(--crimson);
  background: linear-gradient(105deg, var(--onyx-50) -40%, transparent 100%);
  position: relative;
  border-radius: 0 var(--radius) var(--radius) 0;
}
/* .ptnr-pull-quote::before {
  content: '\201C';
  position: absolute;
  top: -0.2em;
  left: var(--space-m);
  font-family: var(--urbanist);
  font-size: var(--font-card-lg);
  color: var(--crimson);
  opacity: 0.15;
  line-height: 1;
  pointer-events: none;
} */
.ptnr-pull-quote-text {
  font-family: var(--outfit);
  font-style: italic;
  font-size: var(--font-body);
  color: var(--onyx-50);
  line-height: 1.4;
  margin-bottom: var(--space-s);
}
.ptnr-pull-quote-attr {
  font-family: var(--urbanist);
  font-size: var(--font-badge);
  color: var(--crimson);
  letter-spacing: 0.04em;
  text-transform: capitalize;
}

/* ─── TECH SECTION OVERRIDES ─────────────────────────────────────────── */
.ptnr-section--tech {
  /* background: var(--onyx-depth); */
  color: var(--pure);
  border-radius: var(--radius);
  padding-top: 0;
}
.ptnr-section--tech .ptnr-section-title {
  /* color: var(--pure); */
  color: var(--onyx-depth);
}
.ptnr-section--tech .ptnr-section-intro {
  color: var(--onyx-50);
}
.ptnr-section--tech .ptnr-section-rule { background: var(--crimson); }
.ptnr-section--tech .ptnr-logo-chip {
  background: rgba(255,255,255,0.05);
  border-color: rgba(255,255,255,0.12);
  color: rgba(255,255,255,0.85);
}
.ptnr-section--tech .ptnr-logo-chip:hover {
  border-color: var(--crimson);
  box-shadow: 0 0 0 3px var(--accent-glow);
}
.ptnr-section--tech .ptnr-pull-quote {
  border-left-color: var(--crimson);
  background: linear-gradient(105deg, var(--onyx-25) -50%, transparent 100%);
}
.ptnr-section--tech .ptnr-pull-quote-text {
  color: var(--onyx-50);
}
.ptnr-section--tech .ptnr-pull-quote-attr { color: var(--crimson); }
.ptnr-section--tech .ptnr-eyebrow {
  color: var(--onyx-50);
  border: 1px solid var(--onyx-50);
 }

/* ─── SPOTLIGHT GALLERY ──────────────────────────────────────────────── */
.ptnr-spotlight {
  padding: var(--section-gap);
  background: #f5f5f5;
  overflow: hidden;
  border-radius: var(--radius);
}
.ptnr-spotlight-header {
  padding: 0 var(--space-m);
  max-width: 1160px;
  margin: 0 auto var(--space-l);
}
.ptnr-spotlight-header .ptnr-section-title { color: var(--pure); }
.ptnr-spotlight-header .ptnr-eyebrow {
  color: var(--onyx-depth);
  border: 1px solid var(--onyx-50);
}
.ptnr-spotlight-header .ptnr-section-title {
  color: var(--onyx-depth) !important;
}
.ptnr-spotlight-header .ptnr-section-rule { background: var(--crimson); }

.ptnr-cards-track-wrap {
  padding: 0 var(--space-m);
  max-width: 1160px;
  margin: 0 auto;
  position: relative;
}
.ptnr-cards-track {
  display: flex;
  gap: var(--space-m);
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
  padding-bottom: var(--space-m);
  scrollbar-width: thin;
  scrollbar-color: var(--crimson) rgba(255,255,255,0.08);
}
.ptnr-cards-track::-webkit-scrollbar { height: 3px; }
.ptnr-cards-track::-webkit-scrollbar-track { background: rgba(255,255,255,0.05); border-radius: 2px; }
.ptnr-cards-track::-webkit-scrollbar-thumb { background: var(--crimson); border-radius: 2px; }

.ptnr-card {
  flex: 0 0 calc(33.333% - var(--space-m) * 2 / 3);
  min-width: 300px;
  scroll-snap-align: start;
  background: var(--pub-bg);
  border: 2px solid var(--pure-40);
  border-radius: var(--radius);
  padding: var(--padding-md);
  display: flex;
  flex-direction: column;
  gap: var(--space-s);
  transition: border-color 0.2s, transform 0.25s var(--ease-out);
}
.ptnr-card:hover {
  border-color: var(--accent-border);
  transform: translateY(-3px);
}
.ptnr-card-tag {
  display: inline-block;
  font-family: var(--urbanist);
  font-size: var(--font-badge);
  font-weight: normal;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--crimson);
  background: var(--accent-glow);
  padding: 0.25em 0.7em;
  border-radius: var(--radius-pill);
  align-self: flex-start;
}
.ptnr-card-partner {
  font-family: var(--urbanist);
  font-weight: normal;
  font-size: var(--font-heading);
  color: var(--pure);
  letter-spacing: -0.5px;
}
.ptnr-card-body {
  font-family: var(--urbanist);
  font-size: var(--font-body);
  color: var(--pure-60);
  line-height: 1.7;
  flex: 1;
}
.ptnr-card-quote {
  font-family: var(--urbanist);
  font-style: italic;
  font-size: var(--font-body);
  color: var(--pure-60);
  line-height: 1.65;
  border-top: 2px solid var(--pure-40);
  padding-top: var(--space-s);
  margin-top: auto;
}
.ptnr-card-quote-attr {
  font-family: var(--urbanist);
  font-style: normal;
  font-size: var(--font-badge);
  font-weight: normal;
  color: var(--pure-40);
  margin-top: 0.4rem;
  letter-spacing: 0.03em;
}
.ptnr-card-cta {
  display: inline-flex;
  align-items: center;
  gap: 0.3em;
  font-family: var(--urbanist);
  font-size: var(--font-badge);
  font-weight: normal;
  color: var(--crimson);
  margin-top: 0.25rem;
  transition: gap 0.15s;
}
.ptnr-card-cta:hover { gap: 0.5em; }
.ptnr-card-cta::after { content: '→'; }

/* dot indicators */
.ptnr-dots {
  display: flex;
  gap: 6px;
  justify-content: center;
  margin-top: var(--space-m);
}
.ptnr-dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: rgba(255,255,255,0.15);
  cursor: pointer;
  transition: background 0.2s, transform 0.2s;
}
.ptnr-dot.is-active {
  background: var(--crimson);
  transform: scale(1.3);
}

/* ─── BECOME A PARTNER ───────────────────────────────────────────────── */
.ptnr-become {
  padding: var(--section-gap);
  background: var(--pure);
  display: none;
}
.ptnr-become-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 60px;
  align-items: start;
}
.ptnr-become-headline {
  font-family: var(--urbanist);
  font-size: var(--font-card-sm);
  font-weight: normal;
  letter-spacing: -1.5px;
  line-height: 1.15;
  color: var(--onyx-depth);
  margin-bottom: 24px;
}
.ptnr-become-body {
  font-family: var(--urbanist);
  font-size: var(--font-body);
  color: var(--onyx-50);
  line-height: 1.7;
  margin-bottom: 40px;
}
.ptnr-reasons {
  margin-top: var(--padding-md);
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 20px;
}
.ptnr-reasons li {
  display: flex;
  gap: 0.75rem;
  font-family: var(--urbanist);
  font-size: var(--font-body);
  color: var(--onyx-50);
  line-height: 1.7;
}
.ptnr-reasons li::before {
  content: '';
  flex-shrink: 0;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--crimson);
  margin-top: 15px;
}

.ptnr-become-cta-wrap {
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: var(--padding-lg);
  background: var(--onyx-depth);
  border-radius: var(--radius);
  border: 2px solid var(--pure-40);
}
.ptnr-become-cta-wrap a {
  text-align: center;
  padding: var(--padding-sm) 0;
}
.ptnr-become-cta-label {
  font-family: var(--urbanist);
  font-size: var(--font-body);
  font-style: italic;
  color: var(--pure-60);
  margin-bottom: var(--space-m);
  line-height: 1.5;
}
.ptnr-note {
  font-family: var(--urbanist);
  font-size: var(--font-badge);
  color: var(--pure-40);
  line-height: 1.6;
  margin-top: var(--space-s);
  font-style: italic;
}

/* ─── BUTTONS ────────────────────────────────────────────────────────── */
.ptnr-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.4em;
  font-family: var(--urbanist);
  font-size: var(--font-badge);
  font-weight: normal;
  padding: 14px 28px;
  border-radius: var(--radius-pill);
  cursor: pointer;
  transition: all 0.2s var(--ease-out);
  border: none;
  text-decoration: none;
}
.ptnr-btn--primary {
  background: var(--crimson);
  color: var(--pure);
}
.ptnr-btn--primary:hover {
  background: var(--crimson);
  transform: translateY(-1px);
  box-shadow: 0 6px 24px var(--accent-glow);
}
.ptnr-btn--ghost {
  background: transparent;
  color: var(--pure);
  border: 2px solid var(--pure-40);
}
.ptnr-btn--ghost:hover {
  border-color: var(--pure);
  background: rgba(255,255,255,0.05);
}

/* ─── BOTTOM CTA ─────────────────────────────────────────────────────── */
.ptnr-bottom-cta {
  padding: var(--section-gap);
  background: var(--onyx-depth);
  text-align: center;
  position: relative;
  overflow: hidden;
  border-radius: var(--radius);
}

.ptnr-bottom-cta-headline {
  font-family: var(--urbanist);
  font-size: var(--font-section);
  font-weight: normal;
  color: var(--pure);
  letter-spacing: -1.5px;
  line-height: 1.15;
  margin-bottom: 50px;
  position: relative;
}
.ptnr-bottom-cta-btns {
  display: flex;
  gap: var(--space-s);
  justify-content: center;
  flex-wrap: wrap;
  position: relative;
}
.ptnr-bottom-cta .ptnr-container {
  margin-bottom: 150px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 80px;
  align-items: flex-start;
  justify-content: flex-start;
  position: relative;
  z-index: 2;
  padding-bottom: 150px;
  max-width: 1512px;
  width: 100%;
  margin: auto;
}
.ptnr-bottom-cta .ptnr-container p {
  font-family: var(--outfit);
  font-size: var(--font-body);
  font-weight: 400;
  color: var(--pure-60);
  line-height: 1.65;
  margin-bottom: 28px;
  text-align: left;
}

.ptnr-bottom-cta .ptnr-bottom-cta-btns.ptnr-reveal.is-visible {
  gap: 20px;
}

.ptnr-cta-watermark {
  position: absolute;
  bottom: -20px;
  left: 0;
  right: 0;
  z-index: 1;
  font-family: var(--urbanist);
  font-size: 24vw;
  color: rgba(255, 255, 255, 0.05);
  line-height: 0.85;
  letter-spacing: -4px;
  user-select: none;
  pointer-events: none;
  white-space: nowrap;
  overflow: visible;
  text-align: center;
  width: 100%;
  font-weight: 800 !important;
  margin: auto;
}

/* ─── FADE-IN ON SCROLL ──────────────────────────────────────────────── */
.ptnr-reveal {
  opacity: 0;
  transform: translateY(22px);
  transition: opacity 0.65s var(--ease-out), transform 0.65s var(--ease-out);
}
.ptnr__related-articles .blog-detail-slider .swiper-slide::before {
  content: none;
}
.ptnr__related-articles .blog-detail-slider .swiper-slide:hover p.card-title {
  color: var(--onyx-depth);
}
.ptnr__related-articles .blog-detail-slider .swiper-slide:hover p.card-content {
  color: var(--onyx-50);
}
.ptnr-reveal.is-visible {
  opacity: 1;
  transform: none;
  font-size: var(--font-card-md);
  font-weight: normal;
  max-width: 1512px;
  width: 100%;
}
.ptnr-logo-grid.ptnr-reveal.ptnr-reveal-delay-1.is-visible {
  display: flex;
  flex-wrap: wrap;
  gap: 30px;
  justify-content: center;
}
.ptnr-reveal-delay-1 { transition-delay: 0.1s; }
.ptnr-reveal-delay-2 { transition-delay: 0.2s; }
.ptnr-reveal-delay-3 { transition-delay: 0.3s; }

/* ptnr slider */
section.ptnr__related-articles {
  padding: 0;
  max-width: 1512px;
  width: 100%;
  margin: auto;
}
.ptnr__related-articles .top-bar {
  display: flex;
  justify-content: space-between;
  align-items: self-end;
  margin-bottom: 40px;
  justify-content: flex-end;
}
.ptnr__related-articles .nav-btn:hover {
  background: var(--onyx-depth);
  color: var(--pure);
  border-color: var(--onyx-depth);
}
.ptnr__related-articles .top-bar h2 {
  font-family: var(--urbanist);
  font-size: var(--font-section);
  color: var(--onyx-depth);
  line-height: 1.1;
  letter-spacing: -1.5px;
  
}
.ptnr__related-articles .nav-btn svg,
.related-articles .nav-btn svg {
  width: 20px;
  height: 20px;
  stroke: var(--onyx-50);
  fill: none;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
  transition: stroke 0.25s ease;
}
.ptnr__related-articles .nav-btn:hover svg,
.related-articles .nav-btn:hover svg {
  stroke: var(--pure);
}
.ptnr__related-articles .nav-btn {
  width: 40px;
  height: 40px;
  border: 1px solid var(--onyx-25);
  background: var(--pure);
  border-radius: 100%;
  cursor: pointer;
  font-size: 20px;
  color: var(--onyx-depth);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.3s ease;
  font-weight: bold;
}
.ptnr__related-articles .nav {
  display: flex;
  gap: 12px;
  justify-content: flex-end;
  align-items: flex-end;
  margin: initial;
  position: relative;
  right: 50px;
}
.ptnr__related-articles .blog-detail-slider {
  overflow: hidden;
  width: 100%;
  position: relative;
}
.ptnr__related-articles .blog-detail-slider .track {
  display: flex;
  gap: 24px;
  transition: transform 0.5s ease-in-out;
  will-change: transform;
  padding: 0;
  margin: 0;
  background: var(--onyx-depth);
}
.ptnr__related-articles .blog-card {
  border: 1px solid var(--onyx-25);
  border-radius: var(--radius);
  padding: var(--padding-sm);
  display: flex;
  flex-direction: column;
  min-height: 180px;
  gap: 30px;
  position: relative;
  overflow: hidden;
  cursor: pointer;
  background: #fff;
}
.ptnr__related-articles .blog-detail-slider .blog-card {
  flex: 0 0 calc(50% - 12px);
  min-width: calc(50% - 12px);
}
.ptnr__related-articles .blog-card::before {
  content: '';
  position: absolute;
  inset: 0;
  background: var(--onyx-depth);
  transform: translateY(-100%);
  transition: transform 300ms ease-out;
  border-radius: inherit;
  z-index: 0;
}
.ptnr__related-articles .blog-card > * {
  position: relative;
  z-index: 1;
}
.ptnr__related-articles .blog-card:hover::before { transform: translateY(0); }
.ptnr__related-articles .blog-card:hover p.card-title {
  color: var(--pure);
  transition: color 300ms ease-out;
}
.ptnr__related-articles .blog-card:hover p.card-content {
  color: var(--pure-60);
  transition: color 300ms ease-out;
}
.ptnr__related-articles .blog-card p.card-title {
  font-size: var(--font-heading);
  min-height: 100px;
}
.ptnr__related-articles .blog-card p.card-content {
  font-size: var(--font-eighteen);
  color: var(--onyx-50);
}

.ptnr__related-articles p.card-content {
  font-size: var(--font-eighteen) !important;
  color: var(--onyx-50);
}



/* ptnr slider */
/* ─── RESPONSIVE ─────────────────────────────────────────────────────── */
@media (max-width: 1024px) {
  .ptnr-hero {
    min-height: 800px;
  }
}
@media (max-width: 900px) {
  .ptnr-become-grid {
    grid-template-columns: 1fr;
  }
  .ptnr-logo-grid {
    grid-template-columns: repeat(2, 1fr);
  }
  .ptnr-logo-grid--5col {
    grid-template-columns: repeat(2, 1fr);
  }
  .ptnr-become-grid {
    gap: 10px;
  }
}



/* CONTACT */

 /* CONTACT US */

* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
  font-family: 'Urbanist', sans-serif;
}

body {
  color: var(--onyx-depth);
}

.contact-container {
  width: 90%;
  max-width: 1200px;
  margin: auto;
}

.contact-center {
  text-align: center;
}

/* HERO */
.hero-contact {
  position: relative;
  padding: 100px 20px;
  background: #ffffff;
  overflow: hidden;
  text-align: center;
}

/* BACKGROUND GRAPHICS */
.hero-contact::before,
.hero-contact::after {
  content: "";
  position: absolute;
  border-radius: 50%;
  pointer-events: none;
}

/* LEFT CIRCLE */
.hero-contact::before {
  width: 500px;
  height: 500px;
  left: -200px;
  top: -100px;
  border: 1px solid rgba(254, 54, 25, 0.15);
}

/* RIGHT CIRCLE */
.hero-contact::after {
  width: 400px;
  height: 400px;
  right: -150px;
  top: -50px;
  border: 1px solid rgba(254, 54, 25, 0.15);
}

/* INNER CONTAINER */
.contact-hero-inner {
  max-width: 700px;
  margin: auto;
  position: relative;
  z-index: 2;
}

/* EYEBROW */
.contact-hero-eyebrow {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  margin-bottom: 15px;
  padding-top: 10%;
}

.contact-hero-eyebrow span {
  width: 35px;
  height: 1px;
  background: rgba(254, 54, 25, 0.5);
}

.contact-hero-eyebrow p {
  font-size: var(--font-xs);
  letter-spacing: 3px;
  color: var(--crimson);
}

/* TITLE */
.contact-hero-title {
  font-size: var(--font-lg);
  font-weight: 500;
  margin-bottom: 15px;
  color: var(--onyx-depth);
}

.contact-hero-title span {
  color: var(--crimson);
}

/* TEXT */
.contact-hero-subtext {
  font-size: var(--font-xs);
  color: var(--gray);
  line-height: 1.6;
  margin-bottom: 25px;
}

/* BUTTON */
.contact-hero-btn {
  background: var(--crimson);
  color: var(--pure);
  border: none;
  padding: 14px 26px;
  border-radius: 30px;
  font-size: var(--font-xs);
  display: inline-flex;
  align-items: center;
  gap: 10px;
  cursor: pointer;
  transition: 0.3s;
}

/* ARROW CIRCLE */
.contact-hero-btn .contact-arrow {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(255,255,255,0.2);
  width: 26px;
  height: 26px;
  border-radius: 50%;
}

/* HOVER */
.contact-hero-btn:hover {
  background: var(--crimson);
  opacity: 0.9;
}

/* BUTTON */
.contact-contact-btn-primary {
  background: var(--crimson);
  color: var(--pure);
  border: none;
  padding: 14px 28px;
  border-radius: 30px;
  margin-top: 20px;
  cursor: pointer;
}

.contact-full {
  width: 100%;
}

/* CONTACT SECTION */
.contact-section {
  padding: 60px 0;
}

.contact-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 50px;
}

.contact-left h2 {
  font-size: var(--font-md);
  margin: 10px 0;
}

.contact-left p {
  color: var(--gray);
  margin-bottom: 20px;
}

.contact-eyebrow {
  font-size: var(--font-xs);
  letter-spacing: 2px;
  color: var(--crimson);
}

.contact-info div {
  margin-bottom: 20px;
}

/* CONTACT INFO WITH ICONS */
.contact-info {
  margin-top: 25px;
}

.contact-info-item {
  display: flex;
  align-items: flex-start;
  gap: 15px;
  margin-bottom: 25px;
}

/* ICON STYLE */
.contact-icon {
  width: 42px;
  height: 42px;
  min-width: 42px;
  border-radius: 50%;
  background: rgba(254, 54, 25, 0.08);
  border: 1px solid rgba(254, 54, 25, 0.3);
  display: flex;
  align-items: center;
  justify-content: center;
}

.contact-icon svg {
  width: 18px;
  height: 18px;
}

/* TEXT */
.contact-info-item span {
  display: block;
  font-weight: 600;
  font-size: var(--font-badge);
  margin-bottom: 4px;
}

.contact-info-item p {
  color: var(--gray);
  font-size: var(--font-badge);
  line-height: 1.6;
}

/* FORM */
.contact-contact-form-card {
  background: var(--pure);
  padding: 30px;
  border-radius: 15px;
  box-shadow: 0 10px 30px rgba(0,0,0,0.05);
}

.contact-form-card h3 {
  margin: 10px 0;
}

.contact-small {
  color: var(--gray);
  font-size: var(--font-xs);
  margin-bottom: 20px;
}

.contact-form-card form input,
.contact-form-card form select,
.contact-form-card form textarea {
  width: 100%;
  padding: 12px;
  margin-bottom: 15px;
  border-radius: 8px;
  border: 1px solid var(--gray-light);
}

.contact-row {
  display: flex;
  gap: 15px;
}

.contact-form-card textarea {
  height: 120px;
}

.contact-contact-checkbox {
  display: flex;
  gap: 10px;
  font-size: var(--font-xs);
  margin-bottom: 15px;
}

.contact-captcha {
  background: #e6f0ff;
  padding: 15px;
  border-radius: 8px;
  margin-bottom: 15px;
  font-size: var(--font-xs);
}

/* CTA */
.contact-cta-dark {
  background: var(--onyx-depth);
  position: relative;
  padding: 100px 20px;
  overflow: hidden;
}

/* Background circular patterns */
.contact-cta-dark::before,
.contact-cta-dark::after {
  content: "";
  position: absolute;
  width: 600px;
  height: 600px;
  border: 1px solid rgba(254, 54, 25, 0.15);
  border-radius: 50%;
}

.contact-cta-dark::before {
  top: -200px;
  left: -200px;
}

.contact-cta-dark::after {
  bottom: -200px;
  right: -200px;
}

/* Container */
.contact-cta-container {
  max-width: 800px;
  margin: auto;
  text-align: center;
  color: var(--pure);
  position: relative;
  z-index: 2;
}

/* Eyebrow */
.contact-cta-eyebrow {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 15px;
  margin-bottom: 20px;
}

.contact-cta-eyebrow span {
  width: 40px;
  height: 1px;
  background: rgba(254, 54, 25, 0.5);
}

.contact-cta-eyebrow p {
  font-size: var(--font-xs);
  letter-spacing: 3px;
  color: var(--crimson);
}

/* Heading */
.contact-cta-heading {
  font-size: var(--font-lg);
  font-weight: 500;
  line-height: 1.3;
  margin-bottom: 20px;
}

.contact-cta-heading span {
  color: var(--crimson);
}

/* Description */
.contact-cta-desc {
  font-size: var(--font-xs);
  color: var(--gray);
  max-width: 600px;
  margin: auto;
  margin-bottom: 35px;
  line-height: 1.6;
}

/* Button */
.contact-cta-btn {
  background: var(--crimson);
  color: var(--pure);
  border: none;
  padding: 14px 30px;
  border-radius: 30px;
  font-size: var(--font-xs);
  cursor: pointer;
  transition: 0.3s;
}

.contact-cta-btn:hover {
  background: var(--crimson);
  opacity: 0.9;
}

/* Responsive */
@media (max-width: 768px) {
  :root {
    --container-margin: 20px;
    --section-gap:      30px;
    --font-hero:        48px;
    --font-section:     38px;
    --font-card-lg:     36px;
    --font-card-md:     32px;
    --font-card-sm:     28px;
    --font-heading:     24px;
    --font-caption:     20px;
    --font-body:        16px;
    --font-badge:       14px;
    --padding-lg:       28px;
    --padding-md:       24px;
    --padding-sm:       18px;
  }
  .contact-hero-title {
    font-size: var(--font-md);
  }

  .hero-contact::before {
    width: 300px;
    height: 300px;
  }

  .hero-contact::after {
    width: 250px;
    height: 250px;
  }

  .contact-cta-heading {
    font-size: var(--font-md);
  }

  .contact-cta-dark::before,
  .contact-cta-dark::after {
    width: 400px;
    height: 400px;
  }
  .ptnr-cta-watermark {
    bottom: 0px;
  }
}

/* RESPONSIVE */
@media (max-width: 900px) {
  .contact-grid {
    grid-template-columns: 1fr;
  }

  .contact-row {
    flex-direction: column;
  }

  .contact-hero-title {
    font-size: var(--font-md);
  }
}

/* Partners Page specific styles */
.blg-grd-col-item-img-wrp {
    padding-bottom: 20px;
}



/* breadcrumb */

.platform-breadcrumb {
  padding-bottom: 20px;
  font-family: var(--outfit);
  font-size: 14px;
  font-weight: 400;
  color: var(--pure-40);
  display: flex;
  gap: 8px;
}

.platform-breadcrumb a:hover {
  color: var(--pure);
}

.hero-breadcrumb {
  padding: 0 var(--padding-lg);
  font-family: var(--urbanist);
  font-size: 14px !important;
  font-weight: 500;
  color: var(--pure-60);
  letter-spacing: 1.5px;
  text-transform: uppercase;
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  justify-content: flex-start;
  position: absolute;
  bottom: 30px;
  left: 0;
  right: 0;
  z-index: 2;
  max-width: 1512px;
  margin: 0 auto;
}

.hero-breadcrumb span {
  margin: 0 6px;
  color: var(--pure-40);
}

.hero-breadcrumb .sep {
  margin: 0 6px;
  color: var(--pure-40);
}

.hero-breadcrumb a {
  color: var(--pure-60);
}
.hero-breadcrumb a:hover {
    color: var(--pure);
}


@media (max-width: 768px) {
  .hero-breadcrumb {
    bottom: 10px;
    left: 0;
    padding: 0 15px;
  }
  .blog-list .blog-section {
    padding: var(--padding-sm) 0;
  }
  .search-results .blog-list .hero {
    height: 500px;
  }
  .ptnr__related-articles .blog-detail-slider .blog-card {
    flex: 0 0 100%;
    min-width: 100%;
  }
  :root {
    --section-gap: 30px;
    --container-margin: 40px;
    --font-hero: 60px;
    --font-section: 32px;
  }
  .ptnr-container {
    padding-left: 40px;
    padding-right: 40px;
  }
  .ptnr-hero { padding: 60px 0;min-height: 580px; }
  .ptnr-pull-quote { padding: var(--padding-sm); }
  .ptnr-card {
    min-width: 280px;
    flex-basis: 85vw;
  }
  .ptnr-section,
  .ptnr-container {
    padding: var(--padding-sm) 0;
  }
  .ptnr-hero .ptnr-container {
    padding: var(--padding-sm);
    padding-top: 100px;
  }
  .ptnr-bottom-cta .ptnr-container {
    padding-bottom: 70px;
    gap: 20px;
    grid-template-columns: 1fr;
  }
  .ptnr-bottom-cta .ptnr-container h2 {
    text-align: left;
    margin-bottom: 0;
  }
  .blog-list .hero {
      background: var(--onyx-depth);
      width: 100%;
      min-height: 340px;
      border-radius: 0 0 var(--radius) var(--radius);
      padding: var(--padding-lg);
  }
}
@media (max-width: 500px) {
  .ptnr-logo-grid {
    grid-template-columns: 1fr;
  }
}

.hsfc-NavigationRow__Alerts {
  display: none;
}
 