/*
Theme Name: Take Charge Lab (Custom)
Author: Ryan Little
Version: 1.0.0
Text Domain: Take Charge Lab
*/

/* =========================================================
   FOUNDATION / DESIGN TOKENS
========================================================= */

:root {
    color-scheme: light;

    /* Brand */
    --c-navy: #0f2a72;
    --c-red: #ca181e;
    --c-ink: #0c2039;
    --c-blue: #0a57e8;
    --c-blue2: #0b64ff;

    --primary: #017bff;
    --primary-hover: #0f2a72;
    --primary-contrast: #ffffff;

    --grad: linear-gradient(
            90deg,
            var(--c-blue) 0%,
            var(--c-red) 100%
    );

    /* Typography */
    --font-sans:
            "Inter",
            system-ui,
            -apple-system,
            "Segoe UI",
            Roboto,
            Arial,
            sans-serif;

    /* Motion */
    --ease: cubic-bezier(.2, .8, .2, 1);

    /* Accessibility */
    --focus: #ffd54a;

    /* Layout */
    --radius: 1.25rem;
    --navH: 104px;

    /* Shadows */
    --shadowLight: 0 16px 50px rgba(12, 32, 57, .12);
    --shadowDark: 0 22px 70px rgba(0, 0, 0, .35);

    /* Light theme defaults */
    --bg: #f6f8ff;
    --surface: #ffffff;
    --alt: rgba(12, 32, 57, .04);
    --border: rgba(12, 32, 57, .14);

    --text: #0c2039;
    --muted: rgba(12, 32, 57, .78);

    --shadow: var(--shadowLight);

    --heroOverlay: linear-gradient(
            90deg,
            rgba(12, 32, 57, .84) 0%,
            rgba(12, 32, 57, .55) 55%,
            rgba(12, 32, 57, .22) 100%
    );

    /* Footer */
    --footer-grad: linear-gradient(
            90deg,
            #062a5a 0%,
            #6d0c0f 100%
    );

    --footer-overlay:
            radial-gradient(
                    circle at 20% 10%,
                    rgba(255,255,255,.12),
                    transparent 45%
            ),
            radial-gradient(
                    circle at 80% 30%,
                    rgba(255,255,255,.06),
                    transparent 55%
            );

    --footer-text: rgba(255,255,255,.92);
    --footer-muted: rgba(255,255,255,.78);
    --footer-border: rgba(255,255,255,.18);
    --footer-chip-bg: rgba(255,255,255,.10);
    --footer-chip-border: rgba(255,255,255,.18);

    /* Buttons */
    --btn-pill-bg: var(--c-blue2);
    --btn-pill-bg-hover: color-mix(
            in srgb,
            var(--c-blue2) 82%,
            #000
    );

    --btn-pill-text: #ffffff;

    --btn-pill-shadow:
            0 10px 24px rgba(0,0,0,.10);

    --btn-pill-shadow-hover:
            0 14px 30px rgba(0,0,0,.14);
}

/* =========================================================
   DARK THEME
========================================================= */

:root[data-theme="dark"] {
    color-scheme: dark;

    --bg: #070b12;
    --surface: rgba(255,255,255,.06);
    --alt: rgba(255,255,255,.04);
    --border: rgba(255,255,255,.16);

    --text: #ffffff;
    --muted: rgba(255,255,255,.82);

    --shadow: var(--shadowDark);

    --heroOverlay: linear-gradient(
            90deg,
            rgba(0,0,0,.78) 0%,
            rgba(0,0,0,.55) 55%,
            rgba(0,0,0,.30) 100%
    );

    --footer-grad: linear-gradient(
            90deg,
            #041b3d 0%,
            #4f070a 100%
    );

    --footer-overlay:
            radial-gradient(
                    circle at 20% 10%,
                    rgba(255,255,255,.10),
                    transparent 45%
            ),
            radial-gradient(
                    circle at 80% 30%,
                    rgba(255,255,255,.04),
                    transparent 55%
            );

    --footer-text: rgba(255,255,255,.92);
    --footer-muted: rgba(255,255,255,.78);
    --footer-border: rgba(255,255,255,.16);
    --footer-chip-bg: rgba(255,255,255,.08);
    --footer-chip-border: rgba(255,255,255,.14);

    --primary: #2f8bff;
    --primary-hover: #5aa6ff;
    --primary-contrast: #0b1324;
}

/* =========================================================
   SYSTEM DARK MODE (when user hasn't manually chosen)
========================================================= */

@media (prefers-color-scheme: dark) {
    :root:not([data-theme]) {
        color-scheme: dark;

        --bg: #070b12;
        --surface: rgba(255,255,255,.06);
        --alt: rgba(255,255,255,.04);
        --border: rgba(255,255,255,.16);

        --text: #ffffff;
        --muted: rgba(255,255,255,.82);

        --shadow: var(--shadowDark);

        --heroOverlay: linear-gradient(
                90deg,
                rgba(0,0,0,.78) 0%,
                rgba(0,0,0,.55) 55%,
                rgba(0,0,0,.30) 100%
        );

        --footer-grad: linear-gradient(
                90deg,
                #041b3d 0%,
                #4f070a 100%
        );

        --footer-overlay:
                radial-gradient(
                        circle at 20% 10%,
                        rgba(255,255,255,.10),
                        transparent 45%
                ),
                radial-gradient(
                        circle at 80% 30%,
                        rgba(255,255,255,.04),
                        transparent 55%
                );

        --footer-text: rgba(255,255,255,.92);
        --footer-muted: rgba(255,255,255,.78);
        --footer-border: rgba(255,255,255,.16);
        --footer-chip-bg: rgba(255,255,255,.08);
        --footer-chip-border: rgba(255,255,255,.14);
    }
}

/* =========================================================
   RESPONSIVE TOKENS
========================================================= */

@media (max-width: 991.98px) {
    :root {
        --navH: 96px;
    }
}

/* =========================================================
   GLOBAL TYPOGRAPHY
========================================================= */

.entry-content a[href^="mailto:"],
.tcl-core-content a[href^="mailto:"],
.post-content a[href^="mailto:"] {
    color: var(--primary);
    font-weight: 600;
    text-decoration: underline;
}

.entry-content a[href^="mailto:"]:hover,
.tcl-core-content a[href^="mailto:"]:hover,
.post-content a[href^="mailto:"]:hover {
    color: #1d4ed8;
}

.tcl-learning .tcl-title {
    color: var(--text);
}

.entry-content ul,
.entry-content ol,
.tcl-prose ul,
.tcl-prose ol,
.tcl-pressProse ul,
.tcl-pressProse ol,
.tcl-legalProse ul,
.tcl-legalProse ol {
    font-size: 1.02rem;
    line-height: 1.75;
    color: var(--text);
    margin-bottom: 1.5rem;
    padding-left: 1.5rem;
}

.entry-content li,
.tcl-prose li,
.tcl-pressProse li,
.tcl-legalProse li {
    font-size: inherit;
    line-height: inherit;
    color: inherit;
    margin-bottom: .45rem;
}

/* ==========================================
   Standard Inner Page Hero
========================================== */

.tcl-standard-hero {
    position: relative;
    width: 100%;
    overflow: hidden;

    /* pull hero under fixed nav */
    margin-top: calc(var(--navH) * -1);
    padding-top: var(--navH);

    background:
            linear-gradient(
                    135deg,
                    #0f4fbf 0%,
                    #1e3a8a 35%,
                    #4c1d95 68%,
                    #b91c1c 100%
            );
}

.tcl-standard-hero::before {
    content: "";
    position: absolute;
    inset: 0;

    background-image:
            radial-gradient(
                    rgba(255,255,255,.05) 1px,
                    transparent 1px
            );

    background-size: 36px 36px;
    opacity: .5;
    pointer-events: none;
}

.tcl-standard-hero::after {
    content: "";
    position: absolute;
    inset: 0;

    background:
            linear-gradient(
                    to bottom,
                    rgba(255,255,255,.06),
                    rgba(15,23,42,.4)
            );

    pointer-events: none;
}

.tcl-standard-hero__inner {
    position: relative;
    z-index: 2;

    min-height: clamp(260px, 28vw, 420px);

    display: flex;
    align-items: flex-end;

    padding:
            clamp(3rem, 6vw, 6rem)
            0
            clamp(2.5rem, 5vw, 4rem);
}

.tcl-standard-hero__eyebrow {
    color: rgba(255,255,255,.82);
    font-size: .9rem;
    text-transform: uppercase;
    letter-spacing: .14em;
    font-weight: 700;
    margin-bottom: 1rem;
}

.tcl-standard-hero__title {
    color: #fff;
    font-size: clamp(2.25rem, 5vw, 4.75rem);
    font-weight: 800;
    line-height: 1.02;
    letter-spacing: -.03em;
    margin: 0;
    max-width: 900px;
}

/* ==========================================
   Standard Inner Page Hero
========================================== */

.tcl-standard-hero {
    position: relative;
    width: 100%;
    overflow: hidden;

    /* pull hero under fixed nav */
    margin-top: calc(var(--navH) * -1);
    padding-top: var(--navH);

    background:
            linear-gradient(
                    135deg,
                    #0f4fbf 0%,
                    #1e3a8a 35%,
                    #4c1d95 68%,
                    #b91c1c 100%
            );
}

.tcl-standard-hero::before {
    content: "";
    position: absolute;
    inset: 0;
    background-image:
            radial-gradient(
                    rgba(255,255,255,.05) 1px,
                    transparent 1px
            );
    background-size: 36px 36px;
    opacity: .5;
    pointer-events: none;
}

.tcl-standard-hero::after {
    content: "";
    position: absolute;
    inset: 0;
    background:
            linear-gradient(
                    to bottom,
                    rgba(255,255,255,.06),
                    rgba(15,23,42,.4)
            );
    pointer-events: none;
}

.tcl-standard-hero__inner {
    position: relative;
    z-index: 2;
    min-height: clamp(260px, 28vw, 420px);
    display: flex;
    align-items: flex-end;
    padding:
            clamp(3rem, 6vw, 6rem)
            0
            clamp(2.5rem, 5vw, 4rem);
}

.tcl-standard-hero__eyebrow {
    color: rgba(255,255,255,.82);
    font-size: .9rem;
    text-transform: uppercase;
    letter-spacing: .14em;
    font-weight: 700;
    margin-bottom: 1rem;
}

.tcl-standard-hero__title {
    color: #fff;
    font-size: clamp(2.25rem, 5vw, 4.75rem);
    font-weight: 800;
    line-height: 1.02;
    letter-spacing: -.03em;
    margin: 0;
    max-width: 900px;
}

/* ==========================================
   FIXED NAV HERO OFFSET (GLOBAL)
========================================== */

.tcl-core-hero,
.tcl-blog-hero,
.tcl-post-feature,
.tcl-testimonial-hero,
.tcl-press-hero {
    margin-top: calc(var(--navH) * -1);
    padding-top: var(--navH);
}

/* Page content */

.tcl-page-content {
    background: var(--bg);
}

/*.tcl-page-content .tcl-content {*/
/*    max-width: 980px;*/
/*    margin: 0 auto;*/
/*}*/

.tcl-page-content a[href^="mailto:"] {
    color: #2563eb;
    font-weight: 600;
}

.tcl-page-content a[href^="mailto:"]:hover {
    color: #1d4ed8;
}

/* ========== Base ========== */
html, body { height: 100%; }

img { max-width: 100%; height: auto; }
img, svg { vertical-align: middle; }

body {
    font-family: var(--font-sans);
    background: var(--bg);
    color: var(--text);
    font-size: 18px;
    line-height: 1.6;
    padding-top: var(--navH);
}
h1, h2, h3, h4, h5, h6,
.navbar, .btn, .tcl-title {
    font-family: var(--font-sans);
}

