/* font */
@font-face {
    font-family: 'cerebri-sans-regular';
    src: url('fonts/CerebriSans-Regular.woff2') format('woff2'),
        url('fonts/CerebriSans-Regular.woff') format('woff');
    font-weight: normal;
    font-style: normal;
}

@font-face {
    font-family: 'cerebri-sans-medium';
    src: url('fonts/CerebriSans-Medium.woff2') format('woff2'),
        url('fonts/CerebriSans-Medium.woff') format('woff');
    font-weight: normal;
    font-style: normal;

}

@font-face {
    font-family: 'cerebri-sans-semibold';
    src: url('fonts/CerebriSans-SemiBold.woff2') format('woff2'),
        url('fonts/CerebriSans-SemiBold.woff') format('woff');
    font-weight: normal;
    font-style: normal;

}

@font-face {
    font-family: 'cerebri-sans-bold';
    src: url('fonts/CerebriSans-Bold.woff2') format('woff2'),
        url('fonts/CerebriSans-Bold.woff') format('woff');
    font-weight: normal;
    font-style: normal;

}

@font-face {
    font-family: 'cerebri-sans-light';
    src: url('fonts/CerebriSans-Light.woff2') format('woff2'),
        url('fonts/CerebriSans-Light.woff') format('woff');
    font-weight: normal;
    font-style: normal;

}

/* variable */
:root {
    --alt-font: 'cerebri-sans-regular';
    --primary-font: 'cerebri-sans-regular';
    --base-color: #3aa6e0;
    --dark-gray: #1F2937;
    --very-light-gray: #F9FAFB;
    --yellow: #3aa6e0;
    --medium-gray: #7c898d;
    --solitude-blue: #F9FAFB;
    --accent-mint: #dceefb;
}

/* reset */
body {
    font-size: 18px;
    line-height: 30px;
}

/* font weight */
.fw-400 {
    font-family: 'cerebri-sans-regular' !important;
    font-weight: normal !important;
}

.fw-300 {
    font-family: 'cerebri-sans-light' !important;
    font-weight: normal !important;
}

.fw-500 {
    font-family: 'cerebri-sans-medium' !important;
    font-weight: normal !important;
}

.fw-600 {
    font-family: 'cerebri-sans-semibold' !important;
    font-weight: normal !important;
}

.fw-700 {
    font-family: 'cerebri-sans-bold' !important;
    font-weight: normal !important;
}

/* custom cursor */
.custom-cursor .circle-cursor-inner {
    background-color: var(--yellow);
}

.custom-cursor .circle-cursor-inner.cursor-link-hover {
    background-color: var(--yellow);
}

.custom-cursor .circle-cursor-outer {
    border: 1px solid var(--yellow);
}

/* heading */
.h1,
.h2,
.h3,
.h4,
.h5,
.h6,
h1,
h2,
h3,
h4,
h5,
h6 {
    margin-bottom: 25px;
}

h1 {
    line-height: 4.375rem;
}

h2 {
    line-height: 3.438rem;
}

h3 {
    line-height: 3rem;
}

h4 {
    line-height: 2.6rem;
}

h5 {
    line-height: 2rem;
}

h6 {
    line-height: 1.75rem;
}

/* header */
.navbar .navbar-nav .nav-link {
    font-size: 18px;
    font-family: 'cerebri-sans-medium' !important;
}

.navbar .navbar-nav .dropdown .dropdown-menu a {
    font-size: 16px;
    line-height: 28px;
    font-family: 'cerebri-sans-regular' !important;
}

header .btn.btn-small {
    font-size: 14px
}

header .btn.btn-small i {
    top: -2px;
}

header .navbar-brand img {
    max-height: 36px;
}

.navbar .navbar-nav .dropdown.dropdown-with-icon-style02 .dropdown-menu {
    width: 300px;
}

.navbar .navbar-nav .dropdown.dropdown-with-icon-style02 .dropdown-menu li a {
    border-bottom: 1px solid var(--very-light-gray);
    padding: 20px 30px;
    font-size: 17px;
    color: var(--dark-gray) !important;
    font-family: 'cerebri-sans-medium' !important;
}

.navbar .navbar-nav .dropdown.dropdown-with-icon-style02 .dropdown-menu li a:hover {
    background-color: var(--very-light-gray);
}

.navbar .navbar-nav .dropdown.dropdown-with-icon-style02 .dropdown-menu li a img {
    width: 40px;
    margin-right: 10px;
}

/* btn */
.btn-link i {
    top: 0px;
}

.btn.btn-hover-animation-switch .btn-icon {
    margin-left: 6px;
}

.btn {
    font-family: 'cerebri-sans-medium';
    font-weight: normal !important;
    text-transform: none;
    letter-spacing: normal;
}

.btn-yellow {
    background-color: var(--base-color) !important;
    color: #fff !important;
}

.btn.btn-box-shadow.btn-yellow:hover {
    background-color: var(--base-color) !important;
    color: #fff !important;
}

.btn.btn-box-shadow.btn-yellow:active {
    border-color: var(--base-color) !important;
}

.btn.btn-extra-large {
    font-size: 17px;
}

.btn.btn-large {
    font-size: 16px;
}

.btn.btn-medium {
    font-size: 15px;
}

.btn.with-rounded.btn-large>span {
    line-height: 34px;
}

.btn.with-rounded.btn-medium>span {
    line-height: 30px;
}

/* text color */
.text-emerald-green {
    color: #3aa6e0;
}

/* bg color */
.bg-orient-blue {
    background-color: #1F6668;
}

/* bg gradient color */
.bg-gradient-green-yellow-color {
    background: rgb(58, 166, 224);
    background: linear-gradient(306deg, rgba(220, 238, 251, 1) 0%, rgba(58, 166, 224, 1) 85%);
}

.bg-gradient-gray-light-dark-transparent {
    background-image: -webkit-gradient(linear, left bottom, left top, from(rgba(32, 35, 41, 1)), to(transparent));
    background-image: linear-gradient(to top, rgba(32, 35, 41, 1) 10%, transparent 50%);
}

/* homepage */
.contact-form-style-01 .btn.btn-large {
    padding: 13px 40px;
}

.terms-condition .box:before {
    top: 7px;
}

.terms-condition .box:after {
    top: 11px;
}

.contact-form-style-01 {
    margin-top: -100px;
}

/* page title */
.page-title-extra-small h1 {
    font-size: 18px;
    line-height: 22px;
}

.page-title-extra-small h2 {
    font-size: 4rem;
    line-height: 3.8rem;
}

/* team style */
.team-style-01 figure figcaption .social-icon a {
    margin: 0 5px;
}

/* text shadow */
.text-shadow-medium {
    text-shadow: 0 0 20px rgba(0, 0, 0, 0.3);
}

/* border color */
.border-color-yellow {
    border-color: var(--yellow) !important;
}

.pagination-style-01 .page-item.active .page-link,
.pagination-style-01 .page-item .page-link:hover {
    background: var(--dark-gray);
    color: var(--white);
}

.pagination-style-01 .page-item:first-child .page-link,
.pagination-style-01 .page-item:last-child .page-link {
    background: transparent;
    box-shadow: none !important;
}

.pagination-style-01 .page-item:first-child .page-link,
.pagination-style-01 .page-item:last-child .page-link {
    background: transparent;
    box-shadow: none !important;
}

.pagination-style-01 .page-item:first-child .page-link:hover,
.pagination-style-01 .page-item:last-child .page-link:hover {
    color: var(--dark-gray);
}

/* progress bar style 03 */
.progress-bar-style-03 .progress .progress-bar-title,
.progress-bar-style-03 .progress .progress-bar-percent {
    bottom: 10px;
}

.progress-bar-style-03 .progress {
    height: 6px;
}

/* tooltip */
.tooltip-inner {
    background-color: var(--white);
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.16);
    color: var(--medium-gray);
    padding: 22px 35px;
    max-width: 260px;
    font-size: 16px;
    line-height: 26px;
    text-transform: none;
    font-weight: 400;
}

.bs-tooltip-auto[data-popper-placement^=bottom] .tooltip-arrow:before,
.bs-tooltip-bottom .tooltip-arrow:before {
    border-bottom-color: var(--white) !important;
    border-width: 0 1.7em 1.7em !important;
}

.bs-tooltip-auto[data-popper-placement^=top] .tooltip-arrow:before,
.bs-tooltip-top .tooltip-arrow:before {
    border-top-color: var(--white) !important;
    border-width: 1.7em 1.7em 0 !important;
}

.bs-tooltip-auto[data-popper-placement^=bottom] {
    margin-top: 15px !important;
}

.bs-tooltip-auto[data-popper-placement^=top] {
    margin-bottom: 15px !important;
}

.tooltip {
    opacity: 1 !important;
}

.tooltip .tooltip-arrow {
    width: 3.5em;
    height: 1.2em;
}

.bs-tooltip-start.tooltip .tooltip-arrow {
    width: 1.2em;
    height: 3.2em;
    margin-top: -18px;
}

.bs-tooltip-auto[data-popper-placement^=left] {
    margin-right: 15px;
}

.bs-tooltip-auto[data-popper-placement^=left] .tooltip-arrow:before,
.bs-tooltip-start .tooltip-arrow:before {
    border-width: 1em 0 1em 1em !important;
    border-left-color: var(--white) !important;
}

.bs-tooltip-end.tooltip .tooltip-arrow {
    width: 1.2em;
    height: 3.2em;
    margin-top: -18px;
}

.bs-tooltip-auto[data-popper-placement^=right] {
    margin-left: 15px !important;
}

.bs-tooltip-auto[data-popper-placement^=right] .tooltip-arrow:before,
.bs-tooltip-end .tooltip-arrow:before {
    border-width: 1.7rem 1.7rem 1.7rem 0 !important;
    border-right-color: var(--white) !important;
}

.tooltip-title {
    font-weight: 600;
    display: block;
    font-size: 18px;
    margin-bottom: 7px;
    color: var(--dark-gray);
    letter-spacing: -0.5px;
}

/* top right bottom left */
.left-35px {
    left: 35px;
}

.bottom-35px {
    bottom: 35px;
}

/* footer */
footer .footer-logo img {
    max-height: 36px;
}

.footer-dark p,
.footer-dark .widget-text {
    color: var(--white);
    opacity: 0.4;
}

.footer-dark .elements-social .light li a {
    opacity: 1;
}

.footer-dark p a,
.footer-dark p a:hover {
    color: var(--white);
}

.footer-dark ul li a,
.footer-dark .widget-link {
    color: var(--white);
    opacity: 0.4;
}

.footer-dark ul li a:hover,
.footer-dark .widget-link:hover,
.footer-dark a:hover {
    opacity: 1;
    color: var(--white);
}

footer ul li {
    margin-bottom: 0;
}

.footer-dark .newsletter-style-02 input::placeholder {
    color: var(--white);
}

.footer-dark .newsletter-style-02 input::-webkit-input-placeholder {
    color: var(--white) !important;
    text-overflow: ellipsis;
    opacity: 0.4;
}

.footer-dark .newsletter-style-02 input::-moz-placeholder {
    color: var(--white) !important;
    text-overflow: ellipsis;
    opacity: 0.4;
}

.footer-dark .newsletter-style-02 input:-ms-input-placeholder {
    color: var(--white) !important;
    text-overflow: ellipsis;
    opacity: 0.4;
}

.is-touchable .cursor-page-inner {
    display: none !important;
}

/* media query responsive */
@media (max-width: 1300px) {
    .sticky-wrap.shadow-in {
        left: 18px;
    }
}

@media (max-width: 1250px) {
    .sticky-wrap.shadow-in {
        left: 2px;
    }
}

@media (max-width: 1199px) {
    header .btn.btn-rounded.btn-small {
        padding: 9px 18px;
    }
}

@media (max-width: 991px) {
    .contact-form-style-01 {
        margin-top: 0;
    }

    .tab-style-08 ul .nav-item .nav-link {
        padding: 18px 20px;
    }

    .elements-social .large-icon li {
        margin: 0 5px;
    }

    .navbar .navbar-nav .dropdown.dropdown-with-icon-style02 .dropdown-menu li a {
        padding-left: 0px;
        padding-right: 0px;
    }

    .navbar .navbar-nav .dropdown.dropdown-with-icon-style02 .dropdown-menu li a:hover {
        background-color: transparent;
    }
}

@media (max-width: 767px) {
    .process-step-style-03 .progress-step-separator {
        display: block;
    }
}

@media (max-width: 575px) {
    .process-step-style-03 .progress-step-separator {
        display: none;
    }
}

/* floating contact buttons */
.floating-contact-btns {
    position: fixed;
    right: 20px;
    bottom: 100px;
    z-index: 9999;
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.floating-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 56px;
    height: 56px;
    border-radius: 50%;
    text-decoration: none;
    box-shadow: 0 4px 16px rgba(0,0,0,0.25);
    transition: transform 0.2s ease, box-shadow 0.2s ease;
    font-size: 24px;
    color: #fff !important;
}

.floating-btn:hover {
    transform: scale(1.12);
    box-shadow: 0 6px 22px rgba(0,0,0,0.35);
    color: #fff !important;
}

.floating-btn-whatsapp {
    background-color: #25D366;
}

.floating-btn-call {
    background-color: var(--base-color);
}

.floating-btn-label {
    position: absolute;
    right: 68px;
    background: var(--dark-gray);
    color: #fff;
    font-size: 13px;
    padding: 4px 10px;
    border-radius: 4px;
    white-space: nowrap;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.2s ease;
    font-family: 'cerebri-sans-medium';
}

.floating-btn:hover .floating-btn-label {
    opacity: 1;
}

.floating-btn {
    position: relative;
}

@media (max-width: 575px) {
    .floating-contact-btns {
        right: 14px;
        bottom: 80px;
    }
    .floating-btn {
        width: 50px;
        height: 50px;
        font-size: 21px;
    }
}

/* footer CTA responsive */
@media (max-width: 575px) {
    .footer-top .btn.btn-extra-large {
        font-size: 15px;
        padding: 12px 22px;
        margin-bottom: 10px;
    }
}

/* ============================================================
   TGMCA — Premium Enhancements
   ============================================================ */

/* Section spacing tune */
.tgmca-section-pad {
    padding-top: 80px;
    padding-bottom: 80px;
}

/* Premium page-title hero (used on inner pages) */
.tgmca-hero {
    position: relative;
    overflow: hidden;
}

.tgmca-hero::before {
    content: "";
    position: absolute;
    inset: 0;
    background: rgba(30, 50, 56, 0.72);
    z-index: 0;
}

.tgmca-hero::after {
    content: "";
    position: absolute;
    left: 0;
    bottom: 0;
    width: 100%;
    height: 1px;
    background: rgba(255, 255, 255, 0.08);
    z-index: 1;
}

.tgmca-hero > .container,
.tgmca-hero > * {
    position: relative;
    z-index: 1;
}

.tgmca-hero .breadcrumb-link {
    color: rgba(255, 255, 255, 0.75);
    font-size: 14px;
    font-family: 'cerebri-sans-medium';
    letter-spacing: 0.3px;
    text-decoration: none;
    transition: color 0.2s ease;
}

.tgmca-hero .breadcrumb-link:hover {
    color: var(--yellow);
}

.tgmca-hero .breadcrumb-sep {
    color: rgba(255, 255, 255, 0.35);
    margin: 0 10px;
}

/* Premium services grid (services.html) — editorial card */
.tgmca-services-grid {
    counter-reset: service-counter;
}

.tgmca-services-grid .col {
    counter-increment: service-counter;
}

.tgmca-services-grid .service-card {
    position: relative;
    background: #fff;
    border-radius: 4px;
    padding: 44px 36px 36px;
    height: 100%;
    border: 1px solid rgba(30, 50, 56, 0.1);
    transition: border-color 0.35s ease, transform 0.35s ease;
    overflow: hidden;
}

.tgmca-services-grid .service-card::after {
    content: counter(service-counter, decimal-leading-zero) "  /  08";
    position: absolute;
    top: 24px;
    right: 28px;
    font-family: 'cerebri-sans-bold';
    font-size: 11px;
    color: var(--medium-gray);
    letter-spacing: 2px;
}

.tgmca-services-grid .service-card::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 60px;
    height: 2px;
    background: var(--dark-gray);
    transition: width 0.45s cubic-bezier(0.22, 1, 0.36, 1), background 0.3s ease;
}

.tgmca-services-grid .service-card:hover {
    border-color: var(--dark-gray);
    transform: translateY(-2px);
}

.tgmca-services-grid .service-card:hover::before {
    width: 100%;
    background: var(--yellow);
}

.tgmca-services-grid .service-card .card-index {
    position: absolute;
    top: 24px;
    right: 28px;
    font-family: 'cerebri-sans-light';
    font-size: 13px;
    color: var(--medium-gray);
    letter-spacing: 2px;
}

.tgmca-services-grid .service-card .service-icon-wrap {
    width: 56px;
    height: 56px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: transparent;
    border: 1px solid rgba(30, 50, 56, 0.15);
    border-radius: 50%;
    margin-bottom: 28px;
    transition: background 0.35s ease, border-color 0.35s ease, color 0.35s ease;
}

.tgmca-services-grid .service-card .service-icon-wrap i {
    color: var(--dark-gray);
    font-size: 24px;
    transition: color 0.35s ease;
}

.tgmca-services-grid .service-card:hover .service-icon-wrap {
    background: var(--dark-gray);
    border-color: var(--dark-gray);
}

.tgmca-services-grid .service-card:hover .service-icon-wrap i {
    color: var(--yellow);
}

.tgmca-services-grid .service-card .service-title {
    font-size: 22px;
    line-height: 1.3;
    color: var(--dark-gray);
    font-family: 'cerebri-sans-bold';
    margin-bottom: 14px;
    display: block;
    letter-spacing: -0.5px;
    text-decoration: none;
}

.tgmca-services-grid .service-card .service-desc {
    font-size: 15px;
    line-height: 1.7;
    color: var(--medium-gray);
    margin-bottom: 28px;
    min-height: 80px;
}

.tgmca-services-grid .service-card .service-link {
    color: var(--dark-gray);
    font-family: 'cerebri-sans-bold';
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 2px;
    display: inline-flex;
    align-items: center;
    gap: 10px;
    text-decoration: none;
    padding-bottom: 4px;
    border-bottom: 1px solid var(--dark-gray);
    transition: gap 0.25s ease, color 0.25s ease, border-color 0.25s ease;
}

.tgmca-services-grid .service-card .service-link i {
    font-size: 10px;
    transition: transform 0.25s ease;
}

.tgmca-services-grid .service-card .service-link:hover {
    color: var(--base-color);
    border-color: var(--yellow);
}

.tgmca-services-grid .service-card .service-link:hover i {
    transform: translateX(4px);
}

@media (max-width: 991px) {
    .tgmca-services-grid .service-card {
        padding: 36px 28px 30px;
    }
    .tgmca-services-grid .service-card .service-desc {
        min-height: 0;
    }
}

/* Final CTA card inside the services grid — solid dark editorial */
.tgmca-services-grid .service-cta {
    position: relative;
    background: var(--dark-gray);
    color: #fff;
    border-radius: 4px;
    padding: 44px 36px 36px;
    height: 100%;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    overflow: hidden;
    border: 1px solid var(--dark-gray);
}

.tgmca-services-grid .service-cta::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 2px;
    background: var(--yellow);
}

.tgmca-services-grid .service-cta::after {
    content: "→";
    position: absolute;
    top: 22px;
    right: 28px;
    color: rgba(255, 255, 255, 0.18);
    font-size: 28px;
    font-family: serif;
}

.tgmca-services-grid .service-cta h5 {
    color: #fff;
    font-family: 'cerebri-sans-bold';
    font-size: 22px;
    line-height: 1.3;
    margin-bottom: 14px;
    letter-spacing: -0.5px;
    margin-top: 16px;
}

.tgmca-services-grid .service-cta p {
    color: rgba(255, 255, 255, 0.6);
    font-size: 15px;
    line-height: 1.7;
    margin-bottom: 28px;
}