:focus-visible {
    outline: 3px solid var(--focus);
    outline-offset: 3px;
}

.skip-link{
    position:absolute; top:12px; left:12px; z-index:2000;
    padding:.6rem .9rem; border-radius:.5rem;
    background:#000; color:#fff;
    transform:translateY(-140%);
    transition:transform .2s var(--ease);
}
.skip-link:focus{ transform:translateY(0); }

/* Links */
.tcl-link{
    color: color-mix(in srgb, var(--c-blue2) 80%, var(--text));
    text-decoration: underline;
    text-underline-offset: .18em;
}
.tcl-link:hover{ filter: brightness(1.05); }

/* =========================================================
   NAVIGATION
========================================================= */

.navbar .navbar-brand {
    display: flex;
    align-items: center;
    gap: 12px;
    line-height: 1;
    padding: 0;
}

.navbar .navbar-brand img {
    width: auto;
    height: auto;
    object-fit: contain;
    max-height: 64px;
}

/* only visible logos should display */
.tcl-logo--light,
.tcl-logo--dark {
    display: none;
}

.tcl-logo--light {
    display: block;
}

:root[data-theme="dark"] .tcl-logo--light {
    display: none;
}

:root[data-theme="dark"] .tcl-logo--dark {
    display: block;
}

@media (prefers-color-scheme: dark) {
    :root:not([data-theme]) .tcl-logo--light {
        display: none;
    }

    :root:not([data-theme]) .tcl-logo--dark {
        display: block;
    }
}

@media (max-width: 991.98px) {
    .navbar .navbar-brand img,
    .tcl-logo {
        max-height: 56px;
    }

    .navbar .navbar-brand img.tcl-logo {
        height: 36px;
    }
}

.tcl-nav {
    background: rgba(246, 248, 255, .86);
    border-bottom: 1px solid var(--border);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
}

@supports (background: color-mix(in srgb, white 50%, transparent)) {
    .tcl-nav {
        background: color-mix(in srgb, var(--bg) 76%, transparent);
    }
}

:root[data-theme="dark"] .tcl-nav {
    background: rgba(7, 11, 18, .72);
}

@supports (background: color-mix(in srgb, white 50%, transparent)) {
    :root[data-theme="dark"] .tcl-nav {
        background: color-mix(in srgb, var(--bg) 76%, transparent);
    }
}

@media (prefers-color-scheme: dark) {
    :root:not([data-theme]) .tcl-nav {
        background: rgba(7, 11, 18, .72);
    }

    @supports (background: color-mix(in srgb, white 50%, transparent)) {
        :root:not([data-theme]) .tcl-nav {
            background: color-mix(in srgb, var(--bg) 76%, transparent);
        }
    }
}

.navbar .nav-link {
    font-size: .93rem;
    font-weight: 700;
    color: var(--muted);
    padding-top: .3rem;
    padding-bottom: .3rem;
    transition: color .2s ease;
}

.navbar .nav-link:hover {
    color: var(--text);
}

.navbar .dropdown-item {
    font-size: .93rem;
    padding-top: .4rem;
    padding-bottom: .4rem;
}

.navbar-toggler {
    padding: .35rem .5rem;
    border-color: var(--border);
}

@media (max-width: 991.98px) {
    .navbar .nav-link {
        padding: .5rem .65rem;
    }
}

/* =========================================================
   NAV CTA BUTTONS
========================================================= */

.tcl-nav .navbar-nav {
    align-items: center;
}

.tcl-nav-ctas {
    display: flex;
    gap: .5rem;
    align-items: center;
}

.tcl-nav-ctas .btn,
.tcl-btn-login,
.tcl-btn-register {
    min-height: 42px;
    padding: .72rem 1.15rem;
    font-size: .88rem;
    font-weight: 700;
    line-height: 1.1;
    border-radius: 999px;
    letter-spacing: .01em;
    box-shadow: var(--btn-pill-shadow);
    transition:
            transform .15s ease,
            box-shadow .15s ease,
            background-color .15s ease;
}

.tcl-nav-ctas .btn:hover,
.tcl-btn-login:hover,
.tcl-btn-register:hover {
    transform: translateY(-1px);
    box-shadow: var(--btn-pill-shadow-hover);
}

/* Register */

.tcl-btn-register {
    background: var(--c-red);
    border: 1px solid var(--c-red);
    color: #fff;
}

.tcl-btn-register:hover,
.tcl-btn-register:focus {
    background: color-mix(in srgb, var(--c-red) 85%, #000);
    border-color: color-mix(in srgb, var(--c-red) 85%, #000);
    color: #fff;
}

/* Login */

.tcl-btn-login {
    background: var(--c-blue);
    border: 1px solid var(--c-blue);
    color: #fff;
}

.tcl-btn-login:hover,
.tcl-btn-login:focus {
    background: color-mix(in srgb, var(--c-blue) 85%, #000);
    border-color: color-mix(in srgb, var(--c-blue) 85%, #000);
    color: #fff;
}

@media (max-width: 991.98px) {
    .tcl-nav-ctas {
        margin-top: .75rem;
        width: 100%;
    }

    .tcl-nav-ctas .btn {
        flex: 1;
        justify-content: center;
    }
}

/* =========================================================
   THEME TOGGLE
========================================================= */

#themeToggle.tcl-theme-toggle {
    width: 36px;
    height: 36px;
    padding: 0;
    display: grid;
    place-items: center;

    border-radius: 12px;
    border: 1px solid var(--border);

    background: color-mix(in srgb, var(--surface) 70%, transparent);
    color: var(--text);

    box-shadow: 0 8px 20px rgba(0,0,0,.10);

    transition:
            transform .15s ease,
            box-shadow .15s ease,
            filter .15s ease;
}

#themeToggle.tcl-theme-toggle:hover {
    transform: translateY(-1px);
    box-shadow: 0 10px 24px rgba(0,0,0,.16);
    filter: brightness(1.03);
}

#themeToggle.tcl-theme-toggle:active {
    transform: translateY(0);
    box-shadow: 0 8px 20px rgba(0,0,0,.12);
}

#themeToggleIcon {
    font-size: 18px;
    color: inherit;
    line-height: 1;
}

@media (max-width: 991.98px) {
    #themeToggle.tcl-theme-toggle {
        width: 44px;
        height: 44px;
    }
}

/* =========================================================
   BUTTON SYSTEM
========================================================= */

.tcl-btn,
.btn-apple,
.wp-element-button,
.wp-block-button__link,
.wpforms-submit,
button:not(.navbar-toggler):not(#themeToggle):not(.accordion-button),
input[type="submit"],
input[type="button"],
input[type="reset"] {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: .5rem;

    min-height: 48px;
    padding: .85rem 1.35rem;

    border: 1px solid transparent;
    border-radius: 999px;

    font-family: inherit;
    font-size: .95rem;
    font-weight: 700;
    line-height: 1;
    text-decoration: none;

    cursor: pointer;
    user-select: none;

    box-shadow: var(--btn-pill-shadow);

    transition:
            transform .22s var(--ease),
            box-shadow .22s var(--ease),
            background-color .22s var(--ease),
            border-color .22s var(--ease),
            color .22s var(--ease);
}

.tcl-btn:hover,
.btn-apple:hover,
.wp-element-button:hover,
.wp-block-button__link:hover,
.wpforms-submit:hover,
button:not(.navbar-toggler):not(#themeToggle):not(.accordion-button):hover,
input[type="submit"]:hover,
input[type="button"]:hover,
input[type="reset"]:hover {
    transform: translateY(-2px);
    box-shadow: var(--btn-pill-shadow-hover);
    text-decoration: none;
}

.tcl-btn:focus-visible,
.btn-apple:focus-visible,
.wp-element-button:focus-visible,
.wp-block-button__link:focus-visible,
.wpforms-submit:focus-visible {
    outline: 3px solid var(--focus);
    outline-offset: 3px;
}

/* Primary */

.tcl-btn--primary,
.btn-apple,
.btn-apple-primary,
.wp-element-button,
.wp-block-button__link,
.wpforms-submit {
    background: var(--btn-pill-bg);
    color: var(--btn-pill-text);
    border-color: transparent;
}

.tcl-btn--primary:hover,
.btn-apple:hover,
.btn-apple-primary:hover {
    background: var(--btn-pill-bg-hover);
    color: var(--btn-pill-text);
}

/* Secondary */

.tcl-btn--secondary,
.btn-apple-secondary {
    background: var(--surface);
    color: var(--text);
    border-color: var(--border);
}

.tcl-btn--secondary:hover,
.btn-apple-secondary:hover {
    background: color-mix(in srgb, var(--surface) 88%, #000);
}

/* Ghost */

.tcl-btn--ghost,
.btn-apple-ghost,
.btn-outline-contrast {
    background: transparent;
    color: var(--text);
    border: 1px solid var(--border);
    box-shadow: none;
}

.tcl-btn--ghost:hover,
.btn-apple-ghost:hover,
.btn-outline-contrast:hover {
    background: var(--alt);
    border-color: color-mix(in srgb, var(--c-blue2) 55%, var(--border));
}

/* Gradient */

.btn-gradient {
    background: var(--grad);
    border: none;
    color: #fff;
}

.btn-gradient:hover {
    filter: brightness(1.06);
    color: #fff;
}

/* Dark mode */

[data-theme="dark"] .btn-apple-secondary,
[data-theme="dark"] .tcl-btn--secondary {
    background: rgba(255,255,255,.08);
    color: #fff;
    border-color: rgba(255,255,255,.14);
}
/* =========================================================
   HERO
========================================================= */

.tcl-hero {
    position: relative;
    min-height: 92vh;
    display: flex;
    align-items: center;

    margin-top: calc(var(--navH) * -1);
    padding-top: calc(4rem + var(--navH));
    padding-bottom: 4rem;

    background-image: var(--hero-bg-mobile);
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
}

/* Responsive hero backgrounds */

@media (min-width: 768px) {
    .tcl-hero {
        background-image: var(--hero-bg-tablet);
    }
}

@media (min-width: 992px) {
    .tcl-hero {
        background-image: var(--hero-bg-lg);
    }
}

@media (min-width: 1200px) {
    .tcl-hero {
        background-image: var(--hero-bg-xl);
    }
}

@media (min-width: 1400px) {
    .tcl-hero {
        background-image: var(--hero-bg-xxl);
    }
}

@media (min-width: 1800px) {
    .tcl-hero {
        background-image: var(--hero-bg-xxxl);
        background-position: center top;
    }
}

/* Overlay */

.tcl-hero__overlay {
    position: absolute;
    inset: 0;
    background: var(--heroOverlay);
    pointer-events: none;
}

/* Content */

.tcl-hero__content {
    position: relative;
    z-index: 2;
    color: #fff;
}

.tcl-hero h1,
.tcl-hero .hero-subtitle,
.tcl-hero .hero-subtitle *,
.tcl-hero .tcl-muted,
.tcl-hero p,
.tcl-hero__lead {
    color: rgba(255, 255, 255, .92);
}

.tcl-hero h1 {
    color: #fff;
}

.hero-subtitle,
.hero-subtitle--white {
    color: inherit;
}

.tcl-hero__lead {
    max-width: 65ch;
}

/* Hero buttons preserve inherited color */

.tcl-hero .btn {
    color: inherit;
}

/* =========================================================
   HERO BADGES
========================================================= */

.tcl-badge {
    background: rgba(255,255,255,.92);
    color: #0c2039;
    border: 1px solid rgba(0,0,0,.08);
    font-weight: 700;
}

.dot {
    width: 8px;
    height: 8px;
    border-radius: 999px;
    background: rgba(255,255,255,.85);
    display: inline-block;
}

/* =========================================================
   SECTIONS
========================================================= */

.tcl-section {
    padding: 5.5rem 0;
}

.tcl-section--alt {
    background: var(--alt);
    border-top: 1px solid var(--border);
    border-bottom: 1px solid var(--border);
}

.tcl-title {
    font-weight: 700;
    letter-spacing: -0.03em;
    font-size: clamp(1.6rem, 2.2vw, 2.15rem);
    margin-bottom: .35rem;
}

.tcl-title.mb-tight {
    margin-bottom: .15rem;
}

.tcl-title.mb-loose {
    margin-bottom: .75rem;
}

.tcl-lead {
    max-width: 70ch;
}

#education .tcl-lead {
    max-width: none;
}

.tcl-muted {
    color: var(--muted);
}

/* =========================================================
   CARDS / PANELS
========================================================= */

.tcl-card,
.tcl-panel {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    box-shadow: var(--shadow);
}

.tcl-panel {
    background: color-mix(in srgb, var(--surface) 80%, transparent);
}

.tcl-card .tcl-icon {
    margin: 0 auto .75rem;
}

/* =========================================================
   ICONS
========================================================= */

.tcl-icon {
    width: 56px;
    height: 56px;
    border-radius: 16px;

    display: flex;
    align-items: center;
    justify-content: center;

    background: color-mix(in srgb, var(--alt) 70%, transparent);
    border: 1px solid var(--border);

    margin-bottom: .75rem;
}

.tcl-icon .tcl-custom-icon {
    width: 40px;
    height: 40px;
    object-fit: contain;
    display: block;
    margin: 0;
    padding: 0;
    line-height: 0;
}

/* =========================================================
   CONTENT IMAGES
========================================================= */

#learning img:not(.tcl-logo):not(.tcl-custom-icon),
#about img:not(.tcl-logo),
#purpose img:not(.tcl-logo),
#partnership img:not(.tcl-logo),
#solution img:not(.tcl-logo) {
    width: 100%;
    height: auto;
    display: block;

    border-radius: var(--radius);
    border: 1px solid color-mix(in srgb, var(--border) 75%, transparent);
    box-shadow: var(--shadow);
}

.tcl-img-circle {
    border-radius: 999px !important;
    aspect-ratio: 1 / 1;
    object-fit: cover;
}
/* =========================================================
   LEARNING SECTION
========================================================= */

.tcl-learning {
    background: var(--surface);
}

.tcl-learning .tcl-title {
    color: var(--text);
}

.tcl-learning .tcl-muted {
    color: var(--muted);
}

#learning .tcl-lead {
    max-width: none;
}