.tgmca-services-grid .service-cta .cta-btns {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.tgmca-services-grid .service-cta .cta-btns a {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 11px 20px;
    border-radius: 2px;
    font-size: 12px;
    font-family: 'cerebri-sans-bold';
    text-transform: uppercase;
    letter-spacing: 1.4px;
    text-decoration: none;
    transition: background 0.2s ease, color 0.2s ease, border-color 0.2s ease;
}

.tgmca-services-grid .service-cta .cta-btn-primary {
    background: var(--yellow);
    color: var(--dark-gray);
    border: 1px solid var(--yellow);
}

.tgmca-services-grid .service-cta .cta-btn-primary:hover {
    background: transparent;
    color: var(--yellow);
}

.tgmca-services-grid .service-cta .cta-btn-secondary {
    background: transparent;
    color: #fff;
    border: 1px solid rgba(255, 255, 255, 0.3);
}

.tgmca-services-grid .service-cta .cta-btn-secondary:hover {
    border-color: #fff;
    background: #fff;
    color: var(--dark-gray);
}

/* Editorial FAQ accordion */
.tgmca-faq {
    counter-reset: faq-counter;
}

.tgmca-faq .accordion-item {
    background: transparent;
    border: none !important;
    border-bottom: 1px solid rgba(30, 50, 56, 0.12) !important;
    border-radius: 0 !important;
    margin-bottom: 0;
    overflow: hidden;
    box-shadow: none;
    transition: background 0.3s ease;
    counter-increment: faq-counter;
}

.tgmca-faq .accordion-item:first-child {
    border-top: 1px solid rgba(30, 50, 56, 0.12) !important;
}

.tgmca-faq .accordion-item:hover {
    box-shadow: none;
}

.tgmca-faq .accordion-item.active-accordion {
    border-color: rgba(30, 50, 56, 0.25) !important;
    box-shadow: none;
}

.tgmca-faq .accordion-header {
    border: none !important;
}

.tgmca-faq .accordion-header > a {
    padding: 26px 0 !important;
    display: block;
    text-decoration: none !important;
}

.tgmca-faq .accordion-title {
    display: flex !important;
    align-items: center;
    gap: 22px;
    position: relative;
    padding-left: 56px;
}

.tgmca-faq .accordion-title::before {
    content: counter(faq-counter, decimal-leading-zero);
    position: absolute;
    left: 0;
    top: 2px;
    font-family: 'cerebri-sans-bold';
    color: var(--medium-gray);
    font-size: 13px;
    letter-spacing: 2px;
    width: 40px;
}

.tgmca-faq .accordion-item.active-accordion .accordion-title::before {
    color: var(--yellow);
}

.tgmca-faq .accordion-title i {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    background: transparent;
    border: 1px solid rgba(30, 50, 56, 0.2);
    color: var(--dark-gray);
    font-size: 11px !important;
    flex-shrink: 0;
    margin-left: auto;
    transition: background 0.25s ease, color 0.25s ease, border-color 0.25s ease, transform 0.3s ease;
}

.tgmca-faq .accordion-item.active-accordion .accordion-title i {
    background: var(--dark-gray);
    border-color: var(--dark-gray);
    color: var(--yellow);
    transform: rotate(180deg);
}

.tgmca-faq .accordion-title span {
    font-family: 'cerebri-sans-bold';
    color: var(--dark-gray);
    font-size: 18px !important;
    line-height: 1.4;
    letter-spacing: -0.3px;
    flex: 1;
}

.tgmca-faq .accordion-body {
    padding: 0 0 26px 56px !important;
    border: none !important;
}

.tgmca-faq .accordion-body p {
    color: var(--medium-gray);
    font-size: 16px;
    line-height: 1.75;
    max-width: 92%;
}

@media (max-width: 575px) {
    .tgmca-faq .accordion-header > a {
        padding: 22px 0 !important;
    }
    .tgmca-faq .accordion-body {
        padding: 0 0 22px 40px !important;
    }
    .tgmca-faq .accordion-title {
        padding-left: 40px;
        gap: 14px;
    }
    .tgmca-faq .accordion-title::before {
        width: 30px;
        font-size: 11px;
    }
    .tgmca-faq .accordion-title span {
        font-size: 15px !important;
    }
}

/* ============================================================
   Inner service pages — premium look
   ============================================================ */

/* Sticky sidebar wrapper on desktop */
@media (min-width: 992px) {
    .tgmca-service-sidebar {
        position: sticky;
        top: 110px;
    }
}

/* Sidebar service navigation — editorial */
.tgmca-sidebar-services {
    padding: 32px 28px !important;
    background: #fff !important;
    border: 1px solid rgba(30, 50, 56, 0.1);
    border-radius: 4px !important;
    position: relative;
}

.tgmca-sidebar-services::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 60px;
    height: 2px;
    background: var(--dark-gray);
}

.tgmca-sidebar-services .sidebar-title {
    display: block;
    font-family: 'cerebri-sans-bold';
    font-size: 13px;
    text-transform: uppercase;
    letter-spacing: 1.5px;
    color: var(--base-color);
    margin-bottom: 18px;
}

.tgmca-sidebar-services ul {
    list-style: none;
    padding: 0;
    margin: 0;
}

.tgmca-sidebar-services ul li {
    margin: 0;
    border-bottom: 1px solid rgba(30, 50, 56, 0.08);
}

.tgmca-sidebar-services ul li:last-child {
    border-bottom: none;
}

.tgmca-sidebar-services ul li a {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 14px 4px;
    color: var(--dark-gray);
    font-family: 'cerebri-sans-medium';
    font-size: 15px;
    text-decoration: none;
    transition: color 0.2s ease, padding 0.25s ease;
}

.tgmca-sidebar-services ul li a::after {
    content: "\f061";
    font-family: "Font Awesome 6 Free";
    font-weight: 900;
    color: rgba(30, 50, 56, 0.3);
    font-size: 11px;
    transition: transform 0.25s ease, color 0.2s ease;
}

.tgmca-sidebar-services ul li a:hover {
    color: var(--base-color);
    padding-left: 8px;
}

.tgmca-sidebar-services ul li a:hover::after {
    color: var(--yellow);
    transform: translateX(4px);
}

.tgmca-sidebar-services ul li.active a {
    color: var(--base-color);
    font-family: 'cerebri-sans-bold';
}

.tgmca-sidebar-services ul li.active a::before {
    content: "";
    width: 4px;
    height: 18px;
    background: var(--yellow);
    margin-right: 12px;
    border-radius: 4px;
}

/* Premium "call us" sidebar card — solid editorial dark */
.tgmca-sidebar-call {
    position: relative;
    background: var(--dark-gray);
    border-radius: 4px;
    padding: 30px 28px;
    overflow: hidden;
    border-top: 2px solid var(--yellow);
}

.tgmca-sidebar-call::after {
    content: "";
    position: absolute;
    top: 18px;
    right: 22px;
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: var(--accent-mint);
    box-shadow: 0 0 0 4px rgba(220, 238, 251, 0.22);
}

.tgmca-sidebar-call .feature-box {
    position: relative;
    z-index: 1;
}

.tgmca-sidebar-call .feature-box-icon {
    background: transparent !important;
    border: 1px solid rgba(255, 255, 255, 0.15);
    box-shadow: none !important;
}

.tgmca-sidebar-call .feature-box-icon i {
    color: var(--yellow) !important;
}

/* Premium consultation form card — clean cream surface */
.tgmca-sidebar-form {
    background: #ffffff !important;
    border: 1px solid rgba(30, 50, 56, 0.1);
    border-radius: 4px !important;
    padding: 32px 28px !important;
    position: relative;
}

.tgmca-sidebar-form::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 60px;
    height: 2px;
    background: var(--yellow);
}

.tgmca-sidebar-form .form-title {
    display: block;
    font-family: 'cerebri-sans-bold';
    font-size: 13px;
    text-transform: uppercase;
    letter-spacing: 1.5px;
    color: var(--base-color);
    margin-bottom: 6px;
}

.tgmca-sidebar-form .form-subtitle {
    display: block;
    font-family: 'cerebri-sans-bold';
    font-size: 18px;
    color: var(--dark-gray);
    line-height: 1.4;
    margin-bottom: 22px;
    letter-spacing: -0.3px;
}

/* ============================================================
   Inner service detail content — premium card grid
   ============================================================ */

.tgmca-service-detail .service-intro-eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 14px;
    font-family: 'cerebri-sans-bold';
    font-size: 11px;
    letter-spacing: 2.4px;
    text-transform: uppercase;
    color: var(--dark-gray);
    margin-bottom: 22px;
}

.tgmca-service-detail .service-intro-eyebrow::before {
    content: "";
    width: 32px;
    height: 1px;
    background: var(--yellow);
}

.tgmca-service-detail .service-main-title {
    font-family: 'cerebri-sans-bold';
    color: var(--dark-gray);
    font-size: 36px;
    line-height: 1.2;
    letter-spacing: -1px;
    margin-bottom: 18px;
}

.tgmca-service-detail .service-intro-lead {
    font-size: 18px;
    line-height: 1.7;
    color: var(--medium-gray);
    margin-bottom: 50px;
    padding-bottom: 30px;
    border-bottom: 1px dashed rgba(30, 50, 56, 0.15);
}

.tgmca-service-detail .section-eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 14px;
    font-family: 'cerebri-sans-bold';
    font-size: 11px;
    letter-spacing: 2.4px;
    text-transform: uppercase;
    color: var(--dark-gray);
    margin-bottom: 18px;
}

.tgmca-service-detail .section-eyebrow::before {
    content: "";
    width: 28px;
    height: 1px;
    background: var(--yellow);
}

.tgmca-service-detail .section-title {
    font-family: 'cerebri-sans-bold';
    color: var(--dark-gray);
    font-size: 32px;
    line-height: 1.2;
    letter-spacing: -1px;
    margin-bottom: 36px;
}

/* The grid wrapper that turns the existing <p> + divider list into cards */
.tgmca-service-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 18px;
    margin-bottom: 60px;
}

@media (max-width: 575px) {
    .tgmca-service-grid {
        grid-template-columns: 1fr;
        gap: 14px;
    }
}

/* Hide the legacy dividers within the grid — we use card spacing instead */
.tgmca-service-grid .divider-style-03 {
    display: none !important;
}

.tgmca-service-grid > p {
    position: relative;
    background: #fff;
    border: 1px solid rgba(30, 50, 56, 0.1);
    border-radius: 4px;
    padding: 24px 26px 24px 60px;
    margin: 0;
    font-size: 15px;
    line-height: 1.7;
    color: var(--medium-gray);
    transition: border-color 0.3s ease, transform 0.3s ease;
}

.tgmca-service-grid > p::before {
    content: "";
    position: absolute;
    left: 26px;
    top: 30px;
    width: 18px;
    height: 1px;
    background: var(--dark-gray);
    transition: width 0.3s ease, background 0.3s ease;
}

.tgmca-service-grid > p:hover {
    border-color: var(--dark-gray);
    transform: translateX(2px);
}

.tgmca-service-grid > p:hover::before {
    width: 26px;
    background: var(--yellow);
}

.tgmca-service-grid > p > span:first-child,
.tgmca-service-grid > p .fw-600.text-decoration-line-bottom {
    display: block;
    font-family: 'cerebri-sans-bold';
    color: var(--dark-gray);
    font-size: 16px;
    line-height: 1.4;
    margin-bottom: 6px;
    letter-spacing: -0.2px;
    text-decoration: none !important;
    border: none !important;
}