[data-theme="dark"] .tcl-icon .tcl-custom-icon {
    filter: brightness(0) invert(1);
}

@media (prefers-color-scheme: dark) {
    :root:not([data-theme]) .tcl-icon .tcl-custom-icon {
        filter: brightness(0) invert(1);
    }
}

/* =========================================================
   PROBLEM SECTION
========================================================= */

.tcl-problem {
    position: relative;
    overflow: hidden;
    padding: 5.5rem 0;

    background: var(--footer-grad);
    color: var(--footer-text);

    border-top: 1px solid var(--footer-border);
    border-bottom: 1px solid var(--footer-border);
}

.tcl-problem::before {
    content: "";
    position: absolute;
    inset: 0;
    background: var(--footer-overlay);
    pointer-events: none;
    z-index: 0;
}

.tcl-problem .container {
    position: relative;
    z-index: 1;
}

.tcl-problem__title {
    font-weight: 900;
    letter-spacing: -0.02em;
    margin-bottom: .5rem;
    color: var(--footer-text);
}

.tcl-problem__lead {
    color: var(--footer-muted);
    max-width: 75ch;
    margin: 0 auto;
}

.tcl-problem__footnote {
    color: var(--footer-muted);
    font-size: .92rem;
    line-height: 1.45;
    opacity: .95;
}

.tcl-problem__footnote i {
    opacity: .95;
}

.tcl-problem__item {
    padding: 1.5rem;

    border-radius: var(--radius);
    border: 1px solid rgba(255,255,255,.18);

    background: rgba(255,255,255,.06);

    box-shadow: 0 18px 60px rgba(0,0,0,.25);
}

.tcl-problem__icon {
    width: 70px;
    height: 70px;

    display: grid;
    place-items: center;

    margin: 0 auto 1rem;

    border-radius: 20px;
    border: 1px solid rgba(255,255,255,.18);

    background: rgba(255,255,255,.10);
}

.tcl-problem__text {
    color: rgba(255,255,255,.88);
}

/* Manual dark mode */

[data-theme="dark"] .tcl-problem__item {
    background: var(--surface);
    border-color: var(--border);
    box-shadow: var(--shadow);
}

[data-theme="dark"] .tcl-problem__icon {
    background: color-mix(in srgb, var(--alt) 70%, transparent);
    border-color: var(--border);
}

[data-theme="dark"] .tcl-problem__lead,
[data-theme="dark"] .tcl-problem__text {
    color: var(--muted);
}

[data-theme="dark"] .tcl-problem__footnote {
    color: color-mix(in srgb, var(--muted) 85%, var(--text));
}

/* System dark mode */

@media (prefers-color-scheme: dark) {
    :root:not([data-theme]) .tcl-problem__item {
        background: var(--surface);
        border-color: var(--border);
        box-shadow: var(--shadow);
    }

    :root:not([data-theme]) .tcl-problem__icon {
        background: color-mix(in srgb, var(--alt) 70%, transparent);
        border-color: var(--border);
    }

    :root:not([data-theme]) .tcl-problem__lead,
    :root:not([data-theme]) .tcl-problem__text {
        color: var(--muted);
    }

    :root:not([data-theme]) .tcl-problem__footnote {
        color: color-mix(in srgb, var(--muted) 85%, var(--text));
    }
}

/* =========================================================
   BACK TO TOP
========================================================= */

.tcl-top {
    position: fixed;
    right: 18px;
    bottom: 18px;

    width: 46px;
    height: 46px;

    display: grid;
    place-items: center;

    border: 0;
    border-radius: 999px;

    background: var(--c-blue2);
    color: #fff;

    box-shadow: var(--shadow);

    opacity: 0;
    transform: translateY(10px);

    transition:
            opacity .2s var(--ease),
            transform .2s var(--ease);

    z-index: 1030;
}

.tcl-top.show {
    opacity: 1;
    transform: translateY(0);
}

/* =========================================================
   ACCESSIBILITY
========================================================= */

@media (prefers-reduced-motion: reduce) {
    html {
        scroll-behavior: auto;
    }

    *,
    *::before,
    *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
    }
}

/* =========================================================
   REVEAL ANIMATION
========================================================= */

.reveal {
    opacity: 1;
    transform: none;
}

.js .reveal {
    opacity: 0;
    transform: translateY(14px);

    transition:
            opacity .55s var(--ease),
            transform .55s var(--ease);
}

.js .reveal.is-visible {
    opacity: 1;
    transform: translateY(0);
}

@media (prefers-reduced-motion: reduce) {
    .reveal,
    .js .reveal {
        opacity: 1;
        transform: none;
        transition: none;
    }
}

/* =========================================================
   LOGO SWITCHING
========================================================= */

.tcl-logo {
    width: auto;
    height: auto;
    max-height: 42px;
    object-fit: contain;
}

/* default state */
.tcl-logo--light {
    display: block;
}

.tcl-logo--dark {
    display: none;
}

/* manual dark mode */
:root[data-theme="dark"] .tcl-logo--light {
    display: none;
}

:root[data-theme="dark"] .tcl-logo--dark {
    display: block;
}

/* system dark mode only when no manual override */
@media (prefers-color-scheme: dark) {
    :root:not([data-theme]) .tcl-logo--light {
        display: none;
    }

    :root:not([data-theme]) .tcl-logo--dark {
        display: block;
    }
}

/* =========================================================
   PARALLAX QUOTE
========================================================= */

.tcl-quote-parallax {
    position: relative;
    overflow: hidden;

    padding: 5.5rem 0;

    color: #fff;
    background-color: #0b0f18;
    background-attachment: fixed;
}

.tcl-quote-parallax::before,
.tcl-quote-parallax::after {
    content: "";

    position: absolute;
    inset: 0;

    background-position: center;
    background-size: cover;
    background-repeat: no-repeat;
    background-attachment: fixed;

    pointer-events: none;
    will-change: opacity;

    transition: opacity 450ms ease;
}

.tcl-quote-parallax::before {
    background-image: var(--bg-a);
    opacity: 1;
}

.tcl-quote-parallax::after {
    background-image: var(--bg-b);
    opacity: 0;
}

.tcl-quote-parallax.bg-b::before {
    opacity: 0;
}

.tcl-quote-parallax.bg-b::after {
    opacity: 1;
}

/* Overlay */

.tcl-quote-parallax__overlay {
    position: absolute;
    inset: 0;

    pointer-events: none;

    background:
            radial-gradient(
                    circle at 20% 20%,
                    rgba(255,255,255,.08),
                    transparent 40%
            ),
            radial-gradient(
                    circle at 80% 30%,
                    rgba(202,24,30,.18),
                    transparent 45%
            ),
            radial-gradient(
                    circle at 35% 85%,
                    rgba(1,123,255,.18),
                    transparent 50%
            ),
            linear-gradient(
                    120deg,
                    rgba(0,0,0,.85),
                    rgba(0,0,0,.55)
            );
}

/* Content */

.tcl-quote-parallax .container {
    position: relative;
    z-index: 2;
}

.tcl-quote-parallax__inner {
    max-width: 980px;
    margin: 0 auto;
    padding: 3.25rem 3rem;

    text-align: center;

    border-radius: calc(var(--radius) + .5rem);
    border: 1px solid rgba(255,255,255,.18);

    background: rgba(255,255,255,.10);

    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);

    box-shadow: 0 28px 80px rgba(0,0,0,.35);

    transition:
            opacity 450ms ease,
            transform 450ms ease;
}

.tcl-quote-parallax.is-fading .tcl-quote-parallax__inner {
    opacity: .15;
    transform: translateY(4px);
}

/* Quote */

.tcl-quote {
    margin: 0;
}

.tcl-quote__text {
    font-size: clamp(1.35rem, 1.1rem + 1vw, 2rem);
    font-weight: 800;
    letter-spacing: -0.02em;
    margin: 0 0 1rem;
}

.tcl-quote__cite {
    margin: 0;
    font-size: 1rem;
    font-weight: 700;
    opacity: .9;
}

/* Responsive */

@media (max-width: 575.98px) {
    .tcl-quote-parallax__inner {
        padding: 2.25rem 1.5rem;
        border-radius: var(--radius);
    }
}

@media (max-width: 991.98px) {
    .tcl-quote-parallax,
    .tcl-quote-parallax::before,
    .tcl-quote-parallax::after {
        background-attachment: scroll;
    }
}

/* Accessibility */

@media (prefers-reduced-motion: reduce) {
    .tcl-quote-parallax::before,
    .tcl-quote-parallax::after,
    .tcl-quote-parallax__inner {
        transition: none;
    }
}

/* =========================================================
   FAQ
========================================================= */

.tcl-faq .tcl-lead {
    max-width: none;
    margin-bottom: 1.25rem;
}

.tcl-faq .accordion-item {
    overflow: hidden;

    border: 1px solid var(--border);
    border-radius: var(--radius);

    background: var(--surface);
    box-shadow: var(--shadow);
}

.tcl-faq .accordion-button {
    padding: 1.05rem 1.25rem;

    background: transparent;
    color: var(--text);

    font-weight: 700;
    letter-spacing: -0.01em;
}

.tcl-faq .accordion-button:focus {
    box-shadow: none;
}

.tcl-faq .accordion-button:not(.collapsed) {
    background: transparent;
    color: var(--text);
}

.tcl-faq .accordion-body {
    padding: 0 1.25rem 1.1rem;
    color: var(--muted);
}