/* "Why choose" callout — editorial bordered list */
.tgmca-why-box {
    border: 1px solid rgba(30, 50, 56, 0.1) !important;
    background: #fff;
    border-radius: 4px !important;
    overflow: hidden;
    padding: 0;
}

.tgmca-why-box > p {
    background: transparent !important;
    border-radius: 0;
    border: none !important;
    border-bottom: 1px solid rgba(30, 50, 56, 0.08) !important;
    margin-bottom: 0 !important;
    padding: 26px 32px 26px 70px !important;
    position: relative;
    font-size: 15px;
    line-height: 1.7;
    color: var(--medium-gray);
}

.tgmca-why-box > p:last-child {
    border-bottom: none !important;
}

.tgmca-why-box > p::before {
    counter-increment: why-counter;
    content: counter(why-counter, decimal-leading-zero);
    position: absolute;
    left: 32px;
    top: 28px;
    font-family: 'cerebri-sans-bold';
    color: var(--yellow);
    font-size: 13px;
    letter-spacing: 1px;
}

.tgmca-why-box {
    counter-reset: why-counter;
}

.tgmca-why-box > p .fw-600 {
    display: block;
    color: var(--dark-gray);
    font-family: 'cerebri-sans-bold';
    margin-bottom: 4px;
    font-size: 16px;
    letter-spacing: -0.2px;
}

.tgmca-why-box > p.bg-solitude-blue {
    background: rgba(220, 238, 251, 0.08) !important;
}

/* Inline contact CTA at bottom of inner page — editorial dark band */
.tgmca-inline-cta {
    position: relative;
    margin-top: 30px;
    background: var(--dark-gray);
    border-radius: 4px;
    padding: 36px 36px;
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 20px;
    border-left: 3px solid var(--yellow);
}

.tgmca-inline-cta::before {
    content: "—";
    position: absolute;
    top: 16px;
    right: 28px;
    color: var(--yellow);
    font-family: 'cerebri-sans-bold';
    letter-spacing: 4px;
    font-size: 18px;
    opacity: 0.6;
}

.tgmca-inline-cta .inline-cta-text {
    color: rgba(255, 255, 255, 0.85);
    font-family: 'cerebri-sans-regular';
    font-size: 17px;
    line-height: 1.55;
    margin: 0;
    flex: 1 1 60%;
}

.tgmca-inline-cta .inline-cta-text strong {
    color: #fff;
    font-family: 'cerebri-sans-bold';
}

.tgmca-inline-cta .inline-cta-btn {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    background: var(--yellow);
    color: var(--dark-gray) !important;
    padding: 14px 26px;
    border-radius: 2px;
    font-family: 'cerebri-sans-bold';
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: 1.6px;
    text-decoration: none !important;
    border: 1px solid var(--yellow);
    transition: background 0.2s ease, color 0.2s ease;
}

.tgmca-inline-cta .inline-cta-btn i {
    font-size: 11px;
    transition: transform 0.25s ease;
}

.tgmca-inline-cta .inline-cta-btn:hover {
    background: transparent;
    color: var(--yellow) !important;
}

.tgmca-inline-cta .inline-cta-btn:hover i {
    transform: translateX(4px);
}

@media (max-width: 575px) {
    .tgmca-inline-cta {
        padding: 22px 22px;
        text-align: center;
        justify-content: center;
    }
    .tgmca-service-detail .service-main-title {
        font-size: 28px;
    }
    .tgmca-service-detail .section-title {
        font-size: 24px;
    }
}

/* ============================================================
   Process / "what to expect" steps strip
   ============================================================ */
.tgmca-process-strip {
    margin: 60px 0;
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 16px;
}