.tcl-faq .accordion-collapse {
    border-top: 1px solid var(--border);
}

/* Dark mode accordion chevron */

[data-theme="dark"] .tcl-faq .accordion-button::after {
    filter: invert(1) brightness(1.15);
    opacity: .85;
}

@media (prefers-color-scheme: dark) {
    :root:not([data-theme]) .tcl-faq .accordion-button::after {
        filter: invert(1) brightness(1.15);
        opacity: .85;
    }
}

/* =========================================================
   CORE PAGE TEMPLATE
========================================================= */

.tcl-core-hero {
    position: relative;
    overflow: hidden;

    margin-top: calc(var(--navH) * -1);

    color: #fff;
    background: #0b0f18;
}

.tcl-core-hero__overlay {
    position: absolute;
    inset: 0;

    pointer-events: none;

    background: linear-gradient(
            180deg,
            rgba(12,32,57,.10) 0%,
            rgba(12,32,57,.45) 55%,
            rgba(12,32,57,.85) 100%
    );
}

.tcl-core-hero__media {
    width: 100%;
    height: clamp(280px, 34vw, 460px);

    background-position: center center;
    background-repeat: no-repeat;
    background-size: contain;
    background-color: #f3f5f9;
    background-attachment: scroll;

    transform: scale(1.02);
    filter: saturate(1.03) contrast(1.01);
}

.tcl-core-hero__media--fallback {
    background:
            radial-gradient(
                    circle at 20% 20%,
                    rgba(255,255,255,.08),
                    transparent 40%
            ),
            radial-gradient(
                    circle at 80% 30%,
                    rgba(202,24,30,.18),
                    transparent 45%
            ),
            linear-gradient(
                    120deg,
                    rgba(0,0,0,.85),
                    rgba(0,0,0,.55)
            );
}

.tcl-core-hero__inner {
    position: absolute;
    inset: 0;

    display: flex;
    flex-direction: column;
    justify-content: flex-end;

    padding-top: var(--navH);
    padding-bottom: 2.25rem;
}

.tcl-core-hero__inner .container,
.tcl-core-wrap .container {
    max-width: 1150px;
}

.tcl-core-hero__inner .tcl-core-content {
    padding-left: var(--bs-gutter-x, 1rem);
    padding-right: var(--bs-gutter-x, 1rem);
}

.tcl-core-hero__title {
    margin: 0 0 .5rem;

    font-size: clamp(2rem, 1.4rem + 2vw, 3rem);
    font-weight: 700;
    letter-spacing: -0.02em;
}

.tcl-core-hero__lead {
    max-width: 70ch;
    margin: 0;

    font-size: 1.05rem;
    font-weight: 600;
    opacity: .92;
}

.tcl-core-body {
    padding: 3.25rem 0;
    background: var(--bg);
}

.tcl-core-body .container {
    max-width: 1140px;
    margin: 0 auto;
}

.tcl-core-content,
.tcl-legalContent {
    width: 100%;
    min-width: 0;
}

.tcl-legal-sidebar {
    width: 100%;
}

.navbar .navbar-brand img {
    width: auto;
    height: auto;
    object-fit: contain;
    max-height: 64px;
}

/* only visible logos should display */
.tcl-logo--light,
.tcl-logo--dark {
    display: none;
}

.tcl-logo--light {
    display: block;
}

:root[data-theme="dark"] .tcl-logo--light {
    display: none;
}

:root[data-theme="dark"] .tcl-logo--dark {
    display: block;
}

@media (prefers-color-scheme: dark) {
    :root:not([data-theme]) .tcl-logo--light {
        display: none;
    }

    :root:not([data-theme]) .tcl-logo--dark {
        display: block;
    }
}

/* =========================================================
   FOOTER
========================================================= */

.tcl-footer {
    position: relative;
    overflow: hidden;
    padding: 3rem 0 2rem;
    background: var(--footer-grad);
    color: var(--footer-text);
    border-top: 1px solid var(--footer-border);
}

.tcl-footer::before {
    content: "";
    position: absolute;
    inset: 0;
    background: var(--footer-overlay);
    pointer-events: none;
    z-index: 0;
}

.tcl-footer .container {
    position: relative;
    z-index: 1;
}

/* =========================================================
   TYPOGRAPHY
========================================================= */

.tcl-footer__heading {
    margin: 0 0 1rem;
    font-size: clamp(1.15rem, 1.3vw, 1.4rem);
    font-weight: 800;
    letter-spacing: -0.02em;
    color: #fff;
}

.tcl-footer__desc,
.tcl-footer__contact,
.tcl-footer__note,
.tcl-footer__newsletter-text {
    font-size: 1rem;
    line-height: 1.65;
    color: var(--footer-muted);
}

/* =========================================================
   LINKS
========================================================= */

.tcl-footer__links {
    margin: 0;
    padding: 0;
    list-style: none;
}

.tcl-footer__links li {
    margin-bottom: .5rem;
}

.tcl-footer__link,
.tcl-footer__links a {
    color: #fff !important;
    font-weight: 600;
    text-decoration: none;
    transition: opacity .2s ease;
}

.tcl-footer__link:hover,
.tcl-footer__links a:hover {
    color: #fff !important;
    opacity: .82;
    text-decoration: none;
}

/* =========================================================
   CONTACT ICON LINKS
========================================================= */

.tcl-footer__iconLink {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    line-height: 1.65;
    color: #fff;
}

.tcl-footer__iconLink i {
    font-size: 1rem;
    color: rgba(255,255,255,.85);
    margin-top: .2rem;
    min-width: 18px;
}

.tcl-footer__address {
    color: #fff;
    margin: 0;
}

.tcl-footer__contact p {
    margin-bottom: 1rem;
}

/* =========================================================
   SOCIAL ICONS
========================================================= */

.social-icons {
    display: flex;
    align-items: center;
    gap: .7rem;
    margin-top: 1rem;
}

.social-icons a {
    width: 42px;
    height: 42px;

    display: flex;
    align-items: center;
    justify-content: center;

    border-radius: 12px;
    border: 1px solid rgba(255,255,255,.18);

    background: rgba(255,255,255,.08);
    backdrop-filter: blur(10px);

    color: #fff !important;
    text-decoration: none;

    box-shadow: 0 10px 24px rgba(0,0,0,.10);

    transition:
            transform .18s ease,
            background .18s ease,
            border-color .18s ease,
            box-shadow .18s ease;
}

.social-icons a:hover {
    transform: translateY(-2px);
    background: rgba(255,255,255,.14);
    border-color: rgba(255,255,255,.28);
    color: #fff !important;
}

.social-icons i {
    font-size: 1rem;
    line-height: 1;
}

/* =========================================================
   WPFORMS FOOTER NEWSLETTER
========================================================= */

.tcl-footer .wpforms-container {
    margin: 0 !important;
    width: 100%;
    max-width: 100%;
}

.tcl-footer .wpforms-form {
    width: 100%;
}

.tcl-footer .wpforms-field-label,
.tcl-footer .wpforms-required-label,
.tcl-footer .wpforms-field-description {
    display: none !important;
}

.tcl-footer .wpforms-field {
    padding: 0 !important;
    margin-bottom: 1rem !important;
}

.tcl-footer .wpforms-field input[type="email"] {
    width: 100% !important;
    height: 54px !important;
    border-radius: 18px !important;
    border: 1px solid rgba(255,255,255,.16) !important;
    background: rgba(255,255,255,.08) !important;
    backdrop-filter: blur(8px);
    color: #fff !important;
    padding: 0 1.15rem !important;
    font-size: .95rem !important;
    font-weight: 500;
    box-shadow:
            inset 0 1px 0 rgba(255,255,255,.08),
            0 10px 24px rgba(0,0,0,.10);
}

.tcl-footer .wpforms-field input[type="email"]::placeholder {
    color: rgba(255,255,255,.65);
}

.tcl-footer .wpforms-submit {
    width: 100% !important;
    min-height: 52px !important;
    border-radius: 999px !important;
    font-size: .95rem !important;
    font-weight: 700 !important;
    background: var(--c-blue) !important;
    border: none !important;
    color: #fff !important;
    box-shadow: 0 12px 28px rgba(10,87,232,.35);
}

.tcl-footer .wpforms-submit:hover {
    transform: translateY(-2px);
    background: #0f2a72 !important;
}

/* =========================================================
   DIVIDER / COPYRIGHT
========================================================= */

.tcl-footer__divider {
    border-color: var(--footer-border);
    opacity: 1;
    margin: 2rem 0 1rem;
}

.tcl-footer__bottom {
    font-size: .95rem;
    color: rgba(255,255,255,.82);
}

/* =========================================================
   MOBILE
========================================================= */

@media (max-width: 991px) {
    .tcl-footer {
        text-align: center;
    }

    .social-icons {
        justify-content: center;
    }

    .tcl-footer__iconLink {
        justify-content: center;
    }
}

/* =========================================================
   BLOG SECTION (HOMEPAGE)
========================================================= */

.tcl-blog {
    display: grid;
    gap: 1.25rem;
}

#blog.tcl-section {
    padding-top: 3rem;
}

.tcl-section-head {
    margin-bottom: 2rem;
}

.tcl-section-head .tcl-lead {
    color: var(--muted);
}

@media (max-width: 575.98px) {
    .tcl-section-head {
        margin-bottom: 1.6rem;
    }

    #blog.tcl-section {
        padding-top: 2.5rem;
    }
}

/* =========================================================
   BLOG HERO
========================================================= */

.tcl-blog__hero {
    position: relative;
    display: block;
    overflow: hidden;
    min-height: 420px;

    border: 1px solid color-mix(in srgb, var(--border) 75%, transparent);
    border-radius: var(--radius);
    box-shadow: var(--shadow);

    text-decoration: none;
}

.tcl-blog__hero-media {
    position: absolute;
    inset: 0;

    background-size: cover;
    background-position: center;

    transform: scale(1.01);
    will-change: opacity;
    transition: opacity .55s var(--ease);
}

.tcl-blog__hero-media.is-fading {
    opacity: 0;
}

.tcl-blog__hero-overlay {
    position: absolute;
    inset: 0;
    pointer-events: none;

    background: linear-gradient(
            180deg,
            rgba(12,32,57,.08) 0%,
            rgba(12,32,57,.40) 55%,
            rgba(12,32,57,.88) 100%
    );
}

.tcl-blog__hero-content {
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 2;

    max-width: 72ch;
    padding: 2.25rem;
    color: #fff;
}

.tcl-blog__title {
    margin: 0 0 .65rem;
    color: #fff;
    font-weight: 800;
    letter-spacing: -0.02em;
    text-decoration: none;
}

.tcl-blog__excerpt {
    margin: 0 0 1rem;
    color: rgba(255,255,255,.88);
}

/* =========================================================
   BLOG THUMBS
========================================================= */

.tcl-blog__thumbs {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1rem;
}

.tcl-blog__thumb {
    display: block;
    overflow: hidden;

    color: inherit;
    text-decoration: none;

    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: calc(var(--radius) - .35rem);
    box-shadow: var(--shadow);

    transition:
            transform .18s var(--ease),
            filter .18s var(--ease);
}

.tcl-blog__thumb:hover {
    transform: translateY(-2px);
    filter: brightness(1.02);
}

.tcl-blog__thumb-media {
    aspect-ratio: 16 / 9;
    background-size: cover;
    background-position: center;
}

.tcl-blog__thumb-body {
    padding: .9rem 1rem 1rem;
}

.tcl-blog__thumb-title {
    margin: 0;
    color: var(--text);
    font-weight: 800;
    line-height: 1.15;
}

.tcl-blog__thumb-excerpt {
    margin: .45rem 0 .75rem;
    color: var(--muted);
    font-size: .95rem;
    line-height: 1.35;
}

/* =========================================================
   BLOG CTA
========================================================= */