.tgmca-process-strip .process-step {
    background: #fff;
    border: 1px solid rgba(30, 50, 56, 0.08);
    border-radius: 12px;
    padding: 26px 22px;
    position: relative;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.tgmca-process-strip .process-step:hover {
    transform: translateY(-4px);
    box-shadow: 0 16px 32px rgba(30, 50, 56, 0.08);
}

.tgmca-process-strip .step-num {
    display: inline-block;
    font-family: 'cerebri-sans-bold';
    color: var(--yellow);
    font-size: 14px;
    letter-spacing: 1px;
    margin-bottom: 14px;
}

.tgmca-process-strip .step-title {
    font-family: 'cerebri-sans-bold';
    color: var(--dark-gray);
    font-size: 17px;
    line-height: 1.35;
    margin-bottom: 8px;
    letter-spacing: -0.3px;
}

.tgmca-process-strip .step-desc {
    color: var(--medium-gray);
    font-size: 14px;
    line-height: 1.6;
    margin: 0;
}

@media (max-width: 991px) {
    .tgmca-process-strip {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 575px) {
    .tgmca-process-strip {
        grid-template-columns: 1fr;
    }
}

/* ============================================================
   Generic responsive polish
   ============================================================ */
@media (max-width: 991px) {
    body {
        font-size: 16px;
        line-height: 28px;
    }
    h1 { font-size: 2.25rem; line-height: 2.6rem; }
    h2 { font-size: 1.9rem; line-height: 2.3rem; }
    h3 { font-size: 1.6rem; line-height: 2rem; }
    h4 { font-size: 1.35rem; line-height: 1.7rem; }
    h5 { font-size: 1.15rem; line-height: 1.6rem; }
}

@media (max-width: 767px) {
    .top-space-margin {
        margin-top: 70px;
    }
    .page-title-extra-small h2 {
        font-size: 2.4rem;
        line-height: 2.6rem;
    }
}

@media (max-width: 575px) {
    .page-title-extra-small h2 {
        font-size: 1.9rem;
        line-height: 2.1rem;
    }
    .page-title-extra-small h1 {
        font-size: 14px;
    }
    section {
        padding-top: 50px;
        padding-bottom: 50px;
    }
}

/* Subtle section divider */
.tgmca-divider {
    height: 1px;
    background: rgba(30, 50, 56, 0.1);
    margin: 0;
    border: none;
}

/* Improved scroll-top button */
.scroll-progress .scroll-top {
    color: var(--base-color);
}

/* Form input premium polish */
.contact-form-style-01 .form-control {
    border-radius: 10px !important;
    border: 1px solid rgba(30, 50, 56, 0.1) !important;
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.contact-form-style-01 .form-control:focus {
    border-color: var(--base-color) !important;
    box-shadow: 0 0 0 3px rgba(58, 166, 224, 0.12) !important;
}

/* ============================================================
   TGMCA — Home & About creative premium sections
   ============================================================ */

/* Stats strip — solid editorial dark band */
.tgmca-stats-strip {
    background: var(--dark-gray);
    border-radius: 4px;
    padding: 60px 50px;
    position: relative;
    overflow: hidden;
    border-top: 2px solid var(--yellow);
}

.tgmca-stats-strip::before {
    content: "BY THE NUMBERS";
    position: absolute;
    top: 22px;
    left: 50px;
    font-family: 'cerebri-sans-bold';
    font-size: 11px;
    letter-spacing: 3px;
    color: rgba(255, 255, 255, 0.35);
}

.tgmca-stats-strip .row {
    position: relative;
    z-index: 1;
    margin-top: 30px;
}

.tgmca-stats-strip .stat-item {
    text-align: left;
    color: #fff;
    padding: 0 10px;
    position: relative;
}

.tgmca-stats-strip .stat-num {
    font-family: 'cerebri-sans-bold';
    font-size: 64px;
    line-height: 1;
    color: #fff;
    letter-spacing: -3px;
    display: block;
    margin-bottom: 14px;
}

.tgmca-stats-strip .stat-num sup {
    color: var(--accent-mint);
    font-size: 26px;
    letter-spacing: 0;
    top: -28px;
    margin-left: 4px;
}

.tgmca-stats-strip .stat-label {
    font-family: 'cerebri-sans-regular';
    font-size: 13px;
    color: rgba(255, 255, 255, 0.55);
    letter-spacing: 1.2px;
    text-transform: uppercase;
    line-height: 1.5;
    display: block;
    padding-top: 14px;
    border-top: 1px solid rgba(255, 255, 255, 0.1);
}

.tgmca-stats-strip .stat-divider {
    width: 1px;
    background: rgba(255, 255, 255, 0.08);
}

@media (max-width: 767px) {
    .tgmca-stats-strip {
        padding: 40px 28px;
    }
    .tgmca-stats-strip::before {
        left: 28px;
    }
    .tgmca-stats-strip .stat-num {
        font-size: 44px;
        letter-spacing: -2px;
    }
    .tgmca-stats-strip .stat-num sup {
        font-size: 18px;
        top: -18px;
    }
    .tgmca-stats-strip .stat-divider {
        display: none;
    }
    .tgmca-stats-strip .stat-item {
        padding: 22px 0;
        border-bottom: 1px solid rgba(255, 255, 255, 0.08);
    }
    .tgmca-stats-strip .stat-item:last-child {
        border-bottom: none;
    }
}

/* Industries strip — editorial bordered tiles */
.tgmca-industries {
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    gap: 0;
    border: 1px solid rgba(30, 50, 56, 0.1);
    border-radius: 4px;
    overflow: hidden;
    background: #fff;
}

.tgmca-industries .industry-pill {
    background: #fff;
    border-right: 1px solid rgba(30, 50, 56, 0.08);
    border-bottom: 1px solid rgba(30, 50, 56, 0.08);
    padding: 28px 18px;
    text-align: center;
    transition: background 0.3s ease, color 0.3s ease;
    cursor: default;
    position: relative;
}

.tgmca-industries .industry-pill:nth-child(6n) {
    border-right: none;
}

.tgmca-industries .industry-pill:nth-last-child(-n+6) {
    border-bottom: none;
}

.tgmca-industries .industry-pill:hover {
    background: var(--dark-gray);
}

.tgmca-industries .industry-pill i {
    color: var(--dark-gray);
    font-size: 26px;
    display: block;
    margin-bottom: 14px;
    transition: color 0.3s ease;
}

.tgmca-industries .industry-pill:hover i {
    color: var(--yellow);
}

.tgmca-industries .industry-pill span {
    font-family: 'cerebri-sans-bold';
    color: var(--dark-gray);
    font-size: 13px;
    line-height: 1.3;
    display: block;
    letter-spacing: 0.3px;
    text-transform: uppercase;
    transition: color 0.3s ease;
}

.tgmca-industries .industry-pill:hover span {
    color: #fff;
}

@media (max-width: 991px) {
    .tgmca-industries {
        grid-template-columns: repeat(3, 1fr);
    }
    .tgmca-industries .industry-pill {
        border-right: 1px solid rgba(30, 50, 56, 0.08);
        border-bottom: 1px solid rgba(30, 50, 56, 0.08);
    }
    .tgmca-industries .industry-pill:nth-child(6n) {
        border-right: 1px solid rgba(30, 50, 56, 0.08);
    }
    .tgmca-industries .industry-pill:nth-child(3n) {
        border-right: none;
    }
    .tgmca-industries .industry-pill:nth-last-child(-n+3) {
        border-bottom: none;
    }
}

@media (max-width: 575px) {
    .tgmca-industries {
        grid-template-columns: repeat(2, 1fr);
    }
    .tgmca-industries .industry-pill:nth-child(3n) {
        border-right: 1px solid rgba(30, 50, 56, 0.08);
    }
    .tgmca-industries .industry-pill:nth-child(2n) {
        border-right: none;
    }
    .tgmca-industries .industry-pill:nth-last-child(-n+3) {
        border-bottom: 1px solid rgba(30, 50, 56, 0.08);
    }
    .tgmca-industries .industry-pill:nth-last-child(-n+2) {
        border-bottom: none;
    }
}

/* "Approach" cards — editorial big-numeral cards */
.tgmca-approach-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 0;
    border-top: 1px solid rgba(30, 50, 56, 0.1);
    border-bottom: 1px solid rgba(30, 50, 56, 0.1);
}

.tgmca-approach-grid .approach-card {
    position: relative;
    background: transparent;
    padding: 56px 36px 56px;
    transition: background 0.35s ease;
    overflow: hidden;
    border-right: 1px solid rgba(30, 50, 56, 0.1);
}

.tgmca-approach-grid .approach-card:last-child {
    border-right: none;
}

.tgmca-approach-grid .approach-card::before {
    content: attr(data-step);
    display: block;
    font-family: 'cerebri-sans-bold';
    font-size: 13px;
    color: var(--yellow);
    letter-spacing: 4px;
    margin-bottom: 28px;
}

.tgmca-approach-grid .approach-card:hover {
    background: rgba(220, 238, 251, 0.14);
}

.tgmca-approach-grid .approach-icon {
    width: 48px;
    height: 1px;
    background: var(--dark-gray);
    display: block;
    margin: 0 0 28px 0;
    transition: width 0.4s ease, background 0.3s ease;
}

.tgmca-approach-grid .approach-card:hover .approach-icon {
    width: 80px;
    background: var(--yellow);
}

.tgmca-approach-grid .approach-icon i {
    display: none;
}

.tgmca-approach-grid .approach-title {
    font-family: 'cerebri-sans-bold';
    color: var(--dark-gray);
    font-size: 26px;
    line-height: 1.25;
    margin-bottom: 18px;
    letter-spacing: -0.7px;
    position: relative;
    z-index: 1;
}

.tgmca-approach-grid .approach-desc {
    color: var(--medium-gray);
    font-size: 15px;
    line-height: 1.7;
    margin: 0;
    position: relative;
    z-index: 1;
    max-width: 90%;
}

@media (max-width: 991px) {
    .tgmca-approach-grid {
        grid-template-columns: 1fr;
    }
    .tgmca-approach-grid .approach-card {
        border-right: none;
        border-bottom: 1px solid rgba(30, 50, 56, 0.1);
        padding: 44px 24px;
    }
    .tgmca-approach-grid .approach-card:last-child {
        border-bottom: none;
    }
}

/* Testimonials grid — editorial quote cards */
.tgmca-testimonials {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
}

.tgmca-testimonials .testimonial-card {
    background: #fff;
    border: 1px solid rgba(30, 50, 56, 0.1);
    border-radius: 4px;
    padding: 36px 32px 32px;
    position: relative;
    transition: border-color 0.3s ease, transform 0.3s ease;
}

.tgmca-testimonials .testimonial-card::before {
    content: "";
    position: absolute;
    top: -1px;
    left: 0;
    width: 50px;
    height: 2px;
    background: var(--dark-gray);
    transition: width 0.4s cubic-bezier(0.22, 1, 0.36, 1), background 0.3s ease;
}

.tgmca-testimonials .testimonial-card:hover {
    border-color: var(--dark-gray);
    transform: translateY(-2px);
}

.tgmca-testimonials .testimonial-card:hover::before {
    width: 100%;
    background: var(--yellow);
}

.tgmca-testimonials .quote-mark {
    position: absolute;
    top: 18px;
    right: 28px;
    font-size: 72px;
    line-height: 1;
    color: var(--dark-gray);
    opacity: 0.08;
    font-family: Georgia, "Times New Roman", serif;
    font-style: italic;
    pointer-events: none;
}

.tgmca-testimonials .testimonial-stars {
    color: var(--yellow);
    margin-bottom: 22px;
    font-size: 12px;
    letter-spacing: 4px;
}

.tgmca-testimonials .testimonial-text {
    color: var(--dark-gray);
    font-size: 17px;
    line-height: 1.6;
    margin-bottom: 32px;
    font-family: Georgia, "Times New Roman", serif;
    font-style: italic;
    letter-spacing: -0.2px;
}

.tgmca-testimonials .testimonial-author {
    display: flex;
    align-items: center;
    gap: 16px;
    padding-top: 22px;
    border-top: 1px solid rgba(30, 50, 56, 0.08);
}

.tgmca-testimonials .author-avatar {
    width: 44px;
    height: 44px;
    border-radius: 50%;
    background: var(--dark-gray);
    border: 1px solid var(--dark-gray);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--yellow);
    font-family: 'cerebri-sans-bold';
    font-size: 14px;
    letter-spacing: 1px;
    flex-shrink: 0;
}

.tgmca-testimonials .author-info span {
    display: block;
}

.tgmca-testimonials .author-name {
    font-family: 'cerebri-sans-bold';
    color: var(--dark-gray);
    font-size: 14px;
    letter-spacing: -0.1px;
    margin-bottom: 2px;
}

.tgmca-testimonials .author-role {
    color: var(--medium-gray);
    font-size: 12px;
    letter-spacing: 0.5px;
    text-transform: uppercase;
}

@media (max-width: 991px) {
    .tgmca-testimonials {
        grid-template-columns: 1fr;
    }
}

/* Mission / Vision / Values — editorial numbered cards */
.tgmca-mvv {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
    counter-reset: mvv-counter;
}

.tgmca-mvv .mvv-card {
    position: relative;
    border-radius: 4px;
    padding: 48px 36px 40px;
    overflow: hidden;
    transition: border-color 0.35s ease, background 0.35s ease;
    border: 1px solid rgba(30, 50, 56, 0.1);
    background: #fff;
    counter-increment: mvv-counter;
}

.tgmca-mvv .mvv-card::before {
    content: counter(mvv-counter, decimal-leading-zero);
    position: absolute;
    top: 30px;
    right: 36px;
    font-family: 'cerebri-sans-bold';
    color: var(--medium-gray);
    font-size: 13px;
    letter-spacing: 2px;
    opacity: 0.6;
}

.tgmca-mvv .mvv-card::after {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 50px;
    height: 2px;
    background: var(--dark-gray);
    transition: width 0.4s cubic-bezier(0.22, 1, 0.36, 1), background 0.3s ease;
}

.tgmca-mvv .mvv-card:hover {
    border-color: var(--dark-gray);
}

.tgmca-mvv .mvv-card:hover::after {
    width: 100%;
    background: var(--yellow);
}

.tgmca-mvv .mvv-icon {
    width: 56px;
    height: 56px;
    border-radius: 50%;
    background: transparent;
    border: 1px solid rgba(30, 50, 56, 0.15);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 28px;
    transition: background 0.35s ease, border-color 0.35s ease;
}

.tgmca-mvv .mvv-icon i {
    color: var(--dark-gray);
    font-size: 22px;
    transition: color 0.35s ease;
}

.tgmca-mvv .mvv-card:hover .mvv-icon {
    background: var(--dark-gray);
    border-color: var(--dark-gray);
}

.tgmca-mvv .mvv-card:hover .mvv-icon i {
    color: var(--yellow);
}

.tgmca-mvv .mvv-card.alt .mvv-icon {
    background: transparent;
}

.tgmca-mvv .mvv-card.alt .mvv-icon i {
    color: var(--dark-gray);
}

.tgmca-mvv .mvv-eyebrow {
    display: inline-block;
    font-family: 'cerebri-sans-bold';
    font-size: 11px;
    letter-spacing: 2.4px;
    text-transform: uppercase;
    color: var(--medium-gray);
    margin-bottom: 12px;
}

.tgmca-mvv .mvv-title {
    font-family: 'cerebri-sans-bold';
    color: var(--dark-gray);
    font-size: 26px;
    line-height: 1.25;
    margin-bottom: 16px;
    letter-spacing: -0.7px;
}

.tgmca-mvv .mvv-desc {
    color: var(--medium-gray);
    font-size: 15px;
    line-height: 1.7;
    margin: 0;
}

@media (max-width: 991px) {
    .tgmca-mvv {
        grid-template-columns: 1fr;
    }
}

/* Section eyebrow + heading composer — editorial */
.tgmca-section-head {
    text-align: center;
    margin-bottom: 60px;
}

.tgmca-section-head .eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 14px;
    font-family: 'cerebri-sans-bold';
    font-size: 11px;
    letter-spacing: 2.6px;
    text-transform: uppercase;
    color: var(--dark-gray);
    margin-bottom: 22px;
    padding: 0;
    background: transparent;
    border-radius: 0;
}

.tgmca-section-head .eyebrow::before,
.tgmca-section-head .eyebrow::after {
    content: "";
    width: 32px;
    height: 1px;
    background: var(--yellow);
}

.tgmca-section-head h3 {
    font-family: 'cerebri-sans-bold';
    color: var(--dark-gray);
    letter-spacing: -1.2px;
    margin: 0 auto;
    max-width: 720px;
}

.tgmca-section-head p {
    color: var(--medium-gray);
    font-size: 17px;
    line-height: 1.7;
    margin: 18px auto 0;
    max-width: 640px;
}

/* Stats strip "BY THE NUMBERS" label uses mint accent on dark bg */
.tgmca-sidebar-call .feature-box-icon i {
    color: var(--accent-mint) !important;
}

/* CTA primary button uses white text on emerald */
.tgmca-services-grid .service-cta .cta-btn-primary {
    background: var(--base-color);
    color: #fff;
    border: 1px solid var(--base-color);
}
.tgmca-services-grid .service-cta .cta-btn-primary:hover {
    background: transparent;
    color: var(--accent-mint);
    border-color: var(--accent-mint);
}

/* Inline CTA button fix for new color */
.tgmca-inline-cta .inline-cta-btn {
    background: var(--base-color);
    color: #fff !important;
    border-color: var(--base-color);
}
.tgmca-inline-cta .inline-cta-btn:hover {
    background: transparent;
    color: var(--accent-mint) !important;
    border-color: var(--accent-mint);
}

/* Promise / commitments grid (about) — editorial bordered list */
.tgmca-promise-list {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 0;
    border-top: 1px solid rgba(30, 50, 56, 0.1);
    border-left: 1px solid rgba(30, 50, 56, 0.1);
}

.tgmca-promise-list .promise-item {
    display: flex;
    gap: 18px;
    background: transparent;
    border: none;
    border-right: 1px solid rgba(30, 50, 56, 0.1);
    border-bottom: 1px solid rgba(30, 50, 56, 0.1);
    border-radius: 0;
    padding: 28px 26px;
    transition: background 0.25s ease;
}

.tgmca-promise-list .promise-item:hover {
    background: rgba(220, 238, 251, 0.14);
}

.tgmca-promise-list .promise-icon {
    flex-shrink: 0;
    width: 42px;
    height: 42px;
    border-radius: 50%;
    background: transparent;
    border: 1px solid rgba(30, 50, 56, 0.2);
    color: var(--dark-gray);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 16px;
    transition: background 0.25s ease, color 0.25s ease, border-color 0.25s ease;
}

.tgmca-promise-list .promise-item:hover .promise-icon {
    background: var(--dark-gray);
    border-color: var(--dark-gray);
    color: var(--yellow);
}

.tgmca-promise-list .promise-text {
    color: var(--medium-gray);
    font-size: 14px;
    line-height: 1.65;
    margin: 0;
}

.tgmca-promise-list .promise-text strong {
    display: block;
    color: var(--dark-gray);
    font-family: 'cerebri-sans-bold';
    font-size: 16px;
    margin-bottom: 6px;
    letter-spacing: -0.2px;
}

@media (max-width: 575px) {
    .tgmca-promise-list {
        grid-template-columns: 1fr;
    }
}

/* ============================================================
   TGMCA — Premium interactions support
   ============================================================ */

/* Top scroll progress bar */
.tgmca-scroll-progress {
    position: fixed;
    top: 0;
    left: 0;
    height: 3px;
    width: 0;
    background: var(--base-color);
    z-index: 9999;
    pointer-events: none;
    box-shadow: 0 0 12px rgba(58, 166, 224, 0.45);
    transition: width 60ms linear;
}

/* Magnetic CTA — smooth return when cursor leaves */
[data-tgmca-magnetic] {
    transition: transform 0.45s cubic-bezier(0.22, 1, 0.36, 1);
    will-change: transform;
}

/* 3D tilt — needs transform-style for child preservation */
[data-tgmca-tilt] {
    transform-style: preserve-3d;
    transition: transform 0.5s cubic-bezier(0.22, 1, 0.36, 1), box-shadow 0.4s ease, border-color 0.4s ease;
    will-change: transform;
}

[data-tgmca-tilt]:hover {
    box-shadow: 0 28px 60px -25px rgba(31, 41, 55, 0.28);
}

/* Inner card content lifts on tilt for depth */
[data-tgmca-tilt] > * {
    transform: translateZ(0);
}

/* Word-by-word heading reveal */
[data-tgmca-words] .tgmca-word {
    display: inline-block;
    overflow: hidden;
    vertical-align: top;
    line-height: 1.1;
    padding-bottom: 0.08em;
}

[data-tgmca-words] .tgmca-word-inner {
    display: inline-block;
    transform: translateY(115%);
    transition: transform 0.85s cubic-bezier(0.22, 1, 0.36, 1);
}

[data-tgmca-words].tgmca-words-visible .tgmca-word-inner {
    transform: translateY(0);
}

/* Parallax wrapper — give browser a hint */
[data-tgmca-parallax] {
    will-change: transform;
}

/* Hover-glow on partner index badge (it is also a magnet) */
[data-tgmca-magnetic].partner-index-badge {
    transition: transform 0.45s cubic-bezier(0.22, 1, 0.36, 1),
                background 0.3s ease, color 0.3s ease;
}

[data-tgmca-magnetic].partner-index-badge:hover {
    background: var(--base-color);
    color: #fff;
}

/* Mood: keep for future section colour shifts */
[data-tgmca-mood] {
    transition: background 0.6s ease;
}

/* Marquee — infinite-scrolling editorial strip between sections */
.tgmca-marquee {
    display: flex;
    overflow: hidden;
    padding: 26px 0;
    background: var(--dark-gray);
    border-top: 1px solid rgba(255, 255, 255, 0.08);
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

.tgmca-marquee-track {
    display: flex;
    gap: 60px;
    animation: tgmca-marquee 32s linear infinite;
    white-space: nowrap;
    flex-shrink: 0;
    align-items: center;
    padding-right: 60px;
}

.tgmca-marquee-item {
    font-family: 'cerebri-sans-bold';
    font-size: 30px;
    text-transform: uppercase;
    letter-spacing: 1.5px;
    color: rgba(255, 255, 255, 0.85);
    display: inline-flex;
    align-items: center;
    gap: 60px;
    flex-shrink: 0;
}

.tgmca-marquee-item::after {
    content: "✦";
    color: var(--accent-mint);
    font-size: 22px;
    margin-left: 60px;
}

@keyframes tgmca-marquee {
    from { transform: translateX(0); }
    to   { transform: translateX(-50%); }
}

@media (max-width: 575px) {
    .tgmca-marquee-item {
        font-size: 22px;
        gap: 40px;
    }
    .tgmca-marquee-item::after {
        margin-left: 40px;
        font-size: 18px;
    }
}

/* Smooth-scroll site-wide for anchor links */
html {
    scroll-behavior: smooth;
}

@media (prefers-reduced-motion: reduce) {
    html { scroll-behavior: auto; }
    .tgmca-scroll-progress { display: none !important; }
    [data-tgmca-magnetic],
    [data-tgmca-tilt],
    [data-tgmca-parallax] {
        transform: none !important;
    }
    [data-tgmca-words] .tgmca-word-inner {
        transform: none !important;
        transition: none !important;
    }
    .tgmca-marquee-track {
        animation: none !important;
    }
}

/* ============================================================
   Founding Partners — premium editorial split layout
   ============================================================ */

.tgmca-partner-section {
    padding: 100px 0;
    background: #fff;
}

.tgmca-partner-row {
    display: grid;
    grid-template-columns: 5fr 6fr;
    gap: 70px;
    align-items: center;
    margin-bottom: 100px;
}

.tgmca-partner-row:last-child {
    margin-bottom: 0;
}

.tgmca-partner-row.reverse {
    grid-template-columns: 6fr 5fr;
}

.tgmca-partner-row.reverse .partner-img-col {
    order: 2;
}

.tgmca-partner-row.reverse .partner-bio-col {
    order: 1;
}

/* Image column */
.partner-img-col {
    position: relative;
}

.partner-img-frame {
    position: relative;
    overflow: hidden;
    border-radius: 4px;
    aspect-ratio: 3 / 4;
    background: var(--very-light-gray);
}

.partner-img-frame img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center top;
    display: block;
    transition: transform 0.75s cubic-bezier(0.22, 1, 0.36, 1);
}

.tgmca-partner-row:hover .partner-img-frame img {
    transform: scale(1.04);
}

/* Accent line — grows down from top on row hover */
.partner-img-frame::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 3px;
    height: 0;
    background: var(--base-color);
    z-index: 2;
    transition: height 0.6s cubic-bezier(0.22, 1, 0.36, 1);
}

.tgmca-partner-row:hover .partner-img-frame::before {
    height: 100%;
}

/* Thin top rule above image */
.partner-img-frame::after {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 0;
    height: 2px;
    background: var(--dark-gray);
    z-index: 2;
    transition: width 0.5s cubic-bezier(0.22, 1, 0.36, 1);
}

.tgmca-partner-row:hover .partner-img-frame::after {
    width: 100%;
}

/* Partner index badge — floating dark circle */
.partner-index-badge {
    position: absolute;
    bottom: -22px;
    right: -22px;
    width: 76px;
    height: 76px;
    background: var(--dark-gray);
    border: 3px solid #fff;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: 'cerebri-sans-bold';
    font-size: 12px;
    letter-spacing: 2px;
    color: var(--accent-mint);
    z-index: 3;
}

/* Bio column */
.partner-bio-col {
    padding: 10px 0;
}

.partner-eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 14px;
    font-family: 'cerebri-sans-bold';
    font-size: 11px;
    letter-spacing: 2.4px;
    text-transform: uppercase;
    color: var(--base-color);
    margin-bottom: 18px;
}

.partner-eyebrow::before {
    content: "";
    width: 28px;
    height: 1px;
    background: var(--base-color);
}

.partner-name {
    font-family: 'cerebri-sans-bold';
    color: var(--dark-gray);
    font-size: 52px;
    line-height: 1.05;
    letter-spacing: -2.5px;
    margin-bottom: 10px;
}

.partner-role {
    display: block;
    font-family: 'cerebri-sans-bold';
    color: var(--medium-gray);
    font-size: 12px;
    letter-spacing: 1.8px;
    text-transform: uppercase;
    margin-bottom: 30px;
}

.partner-credentials {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: 32px;
}

.partner-cred-tag {
    display: inline-block;
    font-family: 'cerebri-sans-bold';
    font-size: 10px;
    letter-spacing: 1.4px;
    text-transform: uppercase;
    color: var(--dark-gray);
    padding: 6px 14px;
    border: 1px solid rgba(31, 41, 55, 0.18);
    border-radius: 2px;
    transition: background 0.2s ease, color 0.2s ease, border-color 0.2s ease;
}

.tgmca-partner-row:hover .partner-cred-tag {
    border-color: var(--base-color);
    color: var(--base-color);
}

.partner-rule {
    width: 48px;
    height: 1px;
    background: var(--dark-gray);
    display: block;
    margin-bottom: 28px;
    transition: width 0.5s cubic-bezier(0.22, 1, 0.36, 1), background 0.3s ease;
}

.tgmca-partner-row:hover .partner-rule {
    width: 100px;
    background: var(--base-color);
}

.partner-bio {
    font-family: Georgia, "Times New Roman", serif;
    font-style: italic;
    color: var(--dark-gray);
    font-size: 18px;
    line-height: 1.7;
    padding-left: 22px;
    border-left: 2px solid var(--base-color);
    margin-bottom: 36px;
    letter-spacing: -0.2px;
}

.partner-link {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    font-family: 'cerebri-sans-bold';
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 2px;
    color: var(--dark-gray);
    text-decoration: none;
    padding-bottom: 4px;
    border-bottom: 1px solid rgba(31, 41, 55, 0.3);
    transition: color 0.2s ease, border-color 0.2s ease;
}