.tcl-blog__cta {
    display: flex;
    justify-content: center;
    margin-top: .75rem;
}

.tcl-blog__cta a {
    text-decoration: none;
}

.tcl-blog .btn-apple,
.tcl-blog .btn-apple-primary {
    background: var(--primary);
    color: #fff;
    border-color: transparent;
}

.tcl-blog .btn-apple:hover,
.tcl-blog .btn-apple-primary:hover {
    background: var(--primary-hover);
    color: #fff;
}

.btn-apple-sm {
    padding: .35rem .65rem;
    font-size: .92rem;
}

.tcl-blog .tcl-blog__hero .btn-apple {
    display: inline-flex;
}

/* =========================================================
   BLOG DOTS (ISOLATED FROM GLOBAL DOT SYSTEM)
========================================================= */

#blogDots {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: .55rem;

    list-style: none;
    padding: 0;
    margin: .9rem 0 0;
}

#blogDots button,
#blogDots a,
#blogDots span {
    width: 10px !important;
    height: 10px !important;
    min-width: 10px !important;
    min-height: 10px !important;
    padding: 0 !important;

    display: block;

    border-radius: 999px;
    border: 1px solid color-mix(in srgb, var(--border) 55%, transparent);

    background: color-mix(in srgb, var(--muted) 35%, transparent);

    opacity: .9;
    cursor: pointer;
    box-shadow: none;

    transition:
            transform .2s ease,
            opacity .2s ease,
            background .2s ease,
            width .2s ease;
}

#blogDots button:hover,
#blogDots a:hover,
#blogDots span:hover {
    opacity: 1;
    transform: scale(1.15);
}

#blogDots .is-active,
#blogDots [aria-current="true"] {
    width: 22px !important;
    background: var(--primary);
    opacity: 1;
}

/* =========================================================
   BLOG PAGE GRID
========================================================= */

.tcl-blog-page {
    background: var(--bg);
}

.tcl-post-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1.5rem;
    align-items: stretch;
}

.tcl-post-card {
    display: flex;
    flex-direction: column;
    height: 100%;

    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    overflow: hidden;
    box-shadow: var(--shadow);

    transition:
            transform .2s ease,
            box-shadow .2s ease;
}

.tcl-post-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 20px 50px rgba(0,0,0,.12);
}

.tcl-post-card__thumb {
    display: block;
    overflow: hidden;
}

.tcl-post-card__image {
    width: 100%;
    aspect-ratio: 16 / 10;
    object-fit: cover;
    display: block;
}

.tcl-post-card__body {
    display: flex;
    flex-direction: column;
    padding: 1rem;
    flex: 1;
}

.tcl-post-card__date {
    margin: 0 0 .5rem;
    font-size: .85rem;
    font-weight: 600;
    color: var(--muted);
}

.tcl-post-card__title {
    margin: 0 0 .75rem;
    font-size: clamp(1.2rem, 1.4vw, 1.65rem);
    line-height: 1.15;
    font-weight: 800;
    letter-spacing: -.02em;
}

.tcl-post-card__title a {
    color: var(--text);
    text-decoration: none;
}

.tcl-post-card__excerpt {
    color: var(--muted);
    line-height: 1.55;
    margin-bottom: 1rem;
    flex: 1;
}

.tcl-post-card__link {
    color: var(--primary);
    font-weight: 700;
    text-decoration: none;
}

.tcl-blog-pagination {
    margin-top: 3rem;
    display: flex;
    justify-content: center;
}

.tcl-blog-pagination .nav-links {
    display: flex;
    gap: .75rem;
    flex-wrap: wrap;
}

.tcl-blog-pagination a,
.tcl-blog-pagination span {
    padding: .65rem 1rem;
    border-radius: 999px;
    border: 1px solid var(--border);
    background: var(--surface);
    color: var(--text);
    text-decoration: none;
}

.tcl-blog-pagination .current {
    background: var(--primary);
    border-color: var(--primary);
    color: #fff;
}

@media (max-width: 991.98px) {
    .tcl-post-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 767.98px) {
    .tcl-post-grid {
        grid-template-columns: 1fr;
    }
}

/* =========================================================
   BLOG ARCHIVE (EDITORIAL LIST)
========================================================= */

.tcl-blog-archive {
    background: var(--bg);
}

.tcl-standard-hero__lead {
    max-width: 70ch;
    color: rgba(255,255,255,.88);
    margin-top: 1rem;
    font-size: 1.05rem;
    line-height: 1.7;
}

.tcl-blog-year-group {
    margin-bottom: 4rem;
}

.tcl-blog-year-header {
    margin-bottom: 1.75rem;
    padding-bottom: .75rem;
    border-bottom: 1px solid var(--border);
}

.tcl-blog-year-header h2 {
    margin: 0;
    font-size: clamp(1.75rem, 2vw, 2.4rem);
    font-weight: 800;
    letter-spacing: -.02em;
}

.tcl-blog-year-posts {
    display: grid;
    gap: 1.5rem;
}

.tcl-blog-listing {
    display: grid;
    grid-template-columns: 280px 1fr;
    gap: 1.5rem;
    align-items: start;

    padding: 1.25rem;
    border: 1px solid var(--border);
    border-radius: var(--radius);
    background: var(--surface);
    box-shadow: var(--shadow);

    transition:
            transform .2s ease,
            box-shadow .2s ease;
}

.tcl-blog-listing:hover {
    transform: translateY(-2px);
}

.tcl-blog-listing__thumb {
    display: block;
    overflow: hidden;
    border-radius: 18px;
}

.tcl-blog-listing__image {
    width: 100%;
    height: 100%;
    aspect-ratio: 16 / 10;
    object-fit: cover;
    display: block;
}

.tcl-blog-listing__date {
    margin: 0 0 .5rem;
    font-size: .9rem;
    color: var(--muted);
    font-weight: 600;
}

.tcl-blog-listing__title {
    margin: 0 0 .75rem;
    font-size: clamp(1.35rem, 1.8vw, 2rem);
    font-weight: 800;
    line-height: 1.15;
    letter-spacing: -.02em;
}

.tcl-blog-listing__title a {
    color: var(--text);
    text-decoration: none;
}

.tcl-blog-listing__excerpt {
    color: var(--muted);
    line-height: 1.65;
    margin-bottom: 1rem;
}

.tcl-blog-listing__link {
    color: var(--primary);
    font-weight: 700;
    text-decoration: none;
}

.tcl-blog-pagination {
    margin-top: 3rem;
    display: flex;
    justify-content: center;
}

.tcl-blog-pagination .nav-links {
    display: flex;
    gap: .75rem;
    flex-wrap: wrap;
}

.tcl-blog-pagination a,
.tcl-blog-pagination span {
    padding: .65rem 1rem;
    border-radius: 999px;
    border: 1px solid var(--border);
    background: var(--surface);
    text-decoration: none;
    color: var(--text);
}

.tcl-blog-pagination .current {
    background: var(--primary);
    color: #fff;
    border-color: var(--primary);
}

@media (max-width: 991.98px) {
    .tcl-blog-listing {
        grid-template-columns: 1fr;
    }
}

/* =========================================================
   RESPONSIVE
========================================================= */

@media (max-width: 991.98px) {
    .tcl-blog__hero {
        min-height: 380px;
    }

    .tcl-blog__thumbs {
        grid-template-columns: 1fr;
    }
}

/* =========================================================
   POST CARD GRID FIX
========================================================= */

.tcl-post-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1.5rem;
    align-items: stretch;
}

.tcl-post-grid > * {
    min-width: 0;
}

/* Post cards */
.tcl-post-card {
    display: flex;
    flex-direction: column;
    width: auto;
    height: 100%;

    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    overflow: hidden;
    box-shadow: var(--shadow);

    text-decoration: none;
    color: inherit;

    transition:
            transform .2s ease,
            box-shadow .2s ease;
}

.tcl-post-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 18px 48px rgba(0,0,0,.14);
}

.tcl-post-card__media {
    width: 100%;
    aspect-ratio: 16 / 9;
    background-size: cover;
    background-position: center;
    flex-shrink: 0;
}

.tcl-post-card__body {
    display: flex;
    flex-direction: column;
    padding: 1rem;
    flex: 1;
}

.tcl-post-card__title {
    margin: 0 0 .5rem;
    font-weight: 800;
    line-height: 1.15;
    color: var(--text);
}

.tcl-post-card__excerpt {
    color: var(--muted);
    line-height: 1.45;
    margin-bottom: 1rem;
    flex: 1;
}

.tcl-post-card .btn {
    align-self: flex-start;
}