.partner-link:hover {
    color: var(--base-color);
    border-color: var(--base-color);
}

.partner-link i {
    font-size: 14px;
    transition: transform 0.25s ease;
}

.partner-link:hover i {
    transform: translateX(3px);
}

@media (max-width: 991px) {
    .tgmca-partner-section {
        padding: 70px 0;
    }
    .tgmca-partner-row {
        grid-template-columns: 1fr;
        gap: 36px;
        margin-bottom: 70px;
    }
    .tgmca-partner-row.reverse .partner-img-col,
    .tgmca-partner-row.reverse .partner-bio-col {
        order: unset;
    }
    .partner-name {
        font-size: 40px;
        letter-spacing: -1.5px;
    }
    .partner-img-frame {
        aspect-ratio: 4 / 3;
    }
    .partner-index-badge {
        bottom: -14px;
        right: -10px;
        width: 60px;
        height: 60px;
        font-size: 11px;
    }
}

@media (max-width: 575px) {
    .tgmca-partner-section {
        padding: 50px 0;
    }
    .partner-name {
        font-size: 32px;
        letter-spacing: -1px;
    }
    .partner-img-frame {
        aspect-ratio: 1 / 1;
    }
    .partner-bio {
        font-size: 16px;
    }
}

/* ============================================================
   TGMCA — Scroll Reveal Animation System
   ============================================================ */

/* Base hidden state for reveal elements */
[data-tgmca-reveal] {
    opacity: 0;
    will-change: opacity, transform;
    transition: opacity 0.85s cubic-bezier(0.22, 1, 0.36, 1),
                transform 0.85s cubic-bezier(0.22, 1, 0.36, 1);
}

/* Direction variants */
[data-tgmca-reveal="up"]    { transform: translateY(48px); }
[data-tgmca-reveal="down"]  { transform: translateY(-28px); }
[data-tgmca-reveal="left"]  { transform: translateX(-56px); }
[data-tgmca-reveal="right"] { transform: translateX(56px); }
[data-tgmca-reveal="scale"] { transform: scale(0.88); opacity: 0; }
[data-tgmca-reveal="fade"]  { transform: none; }

/* Triggered: element enters viewport */
[data-tgmca-reveal].tgmca-visible {
    opacity: 1 !important;
    transform: none !important;
}

/* Optional delay modifiers */
[data-tgmca-delay="100"] { transition-delay: 100ms !important; }
[data-tgmca-delay="200"] { transition-delay: 200ms !important; }
[data-tgmca-delay="300"] { transition-delay: 300ms !important; }
[data-tgmca-delay="400"] { transition-delay: 400ms !important; }
[data-tgmca-delay="500"] { transition-delay: 500ms !important; }
[data-tgmca-delay="600"] { transition-delay: 600ms !important; }

/* Stagger parent: children animate in sequence on enter */
[data-tgmca-stagger] > * {
    opacity: 0;
    transform: translateY(32px);
    transition: opacity 0.7s cubic-bezier(0.22, 1, 0.36, 1),
                transform 0.7s cubic-bezier(0.22, 1, 0.36, 1);
}

[data-tgmca-stagger].tgmca-visible > * {
    opacity: 1;
    transform: none;
}

/* Stagger timing cascade */
[data-tgmca-stagger].tgmca-visible > *:nth-child(1)  { transition-delay:   0ms; }
[data-tgmca-stagger].tgmca-visible > *:nth-child(2)  { transition-delay:  85ms; }
[data-tgmca-stagger].tgmca-visible > *:nth-child(3)  { transition-delay: 170ms; }
[data-tgmca-stagger].tgmca-visible > *:nth-child(4)  { transition-delay: 255ms; }
[data-tgmca-stagger].tgmca-visible > *:nth-child(5)  { transition-delay: 340ms; }
[data-tgmca-stagger].tgmca-visible > *:nth-child(6)  { transition-delay: 425ms; }
[data-tgmca-stagger].tgmca-visible > *:nth-child(7)  { transition-delay: 510ms; }
[data-tgmca-stagger].tgmca-visible > *:nth-child(8)  { transition-delay: 595ms; }
[data-tgmca-stagger].tgmca-visible > *:nth-child(9)  { transition-delay: 680ms; }
[data-tgmca-stagger].tgmca-visible > *:nth-child(10) { transition-delay: 765ms; }
[data-tgmca-stagger].tgmca-visible > *:nth-child(11) { transition-delay: 850ms; }
[data-tgmca-stagger].tgmca-visible > *:nth-child(12) { transition-delay: 935ms; }

/* Section head: eyebrow → heading → paragraph cascade */
.tgmca-section-head[data-tgmca-reveal] {
    opacity: 1 !important;
    transform: none !important;
}

.tgmca-section-head[data-tgmca-reveal] .eyebrow,
.tgmca-section-head[data-tgmca-reveal] h3,
.tgmca-section-head[data-tgmca-reveal] p {
    opacity: 0;
    transform: translateY(28px);
    transition: opacity 0.75s cubic-bezier(0.22, 1, 0.36, 1),
                transform 0.75s cubic-bezier(0.22, 1, 0.36, 1);
}

.tgmca-section-head[data-tgmca-reveal].tgmca-visible .eyebrow {
    opacity: 1;
    transform: none;
    transition-delay: 0ms;
}

.tgmca-section-head[data-tgmca-reveal].tgmca-visible h3 {
    opacity: 1;
    transform: none;
    transition-delay: 130ms;
}

.tgmca-section-head[data-tgmca-reveal].tgmca-visible p {
    opacity: 1;
    transform: none;
    transition-delay: 260ms;
}

/* Stats strip: stat items enter with count-up feel */
@keyframes tgmca-stat-enter {
    from { opacity: 0; transform: translateY(28px); }
    to   { opacity: 1; transform: none; }
}

.tgmca-stats-strip[data-tgmca-anim] .stat-item {
    opacity: 0;
}

.tgmca-stats-strip[data-tgmca-anim].tgmca-visible .stat-item {
    animation: tgmca-stat-enter 0.75s cubic-bezier(0.22, 1, 0.36, 1) both;
}

.tgmca-stats-strip[data-tgmca-anim].tgmca-visible .stat-item:nth-child(1) { animation-delay:   0ms; }
.tgmca-stats-strip[data-tgmca-anim].tgmca-visible .stat-item:nth-child(2) { animation-delay: 130ms; }
.tgmca-stats-strip[data-tgmca-anim].tgmca-visible .stat-item:nth-child(3) { animation-delay: 260ms; }
.tgmca-stats-strip[data-tgmca-anim].tgmca-visible .stat-item:nth-child(4) { animation-delay: 390ms; }

/* Approach card horizontal line: grow in after card enters */
.tgmca-approach-grid[data-tgmca-stagger].tgmca-visible .approach-card .approach-icon {
    animation: tgmca-line-grow 0.9s cubic-bezier(0.22, 1, 0.36, 1) forwards;
}

.tgmca-approach-grid[data-tgmca-stagger].tgmca-visible .approach-card:nth-child(1) .approach-icon { animation-delay: 170ms; }
.tgmca-approach-grid[data-tgmca-stagger].tgmca-visible .approach-card:nth-child(2) .approach-icon { animation-delay: 300ms; }
.tgmca-approach-grid[data-tgmca-stagger].tgmca-visible .approach-card:nth-child(3) .approach-icon { animation-delay: 430ms; }

@keyframes tgmca-line-grow {
    from { width: 0; opacity: 0; }
    to   { width: 48px; opacity: 1; }
}

/* Service & testimonial card top-line: grow from left on enter */
.tgmca-services-grid[data-tgmca-stagger].tgmca-visible .service-card::before,
.tgmca-testimonials[data-tgmca-stagger].tgmca-visible .testimonial-card::before,
.tgmca-mvv[data-tgmca-stagger].tgmca-visible .mvv-card::after {
    animation: tgmca-topline-grow 0.8s cubic-bezier(0.22, 1, 0.36, 1) forwards;
}

@keyframes tgmca-topline-grow {
    from { width: 0; }
    to   { width: 60px; }
}

/* Industries grid: fade + subtle scale */
.tgmca-industries[data-tgmca-stagger] > * {
    transform: scale(0.94) translateY(16px);
}

.tgmca-industries[data-tgmca-stagger].tgmca-visible > * {
    transform: none;
}

/* Process strip: slide up stagger */
.tgmca-process-strip[data-tgmca-stagger] > .process-step {
    opacity: 0;
    transform: translateY(36px);
    transition: opacity 0.65s cubic-bezier(0.22, 1, 0.36, 1),
                transform 0.65s cubic-bezier(0.22, 1, 0.36, 1);
}

.tgmca-process-strip[data-tgmca-stagger].tgmca-visible > .process-step {
    opacity: 1;
    transform: none;
}

/* Sidebar reveal from right */
.tgmca-service-sidebar[data-tgmca-reveal="right"] {
    transform: translateX(40px);
    opacity: 0;
    transition: opacity 0.9s cubic-bezier(0.22, 1, 0.36, 1),
                transform 0.9s cubic-bezier(0.22, 1, 0.36, 1);
    transition-delay: 200ms;
}

.tgmca-service-sidebar[data-tgmca-reveal="right"].tgmca-visible {
    opacity: 1;
    transform: none;
}

/* Respect user motion preference */
@media (prefers-reduced-motion: reduce) {
    [data-tgmca-reveal],
    [data-tgmca-stagger] > *,
    .tgmca-section-head[data-tgmca-reveal] .eyebrow,
    .tgmca-section-head[data-tgmca-reveal] h3,
    .tgmca-section-head[data-tgmca-reveal] p,
    .tgmca-stats-strip[data-tgmca-anim] .stat-item,
    .tgmca-service-sidebar[data-tgmca-reveal="right"] {
        opacity: 1 !important;
        transform: none !important;
        transition: none !important;
        animation: none !important;
    }
}

/* ============================================================
   TGMCA — About Page: Editorial Intro
   ============================================================ */

.tgmca-about-intro {
    padding: 80px 0 70px;
    background: #fff;
}

.tgmca-about-intro-eyebrow {
    font-family: 'cerebri-sans-bold', sans-serif;
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 3px;
    color: var(--base-color);
    display: inline-flex;
    align-items: center;
    gap: 14px;
    margin-bottom: 28px;
}

.tgmca-about-intro-eyebrow::after {
    content: '';
    display: block;
    width: 36px;
    height: 1px;
    background: var(--base-color);
}