/* Tablet */
@media (max-width: 991.98px) {
    .tcl-post-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

/* Mobile */
@media (max-width: 767.98px) {
    .tcl-post-grid {
        grid-template-columns: 1fr;
    }
}

/* =========================================================
   BLOG INDEX / ARCHIVE
========================================================= */

.tcl-blogIndex {
    padding: 4.5rem 0 5rem;
    background: var(--bg);
}

.tcl-blogIndex .container {
    max-width: 1160px;
}

.tcl-blogIndex a {
    color: inherit;
    text-decoration: none;
}

.tcl-blogIndex__grid {
    display: grid;
    grid-template-columns: 1.2fr .8fr;
    gap: 1.5rem;
    align-items: start;
}

@media (max-width: 992px) {
    .tcl-blogIndex__grid {
        grid-template-columns: 1fr;
    }
}

/* Feature */

.tcl-blogIndex__feature,
.tcl-post-feature {
    display: block;
    overflow: hidden;

    border: 1px solid var(--border);
    border-radius: var(--radius);

    background: var(--surface);
    box-shadow: var(--shadow);

    transition:
            transform .25s ease,
            border-color .25s ease;
}

.tcl-blogIndex__feature:hover,
.tcl-post-feature:hover {
    transform: translateY(-2px);
    border-color: color-mix(in srgb, var(--border) 40%, var(--text));
}

.tcl-post-feature {
    position: relative;
    min-height: 460px;
    margin-bottom: 1.75rem;
}

.tcl-post-feature__media {
    position: absolute;
    inset: 0;
    background-size: cover;
    background-position: center;
}

.tcl-post-feature__overlay {
    position: absolute;
    inset: 0;

    background: linear-gradient(
            180deg,
            rgba(12,32,57,.08) 0%,
            rgba(12,32,57,.40) 55%,
            rgba(12,32,57,.88) 100%
    );
}

.tcl-post-feature__content {
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;

    max-width: 75ch;
    padding: 2.25rem;
    color: #fff;
}

.tcl-post-feature__title {
    margin: .2rem 0 .5rem;
    color: #fff;
    font-size: clamp(1.35rem, 2.2vw, 2.05rem);
    font-weight: 800;
    letter-spacing: -0.02em;
    line-height: 1.08;
}

.tcl-post-feature__excerpt {
    color: rgba(255,255,255,.88);
}

@media (max-width: 991.98px) {
    .tcl-post-feature {
        min-height: 380px;
    }
}

.navbar .navbar-brand img {
    width: auto;
    height: auto;
    object-fit: contain;
    max-height: 64px;
}

/* only visible logos should display */
.tcl-logo--light,
.tcl-logo--dark {
    display: none;
}

.tcl-logo--light {
    display: block;
}

:root[data-theme="dark"] .tcl-logo--light {
    display: none;
}

:root[data-theme="dark"] .tcl-logo--dark {
    display: block;
}

@media (prefers-color-scheme: dark) {
    :root:not([data-theme]) .tcl-logo--light {
        display: none;
    }

    :root:not([data-theme]) .tcl-logo--dark {
        display: block;
    }
}

/* =========================================================
   SINGLE BLOG POST
========================================================= */

.tcl-post-hero .tcl-standard-hero__inner {
    min-height: 500px;
}

.tcl-post-meta {
    margin: 0 0 .75rem;
    color: rgba(255,255,255,.82);
    font-size: .95rem;
    font-weight: 600;
}

.single-post .tcl-core-body {
    padding: 3.25rem 0;
}

.single-white-paper .tcl-whitePaperContent h1,
.single-white-paper .tcl-whitePaperTitle {
    font-size: clamp(1.65rem, 2vw, 2.5rem) !important;
    line-height: 1.12 !important;
    font-weight: 800 !important;
    letter-spacing: -0.025em !important;
    margin: 0 0 1.5rem !important;
}

/* =========================================================
   CONTACT
========================================================= */

.tcl-contact-section {
    position: relative;
    padding: 5rem 0;

    background:
            radial-gradient(
                    circle at top left,
                    rgba(10, 87, 232, 0.06),
                    transparent 42%
            ),
            radial-gradient(
                    circle at bottom right,
                    rgba(202, 24, 30, 0.05),
                    transparent 40%
            ),
            linear-gradient(
                    180deg,
                    #f7f9fc 0%,
                    #ffffff 100%
            );
}

.tcl-contact-section::before {
    content: "";
    position: absolute;
    top: 0;
    left: 10%;
    width: 80%;
    height: 1px;

    background: linear-gradient(
            90deg,
            transparent,
            rgba(12,32,57,.10),
            transparent
    );
}

.tcl-contactRow {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    margin-bottom: 1rem;
    line-height: 1.6;
}

.tcl-contactRow i {
    color: var(--c-blue);
    font-size: 1rem;
    margin-top: .2rem;
    min-width: 18px;
}

.tcl-contactRow a {
    color: var(--text);
    text-decoration: none;
    font-weight: 600;
}

.tcl-contactRow a:hover {
    color: var(--c-blue);
}

.tcl-contactInfoCard,
.tcl-contactFormCard {
    position: relative;
    z-index: 2;
}

.tcl-contactInfoCard {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    gap: 2rem;
}

.tcl-contactInfoCard::before,
.tcl-contactFormCard::before {
    content: "";
    position: absolute;
    inset: -20px;
    z-index: -1;
    border-radius: 32px;

    background:
            radial-gradient(
                    circle at top left,
                    rgba(10, 87, 232, 0.08),
                    transparent 45%
            ),
            radial-gradient(
                    circle at bottom right,
                    rgba(202, 24, 30, 0.06),
                    transparent 40%
            );

    filter: blur(28px);
}

.tcl-contactCards {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
}

.tcl-contactCard {
    display: flex;
    gap: 1.25rem;
    padding: 1.5rem;
    border-radius: 24px;
    background: rgba(255,255,255,.85);
    backdrop-filter: blur(12px);
    box-shadow: 0 8px 28px rgba(0,0,0,.08);
    align-items: flex-start;
    min-height: 140px;
}

.tcl-contactCard__icon {
    width: 64px;
    height: 64px;
    border-radius: 20px;
    border: 2px solid rgba(0,0,0,.08);
    background: white;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.tcl-contactCard__icon i {
    color: var(--c-blue);
    font-size: 1.4rem;
}

.tcl-contactCard h3 {
    margin-bottom: .4rem;
    font-size: 1.1rem;
}

.tcl-contactCard p {
    margin: 0;
    color: var(--c-muted);
    line-height: 1.6;
}

/* CONTACT FORM CARD */
.tcl-contactFormCard {
    padding: 2rem;
    border-radius: 28px;
    background: rgba(255,255,255,.95);
    box-shadow: 0 12px 36px rgba(0,0,0,.08);
}

.tcl-contactFormCard .wpforms-container {
    width: 100%;
    max-width: 100%;
    margin: 0;
}

.tcl-contactFormCard .wpforms-form {
    width: 100%;
}

/* NORMAL INPUTS */
.tcl-contactFormCard .wpforms-field input,
.tcl-contactFormCard .wpforms-field textarea,
.tcl-contactFormCard .wpforms-field select {
    width: 100% !important;
    max-width: 100% !important;
    box-sizing: border-box;
    border-radius: 16px !important;
    border: 1px solid rgba(0,0,0,.08) !important;
    padding: .9rem 1rem !important;
    background: white;
}

/* NAME FIELD FIX */
.tcl-contactFormCard .wpforms-field-name {
    width: 100%;
}

.tcl-contactFormCard .wpforms-field-name .wpforms-field-row {
    display: flex !important;
    flex-wrap: nowrap !important;
    gap: 1rem !important;
    width: 100% !important;
}

.tcl-contactFormCard .wpforms-field-name .wpforms-field-row-block {
    flex: 1 1 50% !important;
    width: 50% !important;
    max-width: 50% !important;
    min-width: 0 !important;
}

.tcl-contactFormCard .wpforms-field-name input {
    width: 100% !important;
}

/* TEXTAREA */
.tcl-contactFormCard textarea {
    min-height: 160px;
}

/* BUTTON */
.tcl-contactFormCard .wpforms-submit {
    border-radius: 999px !important;
    padding: .9rem 1.8rem !important;
    background: var(--c-blue) !important;
    border: none !important;
    color: white !important;
    font-weight: 600;
    transition: all .2s ease;
}

.tcl-contactFormCard .wpforms-submit:hover {
    opacity: .92;
    transform: translateY(-1px);
}

/* MOBILE */
@media (max-width: 991px) {
    .tcl-contactCard {
        flex-direction: column;
        text-align: center;
        align-items: center;
    }

    .tcl-contactFormCard .wpforms-field-name .wpforms-field-row {
        flex-wrap: wrap !important;
    }

    .tcl-contactFormCard .wpforms-field-name .wpforms-field-row-block {
        width: 100% !important;
        max-width: 100% !important;
    }
}

.tcl-contactInfoCard {
    padding: 2rem;
    border-radius: 28px;
    background: rgba(255,255,255,.92);
    backdrop-filter: blur(14px);
    box-shadow: 0 12px 36px rgba(0,0,0,.08);

    display: flex;
    flex-direction: column;
    justify-content: space-between;
}

.tcl-contactMeta {
    display: grid;
    gap: 1rem;
    margin-top: 0;
}

.tcl-contactMeta__item {
    background: rgba(255,255,255,.85);
    border: 1px solid rgba(12,32,57,.06);
    border-radius: 20px;
    padding: 1.25rem 1.5rem;
    box-shadow: 0 4px 18px rgba(12,32,57,.04);
}

.tcl-contactMeta__item .fw-bold {
    font-size: 1rem;
    margin-bottom: .35rem;
}

.tcl-contactMeta__item .tcl-link {
    color: var(--c-blue);
    font-weight: 600;
    text-decoration: none;
}

.tcl-contactMeta__item .tcl-link:hover {
    text-decoration: underline;
}

/* MATCH CONTACT PAGE FORM */
.tcl-contactFormCard {
    padding: 2rem;
    border-radius: 28px;
    background: rgba(255,255,255,.95);
    backdrop-filter: blur(12px);
    box-shadow: 0 12px 36px rgba(0,0,0,.08);
}

/* WPForms */
.tcl-contactFormCard .wpforms-container {
    width: 100%;
    max-width: 100%;
    margin: 0;
}

.tcl-contactFormCard .wpforms-field {
    margin-bottom: 1rem !important;
}

.tcl-contactFormCard .wpforms-field input,
.tcl-contactFormCard .wpforms-field textarea,
.tcl-contactFormCard .wpforms-field select {
    width: 100% !important;
    border-radius: 16px !important;
    border: 1px solid rgba(0,0,0,.08) !important;
    padding: .95rem 1rem !important;
    box-sizing: border-box;
    background: white !important;
}

.tcl-contactFormCard textarea {
    min-height: 160px;
}

/* BUTTON */
.tcl-contactFormCard .wpforms-submit {
    border-radius: 999px !important;
    padding: .9rem 1.8rem !important;
    background: var(--c-blue) !important;
    border: none !important;
    color: white !important;
    font-weight: 700;
    transition: all .2s ease;
    box-shadow: 0 10px 24px rgba(10,87,232,.22);
}

.tcl-contactFormCard .wpforms-submit:hover {
    transform: translateY(-2px);
    opacity: .95;
}

/* MOBILE */
@media (max-width: 991px) {
    .tcl-contactInfoCard,
    .tcl-contactFormCard {
        padding: 1.5rem;
    }
}

/* =========================================================
   DOT / PAGINATION SYSTEM
   Consolidated universal dot nav
========================================================= */

.tcl-dots,
.tcl-pagination-dots,
.tcl-dotnav {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: .55rem;
}

.tcl-dots,
.tcl-pagination-dots {
    padding-top: 1.5rem;
}

.tcl-dots__list {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: .55rem;

    list-style: none;
    margin: 0;
    padding: 0;
}

/* Dots */

.tcl-dot,
.tcl-dotnav__dot {
    width: 8px;
    height: 8px;

    display: inline-block;

    border-radius: 999px;
    text-decoration: none;

    background: color-mix(in srgb, var(--text) 18%, transparent);
    border: 1px solid color-mix(in srgb, var(--text) 14%, transparent);

    opacity: .9;

    transition:
            transform .22s var(--ease),
            opacity .22s var(--ease),
            background .22s var(--ease),
            width .22s var(--ease);
}

.tcl-dot:hover,
.tcl-dotnav__dot:hover {
    transform: scale(1.15);
    opacity: 1;
}

.tcl-dot.is-active,
.tcl-dotnav__dot.is-active {
    width: 20px;
    background: var(--primary);
    border-color: color-mix(in srgb, var(--primary) 70%, transparent);
    opacity: 1;
}

.tcl-dot--more,
.tcl-dotnav__hint {
    opacity: .35;
}

/* Dark mode */

[data-theme="dark"] .tcl-dot,
[data-theme="dark"] .tcl-dotnav__dot {
    background: color-mix(in srgb, #fff 22%, transparent);
    border-color: color-mix(in srgb, #fff 14%, transparent);
}

[data-theme="dark"] .tcl-dot.is-active,
[data-theme="dark"] .tcl-dotnav__dot.is-active {
    background: color-mix(in srgb, #fff 42%, transparent);
}

/* Arrow controls */

.tcl-dotnav__arrow {
    width: 34px;
    height: 34px;

    display: grid;
    place-items: center;

    border-radius: 999px;
    border: 1px solid var(--border);

    background: color-mix(in srgb, var(--surface) 85%, var(--alt));
    color: var(--text);

    text-decoration: none;
    font-weight: 900;
    line-height: 1;

    user-select: none;

    transition:
            transform .18s var(--ease),
            filter .18s var(--ease);
}

.tcl-dotnav__arrow:hover {
    filter: brightness(1.02);
    transform: translateY(-1px);
}

.tcl-dotnav__arrow:active {
    transform: translateY(0);
}

.tcl-dotnav__arrow.is-disabled {
    opacity: .45;
    pointer-events: none;
}

/* =========================================================
   POST CARDS
========================================================= */

.tcl-post-card {
    display: block;
    overflow: hidden;

    text-decoration: none;
    color: inherit;

    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: calc(var(--radius) - .35rem);

    box-shadow: var(--shadow);

    transition:
            transform .22s var(--ease),
            box-shadow .22s var(--ease),
            border-color .22s var(--ease);
}

.tcl-post-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 22px 70px rgba(0,0,0,.12);
}

.tcl-post-card__media {
    aspect-ratio: 16 / 9;
    background-size: cover;
    background-position: center;
}

.tcl-post-card__body {
    padding: .9rem 1rem 1rem;
}

.tcl-post-card__title {
    margin: 0;

    color: var(--text);

    font-weight: 750;
    font-size: clamp(1.05rem, 1.2vw, 1.35rem);
    line-height: 1.15;
    letter-spacing: -0.01em;

    transition: opacity .18s var(--ease);
}

.tcl-post-card:hover .tcl-post-card__title {
    opacity: .92;
}

.tcl-post-card__excerpt {
    margin: .5rem 0 .85rem;

    color: var(--muted);
    font-size: .95rem;
    line-height: 1.4;
}

/* Legacy feature tweaks */

.tcl-post-feature .btn-apple {
    padding: .35rem .65rem;
    font-size: .92rem;
}

.tcl-post-feature__title {
    font-size: clamp(1.2rem, 1.6vw, 1.8rem);
    font-weight: 750;
    letter-spacing: -0.015em;
    line-height: 1.2;
}

/* =========================================================
   PRESS RELEASE
========================================================= */

.tcl-pressPage {
    background: var(--bg);
}

/* HERO — match legal page behavior */
.tcl-pressPage .tcl-standard-hero {
    margin-top: calc(var(--navH) * -1);
    padding-top: var(--navH);
}

.tcl-pressPage .tcl-standard-hero__inner {
    min-height: clamp(260px, 28vw, 420px);
    display: flex;
    align-items: flex-end;
    padding:
            clamp(3rem, 6vw, 6rem)
            0
            clamp(2.5rem, 5vw, 4rem);
}

/* keep hero buttons normal width */
.tcl-pressPage .tcl-standard-hero .btn-apple {
    width: auto;
}

/* MAIN LAYOUT */
.tcl-pressPage .tcl-core-body > .container {
    max-width: 1240px;
    margin-left: auto;
    margin-right: auto;
    padding-left: 1.5rem;
    padding-right: 1.5rem;
}

.tcl-pressPage .row {
    align-items: flex-start;
}

.tcl-pressPage .col-lg-8 {
    flex: 0 0 68%;
    max-width: 68%;
}

.tcl-pressPage .col-lg-4 {
    flex: 0 0 32%;
    max-width: 32%;
}

/* ARTICLE CARD */
.tcl-pressContent {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: 28px;
    box-shadow: var(--shadow);
    padding: 0;
    overflow: hidden;
}

/* FEATURE IMAGE — flush to card edges */
.tcl-pressFeaturedImage {
    width: 100%;
    margin: 0;
    padding: 0;
    overflow: hidden;
}

.tcl-pressFeaturedImage img {
    display: block;
    width: 100%;
    height: auto;
    object-fit: cover;
    border-radius: 28px 28px 0 0;
    margin: 0;
}

/* ARTICLE BODY */
.tcl-pressArticleBody {
    padding: clamp(1.75rem, 3vw, 2.5rem);
}

.tcl-pressHeadline {
    margin: 0 0 1.5rem;
    font-size: clamp(1.6rem, 2.4vw, 2.6rem);
    font-weight: 850;
    line-height: 1.12;
    letter-spacing: -0.03em;
    color: var(--text);
    text-wrap: balance;
}

/* CONTENT */
.tcl-pressProse {
    max-width: none;
}

.tcl-pressProse p {
    font-size: 1.02rem;
    line-height: 1.75;
    color: var(--text);
    margin-bottom: 1.15rem;
}

.tcl-pressEnd {
    text-align: center;
    margin-top: 3rem;
    padding-top: 2rem;
    border-top: 1px solid var(--border);
    font-size: 1.2rem;
    font-weight: 800;
    letter-spacing: .2em;
    color: var(--muted);
}

/* SIDEBAR */
.tcl-pressPage .tcl-legal-sidebar {
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
    position: sticky;
    top: calc(var(--navH) + 1.5rem);
}

.tcl-pressPage .tcl-pressCard {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: 24px;
    box-shadow: var(--shadow);
    padding: 1.35rem;
}

.tcl-pressPage .tcl-pressCard__label {
    margin-bottom: .75rem;
    color: var(--text);
    font-weight: 850;
    letter-spacing: -0.02em;
    font-size: 1.05rem;
}

.tcl-pressPage .tcl-pressCard__text {
    color: var(--muted);
    line-height: 1.7;
}

.tcl-pressPage .tcl-pressCard__text strong {
    color: var(--text);
}

/* CONTACT ROWS */
.tcl-contactRow {
    display: flex;
    align-items: flex-start;
    gap: .8rem;
    margin-top: .9rem;
    line-height: 1.55;
}

.tcl-contactRow i {
    width: 18px;
    margin-top: .18rem;
    color: var(--primary);
    flex-shrink: 0;
}

.tcl-contactRow a {
    color: var(--primary);
    text-decoration: none;
    font-weight: 650;
    word-break: break-word;
}

.tcl-contactRow a:hover {
    text-decoration: underline;
}

/* Sidebar/download buttons only */
.tcl-pressPage .tcl-pressCard .btn-apple {
    width: 100%;
    justify-content: center;
}

.tcl-pressPage .tcl-pressCard .btn-apple i {
    margin-right: .5rem;
}

/* MOBILE */
@media (max-width: 991.98px) {
    .tcl-pressPage .col-lg-8,
    .tcl-pressPage .col-lg-4 {
        flex: 0 0 100%;
        max-width: 100%;
    }

    .tcl-pressPage .tcl-legal-sidebar {
        position: static;
        margin-top: 1.5rem;
    }
}

/* ==========================================
   FOOTER TYPOGRAPHY
========================================== */

.tcl-footer {
    font-size: 16px;
    line-height: 1.55;
}

.tcl-footer__heading {
    font-size: 1.1rem;
    font-weight: 750;
    letter-spacing: -0.015em;
    line-height: 1.2;
    margin-bottom: .85rem;
}

.tcl-footer__desc,
.tcl-footer__contact,
.tcl-footer__note,
.tcl-footer__newsletter-text,
.tcl-footer__newsletter-list {
    font-size: 1rem;
    color: var(--footer-muted);
    line-height: 1.65;
}

.tcl-footer__newsletter-list {
    padding-left: 1.15rem;
}

.tcl-footer__newsletter-list li {
    margin-bottom: .45rem;
    font-size: 1rem;
    line-height: 1.6;
}

.tcl-footer__address {
    margin-top: .85rem;
    font-size: .95rem;
    line-height: 1.6;
    color: var(--footer-muted);
}

/* ==========================================
   WPFORMS
========================================== */

.tcl-footer .wpforms-container {
    margin: 0 !important;
    width: 100%;
    max-width: 100%;
}

.tcl-footer .wpforms-form {
    width: 100%;
}

.tcl-footer .wpforms-field-label {
    display: none !important;
}

.tcl-footer .wpforms-field {
    padding: 0 !important;
    margin-bottom: 1rem !important;
}

/* Input */

.tcl-footer .wpforms-field input[type="email"] {
    width: 100% !important;
    height: 54px !important;

    border-radius: 18px !important;
    border: 1px solid rgba(255,255,255,.16) !important;

    background: rgba(255,255,255,.08) !important;
    backdrop-filter: blur(8px);

    color: #fff !important;

    padding: 0 1.15rem !important;

    font-size: .95rem !important;
    font-weight: 500;

    box-shadow:
            inset 0 1px 0 rgba(255,255,255,.08),
            0 10px 24px rgba(0,0,0,.10);

    transition: all .2s ease;
}

.tcl-footer .wpforms-field input[type="email"]::placeholder {
    color: rgba(255,255,255,.65);
}

.tcl-footer .wpforms-field input[type="email"]:focus {
    border-color: rgba(255,255,255,.35) !important;
    background: rgba(255,255,255,.12) !important;

    box-shadow:
            0 0 0 3px rgba(96,165,250,.25),
            0 10px 24px rgba(0,0,0,.16);
}

.tcl-footer .wpforms-submit-container {
    padding: 0 !important;
    margin: 0 !important;
}

.tcl-footer .wpforms-submit {
    width: 100% !important;
    min-height: 52px !important;

    border-radius: 999px !important;

    font-size: .95rem !important;
    font-weight: 700 !important;
    letter-spacing: -.01em;

    background: var(--c-blue) !important;
    border: none !important;
    color: #fff !important;

    box-shadow:
            0 12px 28px rgba(10,87,232,.35);

    transition: all .2s ease;
}

.tcl-footer .wpforms-submit:hover {
    transform: translateY(-2px);
    background: #0f2a72 !important;

    box-shadow:
            0 16px 34px rgba(10,87,232,.45);
}

.tcl-footer .wpforms-required-label,
.tcl-footer .wpforms-field-description {
    display: none !important;
}

/* ==========================================
   FOOTER SOCIAL ICONS
========================================== */

.tcl-footerSocial {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 12px;
    margin-top: 1.25rem;
}

.tcl-footerSocial a {
    width: 42px;
    height: 42px;

    display: inline-flex;
    align-items: center;
    justify-content: center;

    border-radius: 999px;
    border: 1px solid rgba(255,255,255,.18);

    background: rgba(255,255,255,.08);
    backdrop-filter: blur(8px);

    color: #fff;
    text-decoration: none;

    transition:
            transform .22s ease,
            background-color .22s ease,
            border-color .22s ease,
            box-shadow .22s ease;
}

.tcl-footerSocial a:hover {
    background: var(--primary);
    border-color: var(--primary);
    transform: translateY(-2px);

    box-shadow:
            0 10px 24px rgba(10,87,232,.35);
}

.tcl-footerSocial i {
    font-size: 1rem;
    line-height: 1;
}

/* ==========================================
   RESPONSIVE
========================================== */

@media (max-width: 991px) {
    .tcl-footer__heading {
        font-size: 1rem;
    }
}

/* =========================================================
   LEGAL PAGE / COMPLIANCE PAGES
========================================================= */

.tcl-legal-badge {
    display: inline-block;
    padding: .4rem .9rem;
    border-radius: 999px;
    background: rgba(255,255,255,.18);
    color: #fff;
    font-size: .78rem;
    font-weight: 700;
    letter-spacing: .08em;
    text-transform: uppercase;
    margin-bottom: 1rem;
}

.tcl-legalPage {
    background: var(--bg);
}

/* wider container */
.tcl-legalPage .tcl-core-body > .container {
    max-width: 1320px !important;
    margin-left: auto;
    margin-right: auto;
    padding-left: 1.5rem;
    padding-right: 1.5rem;
}

/* layout */
.tcl-legalPage .row.g-5 {
    --bs-gutter-x: 2rem;
    align-items: flex-start;
}

.tcl-legalPage .col-lg-8 {
    flex: 0 0 65%;
    max-width: 65%;
}

.tcl-legalPage .col-lg-4 {
    flex: 0 0 35%;
    max-width: 35%;
}

.tcl-legalContent {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: 28px;
    box-shadow: var(--shadow);
    padding: clamp(2rem, 3vw, 3rem);
    overflow: hidden;

    font-size: 1rem;
    line-height: 1.75;
    color: var(--text);
    width: 100%;
}

.tcl-legalContent h1,
.tcl-legalContent h2,
.tcl-legalContent h3,
.tcl-legalContent h4 {
    color: var(--text);
    letter-spacing: -0.02em;
}

.tcl-legalContent h2 {
    margin-top: 2.5rem;
    margin-bottom: 1rem;
    font-size: clamp(1.45rem, 2vw, 1.9rem);
    font-weight: 800;
}

.tcl-legalContent h3 {
    margin-top: 1.75rem;
    margin-bottom: .75rem;
    font-weight: 750;
}

.tcl-legalContent p {
    margin-bottom: 1.15rem;
}

.tcl-legalContent ul,
.tcl-legalContent ol {
    margin-bottom: 1.25rem;
    padding-left: 1.5rem;
}

.tcl-legalContent li {
    margin-bottom: .5rem;
}

.tcl-legalContent a {
    color: var(--primary);
    font-weight: 650;
    text-decoration: underline;
    text-underline-offset: 2px;
}

/* sidebar */
.tcl-legal-sidebar {
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
    position: sticky;
    top: calc(var(--navH) + 1.5rem);
    width: 100%;
}

.tcl-legal-sidebar .tcl-pressCard {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: 24px;
    box-shadow: var(--shadow);
    padding: 1.5rem;
}

.tcl-legal-sidebar .tcl-pressCard__label {
    margin-bottom: .65rem;
    color: var(--text);
    font-weight: 850;
    letter-spacing: -0.02em;
}

.tcl-legal-sidebar .tcl-pressCard__text {
    color: var(--muted);
    line-height: 1.65;
}

.tcl-legal-sidebar .tcl-pressCard__text strong {
    color: var(--text);
}

.tcl-legal-sidebar a:not(.btn-apple) {
    color: var(--primary);
    font-weight: 650;
    text-decoration: none;
}

.tcl-legal-sidebar a:not(.btn-apple):hover {
    text-decoration: underline;
    text-underline-offset: .16em;
}

.tcl-legal-sidebar .btn-apple {
    width: 100%;
}

.tcl-legal-sidebar .btn-apple i {
    margin-right: .5rem;
}

.tcl-legal-sidebar .tcl-pressCard {
    min-width: 0;
}

.tcl-legal-sidebar .tcl-pressCard__text,
.tcl-legal-sidebar .tcl-pressCard__text a {
    overflow-wrap: break-word;
    word-break: break-word;
}

/* contact rows */
.tcl-contactRow {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    margin-bottom: 1rem;
    line-height: 1.6;
}

.tcl-contactRow i {
    color: var(--c-blue);
    font-size: 1rem;
    margin-top: .2rem;
    min-width: 18px;
}

.tcl-contactRow a {
    color: var(--primary);
    font-weight: 650;
    text-decoration: none;
}

.tcl-contactRow a:hover {
    text-decoration: underline;
}

/* mobile */
@media (max-width: 991.98px) {
    .tcl-legal-sidebar {
        position: static;
        margin-top: 1.5rem;
    }

    .tcl-legalPage .col-lg-8,
    .tcl-legalPage .col-lg-4 {
        flex: 0 0 100%;
        max-width: 100%;
    }

    .tcl-legalContent {
        padding: 2rem;
        border-radius: 22px;
    }
}

/* =========================================================
       TESTIMONIALS PAGE
========================================================= */
    .tcl-testimonialsIndex .tcl-resource-thumb {
        width: 100%;
        aspect-ratio: 4 / 3;
        object-fit: cover;
        display: block;
    }

    .tcl-testimonial-label {
        display: inline-block;
        padding: .35rem .75rem;
        border-radius: 999px;
        background: rgba(59, 130, 246, .12);
        color: var(--c-blue);
        font-size: .75rem;
        font-weight: 700;
        letter-spacing: .06em;
        text-transform: uppercase;
    }

    .tcl-testimonialsIndex .tcl-card h3 a {
        display: -webkit-box;
        -webkit-line-clamp: 3;
        -webkit-box-orient: vertical;
        overflow: hidden;
        color: inherit;
    }

    .tcl-testimonialsIndex .pagination .page-numbers {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        min-width: 42px;
        height: 42px;
        padding: 0 14px;
        border-radius: 999px;
        background: white;
        color: var(--c-ink);
        text-decoration: none;
        margin: 0 4px;
        box-shadow: 0 6px 20px rgba(0, 0, 0, .08);
    }

    .tcl-testimonialsIndex .pagination .current {
        background: var(--c-blue);
        color: white;
    }

    .tcl-testimonial-excerpt {
        min-height: 130px;
    }

    .tcl-testimonialsIndex .btn-apple {
        width: 100%;
    }

    /* SINGLE TESTIMONIAL */
    .tcl-testimonial-badge {
        display: inline-block;
        padding: .4rem .9rem;
        border-radius: 999px;
        background: rgba(255, 255, 255, .18);
        color: white;
        font-size: .78rem;
        font-weight: 700;
        letter-spacing: .08em;
        text-transform: uppercase;
        margin-bottom: 1rem;
    }

    .tcl-testimonial-sidebar {
        position: sticky;
        top: 120px;
    }

    .tcl-testimonial-sidebar .tcl-pressCard {
        margin-bottom: 1.5rem;
    }

    .tcl-testimonial-sidebar .tcl-pressCard:last-child {
        margin-bottom: 0;
    }

    .tcl-testimonial-sidebar .btn-apple {
        width: 100%;
    }

    @media (max-width: 991px) {
        .tcl-testimonial-sidebar {
            position: static;
        }

        .tcl-testimonial-sidebar .tcl-pressCard {
            margin-bottom: 1rem;
        }
    }

    /* =========================================================
       RESOURCES PAGE
    ========================================================= */
    .tcl-resourceTile {
        display: flex;
        flex-direction: column;
        align-items: center;
        text-align: center;
        padding: 2.5rem 2rem;
        border-radius: 24px;
        background: white;
        box-shadow: 0 12px 30px rgba(0, 0, 0, .08);
        height: 100%;
        transition: transform .2s ease;
    }

    .tcl-resourceTile:hover {
        transform: translateY(-4px);
    }

    .tcl-resourceIcon {
        font-size: 3.5rem;
        margin-bottom: 1.5rem;
        color: var(--c-blue);
        line-height: 1;
    }

    .tcl-resourceTile h3 {
        margin-top: 1rem;
        margin-bottom: .75rem;
    }

    .tcl-resourceTile p {
        margin-bottom: 0;
        flex-grow: 1;
    }

    .tcl-resourceTile .btn-apple {
        margin-top: 1.5rem;
    }

    .tcl-resourceTile__label,
    .tcl-resourceBadge {
        display: inline-block;
        padding: .35rem .75rem;
        border-radius: 999px;
        background: rgba(59, 130, 246, .12);
        color: var(--c-blue);
        font-size: .72rem;
        font-weight: 700;
        letter-spacing: .06em;
        text-transform: uppercase;
    }

    .tcl-resourcesHub .tcl-resource-thumb {
        width: 100%;
        aspect-ratio: 16 / 9;
        object-fit: cover;
        display: block;
    }

    .tcl-resourcesHub .tcl-card h3 a {
        display: -webkit-box;
        -webkit-line-clamp: 3;
        -webkit-box-orient: vertical;
        overflow: hidden;
        color: inherit;
    }

    .tcl-resourceCTA {
        padding: 3rem;
        border-radius: 28px;
        background: linear-gradient(135deg, var(--c-blue), var(--c-red));
        color: white;
        text-align: center;
    }

    .tcl-resourceCTA p {
        max-width: 700px;
        margin: 1rem auto 2rem;
        opacity: .95;
    }

    /* =========================================================
       FAQ HUB
    ========================================================= */
    .tcl-faqHub .tcl-faqSearchWrap {
        max-width: 760px;
        margin: 0 auto 3rem;
    }

    .tcl-faqHub .tcl-faqSearch {
        border-radius: 999px;
        padding: 1rem 1.5rem;
        font-size: 1rem;
        box-shadow: 0 10px 28px rgba(0, 0, 0, .08);
        border: 1px solid rgba(0, 0, 0, .08);
    }

    .tcl-faqHub .tcl-faqSearch:focus {
        box-shadow: 0 0 0 4px rgba(59, 130, 246, .12);
        border-color: var(--c-blue);
    }

/* =========================================================
   WHITE PAPER
========================================================= */

.tcl-whitePaperPage {
    background: var(--bg);
}

/* MATCH HERO CONTAINER EXACTLY */
.tcl-whitePaperPage .container {
    max-width: 1140px;
    margin: 0 auto;
    padding-left: 1rem;
    padding-right: 1rem;
}

/* GRID */
.tcl-whitePaperPage .row {
    align-items: flex-start;
    --bs-gutter-x: 2rem;
    overflow: visible;
}

.tcl-whitePaperPage .col-lg-8 {
    width: 65%;
    flex: 0 0 65%;
}

.tcl-whitePaperPage .col-lg-4 {
    width: 35%;
    flex: 0 0 35%;
}

.tcl-whitePaperPage .row,
.tcl-whitePaperPage .col-lg-8,
.tcl-whitePaperPage .col-lg-4 {
    overflow: visible !important;
}

/* MAIN CONTENT CARD */
.tcl-whitePaperContent {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: 28px;
    box-shadow: var(--shadow);
    overflow: hidden;
    color: var(--text);
    padding: 0;
}

/* FEATURE IMAGE */
.tcl-whitePaperFeature {
    margin: 0;
    padding: 0;
    line-height: 0;
    display: block;
    width: 100%;
}

.tcl-whitePaperFeature img {
    display: block;
    width: 100%;
    height: auto;
    object-fit: cover;
}

/* INNER CONTENT PADDING */
.tcl-whitePaperInner {
    padding: 2.75rem;
}

/* TITLE */
.tcl-whitePaperTitle {
    font-size: clamp(1.75rem, 2.2vw, 2.7rem);
    line-height: 1.15;
    font-weight: 800;
    letter-spacing: -0.025em;
    margin: 0 0 1.5rem;
    color: var(--text);
}

.tcl-whitePaperCaption {
    font-size: .9rem;
    line-height: 1.6;
    color: var(--muted);
    font-style: italic;
    margin-bottom: 2rem;
}

/* META */
.tcl-whitePaperMeta {
    margin-bottom: 2rem;
    color: var(--muted);
    font-size: .95rem;
}

/* BODY CONTENT */
.tcl-whitePaperInner p,
.tcl-whitePaperInner li {
    font-size: 1.02rem;
    line-height: 1.8;
    color: var(--text);
}

.tcl-whitePaperInner h2 {
    font-size: clamp(1.45rem, 2vw, 1.9rem);
    font-weight: 800;
    margin-top: 2.5rem;
    margin-bottom: 1rem;
    letter-spacing: -0.02em;
}

.tcl-whitePaperInner h3 {
    font-size: 1.2rem;
    font-weight: 700;
    margin-top: 2rem;
    margin-bottom: .8rem;
}

.tcl-whitePaperInner ul,
.tcl-whitePaperInner ol {
    padding-left: 1.5rem;
    margin-bottom: 1.5rem;
}

/* SIDEBAR */
.tcl-whitePaper-sidebar {
    position: sticky !important;
    top: 120px !important;
    align-self: start;
}

/* SIDEBAR CARDS */
.tcl-whitePaper-sidebar .tcl-pressCard {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: 24px;
    box-shadow: var(--shadow);
    padding: 1.5rem;
}

/* RESEARCH CARD */
.tcl-researchCard {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.tcl-researchHeadshot {
    width: 100%;
    overflow: hidden;
    border-radius: 18px;
    margin-bottom: .75rem;
}

.tcl-researchHeadshot img {
    width: 100%;
    display: block;
    object-fit: cover;
}

.tcl-contactRow {
    display: flex;
    align-items: flex-start;
    gap: .8rem;
    margin-bottom: .9rem;
    line-height: 1.6;
}

.tcl-contactRow i {
    width: 18px;
    flex-shrink: 0;
    margin-top: .25rem;
    color: var(--primary);
}

.tcl-contactRow a {
    color: var(--text);
    text-decoration: none;
    font-weight: 600;

    word-break: break-word;
    overflow-wrap: anywhere;
}

.tcl-contactRow a:hover {
    color: var(--primary);
}

.tcl-researchBio {
    color: var(--muted);
    line-height: 1.75;
    font-size: .96rem;
    margin-top: .5rem;
}

/* BUTTONS */
.tcl-whitePaper-sidebar .btn-apple {
    width: 100%;
}

/* MOBILE */
@media (max-width: 991.98px) {
    .tcl-whitePaperPage .col-lg-8,
    .tcl-whitePaperPage .col-lg-4 {
        width: 100%;
        flex: 0 0 100%;
    }

    .tcl-whitePaper-sidebar {
        position: static;
        margin-top: 2rem;
    }

    .tcl-whitePaperInner {
        padding: 1.75rem;
    }
}