.tgmca-about-headline {
    font-size: clamp(34px, 5vw, 64px);
    font-weight: 800;
    line-height: 1.05;
    letter-spacing: -2.5px;
    color: var(--dark-gray);
    margin: 0 0 36px;
    max-width: 860px;
}

.tgmca-about-intro-rule {
    width: 100%;
    height: 1px;
    background: rgba(31, 41, 55, 0.1);
    margin: 0 0 50px;
}

.tgmca-about-body-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 64px;
    align-items: start;
}

.tgmca-about-lead-text {
    font-size: 17px;
    line-height: 1.8;
    color: rgba(31, 41, 55, 0.68);
    margin-bottom: 20px;
}

.tgmca-about-year-badge {
    font-family: Georgia, 'Times New Roman', serif;
    font-size: clamp(80px, 10vw, 130px);
    font-weight: 700;
    line-height: 1;
    letter-spacing: -6px;
    color: transparent;
    -webkit-text-stroke: 1px rgba(58, 166, 224, 0.22);
    text-stroke: 1px rgba(58, 166, 224, 0.22);
    margin-bottom: 4px;
    display: block;
    user-select: none;
}

.tgmca-about-found-label {
    font-family: 'cerebri-sans-bold', sans-serif;
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 2.5px;
    color: rgba(31, 41, 55, 0.4);
    display: block;
    margin-bottom: 32px;
}

.tgmca-about-mini-stats {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 24px 32px;
    border-top: 1px solid rgba(31, 41, 55, 0.1);
    padding-top: 28px;
}

.tgmca-about-mini-stat .stat-val {
    font-family: 'cerebri-sans-bold', sans-serif;
    font-size: 38px;
    font-weight: 800;
    letter-spacing: -2px;
    color: var(--dark-gray);
    line-height: 1;
    display: block;
    margin-bottom: 5px;
}

.tgmca-about-mini-stat .stat-val sup {
    font-size: 17px;
    color: var(--base-color);
    vertical-align: super;
}

.tgmca-about-mini-stat .stat-lbl {
    font-size: 11px;
    color: rgba(31, 41, 55, 0.5);
    text-transform: uppercase;
    letter-spacing: 1px;
    font-weight: 600;
}

.tgmca-about-img-strip {
    display: grid;
    grid-template-columns: 1.45fr 1fr;
    gap: 14px;
    margin-top: 56px;
}

.tgmca-about-img-strip img {
    width: 100%;
    object-fit: cover;
    border-radius: 8px;
    display: block;
}

.tgmca-about-img-strip img:first-child { height: 360px; }
.tgmca-about-img-strip img:last-child  { height: 270px; align-self: end; }

@media (max-width: 991px) {
    .tgmca-about-body-grid {
        grid-template-columns: 1fr;
        gap: 40px;
    }
    .tgmca-about-img-strip {
        grid-template-columns: 1fr 1fr;
    }
    .tgmca-about-img-strip img:first-child,
    .tgmca-about-img-strip img:last-child {
        height: 240px;
        align-self: unset;
    }
}

@media (max-width: 575px) {
    .tgmca-about-intro { padding: 55px 0 45px; }
    .tgmca-about-img-strip { display: none; }
    .tgmca-about-mini-stats { gap: 18px 20px; }
    .tgmca-about-mini-stat .stat-val { font-size: 30px; }
}

/* ============================================================
   TGMCA — Contact Page: Premium Layout
   ============================================================ */

.tgmca-contact-section {
    padding: 90px 0 80px;
    background: #fff;
}

.tgmca-contact-split {
    display: grid;
    grid-template-columns: 1fr 1.35fr;
    gap: 80px;
    align-items: start;
}

/* Info column */
.tgmca-contact-info-eyebrow {
    font-family: 'cerebri-sans-bold', sans-serif;
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 3px;
    color: var(--base-color);
    display: inline-flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 24px;
}

.tgmca-contact-info-eyebrow::before {
    content: '';
    display: block;
    width: 30px;
    height: 1px;
    background: var(--base-color);
}

.tgmca-contact-info-headline {
    font-size: clamp(28px, 4vw, 48px);
    font-weight: 800;
    letter-spacing: -2px;
    line-height: 1.1;
    color: var(--dark-gray);
    margin-bottom: 18px;
}

.tgmca-contact-info-lead {
    font-size: 16px;
    line-height: 1.75;
    color: rgba(31, 41, 55, 0.62);
    margin-bottom: 40px;
}

.tgmca-contact-card {
    border: 1px solid rgba(31, 41, 55, 0.1);
    border-radius: 8px;
    padding: 24px 26px;
    margin-bottom: 14px;
    background: #fff;
    display: flex;
    gap: 20px;
    align-items: flex-start;
    transition: border-color 0.25s ease, box-shadow 0.25s ease, transform 0.25s ease;
    position: relative;
    overflow: hidden;
}

.tgmca-contact-card::before {
    content: '';
    position: absolute;
    left: 0; top: 0; bottom: 0;
    width: 3px;
    background: var(--base-color);
    transform: scaleY(0);
    transform-origin: bottom;
    transition: transform 0.32s cubic-bezier(0.22, 1, 0.36, 1);
}

.tgmca-contact-card:hover {
    border-color: rgba(58, 166, 224, 0.2);
    box-shadow: 0 8px 28px rgba(58, 166, 224, 0.07);
    transform: translateY(-2px);
}

.tgmca-contact-card:hover::before { transform: scaleY(1); }

.tgmca-contact-card-icon {
    width: 42px;
    height: 42px;
    border-radius: 50%;
    background: var(--accent-mint);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.tgmca-contact-card-icon i {
    font-size: 16px;
    color: var(--base-color);
}

.tgmca-contact-card-label {
    font-family: 'cerebri-sans-bold', sans-serif;
    font-size: 10px;
    text-transform: uppercase;
    letter-spacing: 2px;
    color: rgba(31, 41, 55, 0.38);
    display: block;
    margin-bottom: 5px;
}

.tgmca-contact-card-value {
    font-size: 16px;
    font-weight: 600;
    color: var(--dark-gray);
    line-height: 1.5;
}

.tgmca-contact-card-value a {
    color: var(--dark-gray);
    text-decoration: none;
    transition: color 0.2s ease;
}

.tgmca-contact-card-value a:hover { color: var(--base-color); }

.tgmca-contact-hours {
    display: flex;
    gap: 12px;
    align-items: center;
    padding: 18px 0;
    margin-top: 4px;
    border-top: 1px solid rgba(31, 41, 55, 0.08);
}

.tgmca-contact-hours-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: var(--base-color);
    flex-shrink: 0;
    animation: tgmca-pulse-dot 2.2s ease-in-out infinite;
}

@keyframes tgmca-pulse-dot {
    0%, 100% { opacity: 1; transform: scale(1); }
    50% { opacity: 0.45; transform: scale(1.5); }
}

.tgmca-contact-hours-text {
    font-size: 13px;
    color: rgba(31, 41, 55, 0.52);
    line-height: 1.5;
}

.tgmca-contact-hours-text strong { color: var(--dark-gray); }

.tgmca-contact-office-img {
    width: 100%;
    height: 210px;
    object-fit: cover;
    border-radius: 8px;
    margin-top: 22px;
    display: block;
}

/* Form column */
.tgmca-contact-form-col {
    position: sticky;
    top: 110px;
}

.tgmca-contact-form-wrap {
    background: var(--very-light-gray);
    border-radius: 12px;
    padding: 48px 42px;
    border: 1px solid rgba(31, 41, 55, 0.07);
}

.tgmca-contact-form-wrap h3 {
    font-size: 26px;
    font-weight: 700;
    letter-spacing: -0.8px;
    color: var(--dark-gray);
    margin-bottom: 6px;
}

.tgmca-contact-form-subhead {
    font-size: 15px;
    color: rgba(31, 41, 55, 0.52);
    display: block;
    margin-bottom: 32px;
}

.tgmca-contact-form-wrap .form-control {
    background: #fff;
    border: 1px solid rgba(31, 41, 55, 0.12);
    border-radius: 6px;
    padding: 13px 16px;
    font-size: 15px;
    color: var(--dark-gray);
    width: 100%;
    outline: none;
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.tgmca-contact-form-wrap .form-control:focus {
    border-color: var(--base-color);
    box-shadow: 0 0 0 3px rgba(58, 166, 224, 0.1);
}

.tgmca-contact-form-wrap .form-control::placeholder {
    color: rgba(31, 41, 55, 0.35);
}

.tgmca-contact-form-wrap textarea.form-control {
    resize: none;
    min-height: 110px;
}

.tgmca-form-row-2 {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 14px;
    margin-bottom: 14px;
}

.tgmca-form-field { margin-bottom: 14px; }

.tgmca-form-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    margin-top: 6px;
}

.tgmca-form-privacy {
    font-size: 12.5px;
    color: rgba(31, 41, 55, 0.42);
    line-height: 1.5;
    flex: 1;
}

.tgmca-contact-submit-btn {
    display: inline-flex;
    align-items: center;
    gap: 9px;
    background: var(--base-color);
    color: #fff;
    border: none;
    border-radius: 50px;
    padding: 13px 26px;
    font-family: 'cerebri-sans-bold', sans-serif;
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: 1.5px;
    cursor: pointer;
    white-space: nowrap;
    transition: background 0.2s ease, transform 0.2s ease, box-shadow 0.2s ease;
}

.tgmca-contact-submit-btn:hover {
    background: #047857;
    transform: translateY(-2px);
    box-shadow: 0 8px 22px rgba(58, 166, 224, 0.28);
}

.tgmca-contact-submit-btn i {
    font-size: 15px;
    transition: transform 0.2s ease;
}

.tgmca-contact-submit-btn:hover i { transform: translateX(2px); }

@media (max-width: 991px) {
    .tgmca-contact-split {
        grid-template-columns: 1fr;
        gap: 48px;
    }
    .tgmca-contact-form-col { position: static; }
    .tgmca-contact-form-wrap { padding: 34px 28px; }
}

@media (max-width: 575px) {
    .tgmca-contact-section { padding: 55px 0 50px; }
    .tgmca-form-row-2 { grid-template-columns: 1fr; }
    .tgmca-form-footer { flex-direction: column; align-items: flex-start; }
    .tgmca-contact-submit-btn { width: 100%; justify-content: center; }
    .tgmca-contact-form-wrap { padding: 26px 18px; }
}

/* Uniform sizing for home service cards (mixed portrait/landscape source images) */
.interactive-banner-style-08 > figure {
    width: 100%;
}
.interactive-banner-style-08 > figure > a {
    display: block;
    width: 100%;
    aspect-ratio: 4 / 5;
    overflow: hidden;
}
.interactive-banner-style-08 > figure > a > img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}