/*
Theme Name: Kixie Theme
Theme URI: https://www.kixie.com/
Description: Custom lightweight Kixie WordPress theme.
Author: Shane Martin
Author URI: https://www.kixie.com/
Version: 1.0.0
Text Domain: kixie-theme
*/

/* Kixie theme styles extracted from template inline blocks. */

/* Global typography: match original React templates. */
body,
button,
input,
select,
textarea {
    font-family: 'DM Sans', system-ui, -apple-system, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif;
}

h1,
h2,
h3,
h4,
h5,
h6 {
    font-family: 'DM Sans', system-ui, -apple-system, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif;
    letter-spacing: -0.02em;
}

/* Header */
.kixie-site-header,
        .kixie-site-header * {
            box-sizing: border-box;
            font-family: 'DM Sans', system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, sans-serif;
        }

        .kixie-site-header {
            position: fixed;
            top: 0;
            left: 0;
            right: 0;
            z-index: 1000;
        }

        .admin-bar .kixie-site-header {
            top: 32px;
        }

        .kixie-container {
            width: 100%;
            max-width: 1280px;
            margin: 0 auto;
            padding: 0 1rem;
        }

        .kixie-hello-bar {
            background: linear-gradient(90deg, #6b21a8 0%, #7e22ce 50%, #be185d 100%);
            color: #fff;
            font-size: 0.875rem;
        }

        .kixie-hello-inner {
            min-height: 2.25rem;
            display: flex;
            align-items: center;
            justify-content: center;
            gap: 0.75rem;
            text-align: center;
            flex-wrap: wrap;
            padding: 0.4rem 0;
        }

        .kixie-hello-text {
            font-weight: 500;
        }

        .kixie-hello-link {
            display: inline-flex;
            align-items: center;
            justify-content: center;
            padding: 0.25rem 0.75rem;
            border-radius: 0.25rem;
            background: #fff;
            color: #111827;
            text-decoration: none;
            text-transform: uppercase;
            letter-spacing: 0.04em;
            font-size: 0.72rem;
            font-weight: 700;
            transition: background-color 0.2s ease;
        }

        .kixie-hello-link:hover,
        .kixie-hello-link:focus {
            background: #f3f4f6;
        }

        .kixie-main-nav {
            background: #fff;
            border-bottom: 1px solid #f3f4f6;
            position: relative;
        }

        .kixie-main-nav .kixie-container {
            max-width: 1180px;
        }

        .kixie-nav-inner {
            min-height: 0;
            display: flex;
            align-items: center;
            justify-content: space-between;
            gap: 1rem;
            padding: 0.75rem 0;
        }

        .kixie-logo {
            min-width: 0;
            flex: 0 0 auto;
            margin-right: 0;
        }

        .kixie-logo-link,
        .kixie-logo .custom-logo-link {
            display: inline-flex;
            align-items: center;
            gap: 0.35rem;
            text-decoration: none;
            color: #1f1533;
        }

        .kixie-logo .custom-logo-link img {
            max-height: 2rem;
            width: auto;
            height: auto;
        }

        .kixie-logo-image {
            display: block;
            width: auto;
            height: 2rem;
            max-width: 10.5rem;
        }

        .kixie-logo-mark {
            width: 1.75rem;
            height: 1.75rem;
            border-radius: 0.25rem;
            background: #ef4444;
            display: inline-flex;
            align-items: center;
            justify-content: center;
            color: #fff;
            font-size: 0.9rem;
            font-weight: 700;
            line-height: 1;
        }

        .kixie-logo-text {
            font-size: 1.25rem;
            font-weight: 700;
            letter-spacing: -0.02em;
            color: #1f1533;
            line-height: 1;
        }

        /* Careers template offset for fixed header */
        .kixie-careers-page-template {
            padding-top: 7.5rem;
        }

        .admin-bar .kixie-careers-page-template {
            padding-top: calc(7.5rem + 32px);
        }

        @media (max-width: 782px) {
            .kixie-careers-page-template {
                padding-top: 8.5rem;
            }

            .admin-bar .kixie-careers-page-template {
                padding-top: calc(8.5rem + 46px);
            }
        }

        /* Default single post template */
        .kixie-blog-post-template {
            padding-top: 8.25rem;
            padding-bottom: 4.5rem;
        }

        .admin-bar .kixie-blog-post-template {
            padding-top: calc(8.25rem + 32px);
        }

        .kixie-blog-wrap {
            max-width: 1180px;
            margin: 0 auto;
            padding: 0 1rem;
        }

        .kixie-blog-breadcrumb {
            display: flex;
            flex-wrap: wrap;
            gap: 0.35rem;
            align-items: center;
            color: #746c83;
            font-size: 0.92rem;
            margin-bottom: 1.1rem;
        }

        .kixie-blog-breadcrumb a {
            color: #51456b;
            text-decoration: none;
        }

        .kixie-blog-breadcrumb a:hover,
        .kixie-blog-breadcrumb a:focus {
            color: #2b1f48;
            text-decoration: underline;
        }

        .kixie-blog-post-template .kixie-blog-breadcrumb {
            display: none;
        }

        .kixie-blog-hero {
            max-width: 950px;
            margin: 0 auto 2.3rem;
        }

        .kixie-blog-category {
            margin-bottom: 0.75rem;
            color: #ef4444;
            font-weight: 700;
            font-size: 0.8rem;
            text-transform: uppercase;
            letter-spacing: 0.08em;
        }

        .kixie-blog-title {
            margin: 0;
            color: #1f1533;
            font-size: clamp(2rem, 4.6vw, 3.35rem);
            line-height: 1.08;
            letter-spacing: -0.02em;
        }

        .kixie-blog-meta {
            display: flex;
            align-items: center;
            gap: 0.75rem 1.35rem;
            flex-wrap: wrap;
            margin-top: 1rem;
            color: #635b74;
            font-size: 0.95rem;
        }

        .kixie-blog-share {
            border: 1px solid #d9d7e1;
            background: #ffffff;
            border-radius: 999px;
            color: #3b3156;
            font-size: 0.85rem;
            font-weight: 600;
            padding: 0.36rem 0.85rem;
            line-height: 1;
            cursor: pointer;
        }

        .kixie-blog-share:hover,
        .kixie-blog-share:focus {
            border-color: #bbb5ca;
        }

        .kixie-blog-chatgpt-wrap {
            display: inline-flex;
            align-items: center;
        }

        .kixie-blog-chatgpt-button {
            display: inline-flex;
            align-items: center;
            gap: 0.35rem;
            border: 1px solid #d9d7e1;
            background: #ffffff;
            border-radius: 999px;
            color: #3b3156;
            font-size: 0.85rem;
            font-weight: 600;
            padding: 0.36rem 0.85rem;
            line-height: 1;
            text-decoration: none;
            cursor: pointer;
        }

        .kixie-blog-chatgpt-button svg {
            width: 16px;
            height: 16px;
        }

        .kixie-blog-chatgpt-button:hover,
        .kixie-blog-chatgpt-button:focus {
            border-color: #bbb5ca;
            color: #3b3156;
            text-decoration: none;
        }

        .kixie-blog-featured-image {
            margin-top: 1.45rem;
            border-radius: 1rem;
            overflow: hidden;
            border: 1px solid #e4e1ea;
            background: #f7f7fa;
        }

        .kixie-blog-featured-image img {
            width: 100%;
            height: auto;
            display: block;
            object-fit: cover;
        }

        .kixie-blog-layout {
            max-width: 1030px;
            margin: 0 auto;
            display: grid;
            grid-template-columns: 250px minmax(0, 1fr);
            gap: 2.6rem;
            align-items: start;
        }

        .kixie-blog-sidebar {
            min-width: 0;
        }

        .kixie-blog-toc {
            position: sticky;
            top: 8.1rem;
            border: 1px solid #e6e2ee;
            background: #fcfcfe;
            border-radius: 0.85rem;
            padding: 1rem;
        }

        .admin-bar .kixie-blog-toc {
            top: calc(8.1rem + 32px);
        }

        .kixie-blog-toc h2 {
            margin: 0 0 0.7rem;
            color: #54496f;
            font-size: 0.75rem;
            text-transform: uppercase;
            letter-spacing: 0.08em;
            font-weight: 700;
        }

        .kixie-blog-toc ul {
            list-style: none;
            margin: 0;
            padding: 0;
            display: flex;
            flex-direction: column;
            gap: 0.25rem;
        }

        .kixie-blog-toc li a {
            display: block;
            color: #5f5772;
            text-decoration: none;
            border-left: 2px solid #e4e0eb;
            padding: 0.38rem 0 0.38rem 0.6rem;
            line-height: 1.3;
            font-size: 0.9rem;
            transition: color 0.2s ease, border-color 0.2s ease;
        }

        .kixie-blog-toc li.is-subheading a {
            font-size: 0.84rem;
            padding-left: 0.9rem;
        }

        .kixie-blog-toc li a:hover,
        .kixie-blog-toc li a:focus {
            color: #2b1f48;
            border-left-color: #6c43cc;
        }

        .kixie-blog-article {
            min-width: 0;
        }

        .kixie-blog-content {
            color: #2f2546;
            font-size: 1.08rem;
            line-height: 1.72;
        }

        .kixie-blog-content > *:first-child {
            margin-top: 0;
        }

        .kixie-blog-content p {
            margin: 0 0 1rem;
        }

        .kixie-blog-content h2,
        .kixie-blog-content h3,
        .kixie-blog-content h4 {
            color: #1f1533;
            letter-spacing: -0.02em;
            line-height: 1.24;
            margin-top: 2rem;
            margin-bottom: 0.8rem;
            scroll-margin-top: 8rem;
        }

        .kixie-blog-content h2 {
            font-size: clamp(1.45rem, 2.1vw, 2rem);
        }

        .kixie-blog-content h3 {
            font-size: clamp(1.2rem, 1.7vw, 1.5rem);
        }

        .kixie-blog-content h4 {
            font-size: clamp(1.05rem, 1.45vw, 1.2rem);
        }

        @media (min-width: 1200px) {
            .kixie-blog-wrap {
                max-width: 1280px;
            }

            .kixie-blog-hero {
                max-width: 1040px;
            }

            .kixie-blog-layout {
                max-width: 1120px;
                grid-template-columns: 270px minmax(0, 1fr);
            }
        }

        .kixie-blog-content ul,
        .kixie-blog-content ol {
            margin: 0 0 1rem 1.2rem;
            padding: 0;
        }

        .kixie-blog-content li {
            margin-bottom: 0.5rem;
        }

        .kixie-blog-content img {
            display: block;
            max-width: 100% !important;
            width: auto;
            height: auto !important;
            margin: 1rem auto;
        }

        .kixie-blog-content figure,
        .kixie-blog-content .wp-block-image {
            max-width: 100%;
            margin: 1rem 0;
        }

        .kixie-blog-content figure img,
        .kixie-blog-content .wp-block-image img {
            width: 100%;
            max-width: 100% !important;
            height: auto !important;
        }

        .kixie-blog-content table {
            width: 100%;
            border-collapse: collapse;
            border: 1px solid #e3e0ea;
            border-radius: 0.75rem;
            overflow: hidden;
            margin: 1rem 0;
            font-size: 0.95rem;
            background: #fff;
        }

        .kixie-blog-content th,
        .kixie-blog-content td {
            border: 1px solid #e9e5ef;
            padding: 0.65rem 0.75rem;
            text-align: left;
        }

        .kixie-blog-content th {
            background: #f7f5fb;
            color: #2b1f48;
            font-weight: 700;
        }

        .kixie-blog-content blockquote {
            margin: 1rem 0;
            border-left: 3px solid #d5cdf3;
            padding-left: 0.9rem;
            color: #4a3f66;
            font-style: italic;
        }

        .kixie-blog-content a {
            color: #5b2fc7;
            text-decoration: underline;
            text-underline-offset: 2px;
        }

        .kixie-blog-content a:hover,
        .kixie-blog-content a:focus {
            color: #451a9f;
        }

        .kixie-blog-cta {
            margin-top: 2.1rem;
            border: 1px solid #e6e1ee;
            border-radius: 1rem;
            background: #ffffff;
            padding: 1.5rem;
            text-align: center;
        }

        .kixie-blog-cta h2 {
            margin: 0 0 0.6rem;
            color: #201635;
            font-size: 1.4rem;
            line-height: 1.22;
        }

        .kixie-blog-cta p {
            margin: 0 auto 1rem;
            max-width: 36rem;
            color: #6a617a;
        }

        .kixie-blog-cta-button {
            display: inline-flex;
            align-items: center;
            justify-content: center;
            min-height: 2.75rem;
            border-radius: 999px;
            background: #ef4444;
            color: #fff;
            text-decoration: none;
            font-weight: 700;
            letter-spacing: 0.01em;
            padding: 0.55rem 1.45rem;
            transition: background-color 0.2s ease;
        }

        .kixie-blog-cta-button:hover,
        .kixie-blog-cta-button:focus {
            background: #dc2626;
        }

        .kixie-blog-related {
            margin-top: 2rem;
        }

        .kixie-blog-related h2 {
            margin: 0 0 0.9rem;
            color: #201635;
            font-size: 1.4rem;
            line-height: 1.22;
        }

        .kixie-blog-related ul {
            list-style: none;
            margin: 0;
            padding: 0;
            display: grid;
            gap: 0.55rem;
        }

        .kixie-blog-related a {
            color: #5b2fc7;
            text-decoration: none;
            line-height: 1.35;
        }

        .kixie-blog-related a:hover,
        .kixie-blog-related a:focus {
            text-decoration: underline;
        }

        @media (max-width: 1024px) {
            .kixie-blog-layout {
                grid-template-columns: 1fr;
                gap: 1.5rem;
            }

            .kixie-blog-sidebar {
                order: 2;
            }

            .kixie-blog-article {
                order: 1;
            }

            .kixie-blog-toc {
                position: static;
            }
        }

        @media (max-width: 782px) {
            .kixie-blog-post-template {
                padding-top: 9.2rem;
                padding-bottom: 3.2rem;
            }

            .admin-bar .kixie-blog-post-template {
                padding-top: calc(9.2rem + 46px);
            }

            .kixie-blog-title {
                font-size: clamp(1.65rem, 8vw, 2.2rem);
            }

            .kixie-blog-content {
                font-size: 1rem;
                line-height: 1.66;
            }
        }

        /* /sales-blog/ landing page */
        .kixie-blog-index-template {
            padding-top: 8.2rem;
            padding-bottom: 4.5rem;
            background: #f8f7f3;
        }

        .admin-bar .kixie-blog-index-template {
            padding-top: calc(8.2rem + 32px);
        }

        .kixie-blog-index-wrap {
            max-width: 1380px;
            margin: 0 auto;
            padding: 0 1rem;
        }

        .kixie-blog-index-hero {
            max-width: 880px;
            margin: 0 0 2.1rem;
        }

        .kixie-blog-index-hero h1 {
            margin: 0;
            color: #1f1533;
            font-size: clamp(2.55rem, 5vw, 4.2rem);
            line-height: 1.03;
            letter-spacing: -0.02em;
        }

        .kixie-blog-index-hero p {
            margin: 1rem 0 0;
            color: #6c637f;
            font-size: clamp(1rem, 1.7vw, 1.15rem);
            line-height: 1.5;
            max-width: 760px;
        }

        .kixie-blog-index-filters {
            display: flex;
            align-items: center;
            gap: 0.6rem;
            flex-wrap: wrap;
            margin-bottom: 2rem;
        }

        .kixie-blog-filter-btn {
            border: 1px solid #ddd8e7;
            background: #f3f1f7;
            color: #554c6b;
            border-radius: 999px;
            padding: 0.53rem 1.25rem;
            min-height: 2.6rem;
            font-size: 1.03rem;
            font-weight: 600;
            line-height: 1;
            cursor: pointer;
            transition: border-color 0.2s ease, background-color 0.2s ease, color 0.2s ease;
        }

        .kixie-blog-filter-btn:hover,
        .kixie-blog-filter-btn:focus {
            border-color: #c9bbec;
            color: #3f3160;
        }

        .kixie-blog-filter-btn.is-active {
            background: #fff;
            border-color: #ccbbf6;
            color: #2b1f48;
        }

        .kixie-blog-index-grid {
            display: grid;
            grid-template-columns: repeat(3, minmax(0, 1fr));
            gap: 2rem;
        }

        .kixie-blog-card {
            min-width: 0;
        }

        .kixie-blog-card-link {
            display: flex;
            flex-direction: column;
            height: 100%;
            border-radius: 1rem;
            border: 1px solid #ddd9e6;
            background: #fff;
            overflow: hidden;
            text-decoration: none;
            transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
        }

        .kixie-blog-card-link:hover,
        .kixie-blog-card-link:focus {
            transform: translateY(-2px);
            border-color: #cfbce9;
            box-shadow: 0 16px 30px -22px rgba(49, 34, 90, 0.45);
        }

        .kixie-blog-card-image-wrap {
            aspect-ratio: 16 / 10;
            background: #edf3fb;
            overflow: hidden;
        }

        .kixie-blog-card-image-wrap img {
            width: 100%;
            height: 100%;
            object-fit: cover;
            display: block;
        }

        .kixie-blog-card-placeholder {
            width: 100%;
            height: 100%;
            background: linear-gradient(180deg, #dfe8f5 0%, #f2f7fd 100%);
        }

        .kixie-blog-card-content {
            padding: 1rem 1.2rem 1.3rem;
        }

        .kixie-blog-card-category {
            display: inline-block;
            margin-bottom: 0.55rem;
            color: #f10606;
            font-size: 0.82rem;
            font-weight: 700;
            letter-spacing: 0.08em;
            line-height: 1.2;
            text-transform: uppercase;
        }

        .kixie-blog-card h2 {
            margin: 0;
            color: #1f1533;
            font-size: clamp(1.2rem, 2vw, 2rem);
            line-height: 1.3;
            letter-spacing: -0.01em;
        }

        .kixie-blog-index-empty {
            color: #655c77;
            font-size: 1rem;
        }

        .kixie-blog-index-load-status {
            min-height: 1.35rem;
            margin-top: 1.25rem;
            color: #655c77;
            font-size: 0.95rem;
            line-height: 1.3;
        }

        .kixie-blog-index-load-status.is-error {
            color: #b42318;
        }

        .kixie-blog-index-sentinel {
            width: 100%;
            height: 1px;
        }

        @media (max-width: 1180px) {
            .kixie-blog-index-grid {
                grid-template-columns: repeat(2, minmax(0, 1fr));
            }
        }

        @media (max-width: 782px) {
            .kixie-blog-index-template {
                padding-top: 9.15rem;
                padding-bottom: 3.3rem;
            }

            .admin-bar .kixie-blog-index-template {
                padding-top: calc(9.15rem + 46px);
            }

            .kixie-blog-index-grid {
                grid-template-columns: 1fr;
                gap: 1.2rem;
            }

            .kixie-blog-filter-btn {
                font-size: 0.95rem;
                min-height: 2.35rem;
                padding: 0.45rem 1rem;
            }
        }

        .kixie-nav-desktop {
            margin-left: 0;
            flex: 0 1 auto;
            min-width: auto;
            display: flex;
            justify-content: center;
        }

        .kixie-nav-menu,
        .kixie-mobile-nav-menu,
        .kixie-mobile-nav-menu .sub-menu {
            list-style: none;
            margin: 0;
            padding: 0;
        }

        .kixie-nav-menu {
            display: flex;
            align-items: center;
            justify-content: center;
            gap: 0.125rem;
            width: auto;
        }

        .kixie-nav-menu > li {
            position: relative;
        }

        .kixie-nav-menu > li > a {
            display: inline-flex;
            align-items: center;
            gap: 0.25rem;
            padding: 0.5rem 0.75rem;
            color: #4b5563;
            text-decoration: none;
            font-size: 0.875rem;
            font-weight: 500;
            line-height: 1.25rem;
            transition: color 0.2s ease;
        }

        .kixie-nav-menu > li > a:hover,
        .kixie-nav-menu > li > a:focus {
            color: #111827;
        }

        .kixie-nav-menu-mega {
            gap: 0.125rem;
        }

        .kixie-nav-item {
            position: relative;
        }

        .kixie-nav-trigger,
        .kixie-nav-link {
            display: inline-flex;
            align-items: center;
            gap: 0.25rem;
            padding: 0.5rem 0.75rem;
            color: #4b5563;
            text-decoration: none;
            font-size: 0.875rem;
            font-weight: 500;
            line-height: 1.25rem;
            border: 0;
            background: transparent;
            cursor: pointer;
            border-radius: 0.375rem;
            transition: color 0.2s ease;
        }

        .kixie-nav-trigger:hover,
        .kixie-nav-trigger:focus,
        .kixie-nav-link:hover,
        .kixie-nav-link:focus {
            color: #111827;
            background: transparent;
        }

        .kixie-nav-item.is-open .kixie-nav-trigger {
            color: #111827;
        }

        .kixie-nav-chevron {
            width: 0.875rem;
            height: 0.875rem;
            color: #9ca3af;
            transition: transform 0.2s ease, color 0.2s ease;
        }

        .kixie-nav-item.is-open .kixie-nav-chevron {
            transform: rotate(180deg);
            color: #111827;
        }

        .kixie-nav-link-chevron:hover .kixie-nav-chevron,
        .kixie-nav-link-chevron:focus .kixie-nav-chevron {
            color: #4b5563;
        }

        .kixie-mega-menu {
            position: absolute;
            top: calc(100% - 2px);
            left: 0;
            z-index: 1200;
            border: 1px solid #f3f4f6;
            border-radius: 0.75rem;
            background: #fff;
            box-shadow: 0 20px 25px -5px rgba(17, 24, 39, 0.1), 0 8px 10px -6px rgba(17, 24, 39, 0.1);
            overflow: hidden;
            min-width: 0;
        }

        .kixie-mega-menu[hidden] {
            display: none !important;
        }

        .kixie-mega-platform {
            width: 20rem;
            max-width: min(92vw, 20rem);
            min-width: min(20rem, calc(100vw - 2.5rem));
        }

        .kixie-site-header .kixie-nav-item.has-mega > .kixie-mega-menu.kixie-mega-platform {
            width: min(20rem, calc(100vw - 2.5rem)) !important;
            max-width: min(20rem, calc(100vw - 2.5rem)) !important;
            min-width: min(20rem, calc(100vw - 2.5rem)) !important;
        }

        .kixie-mega-solutions {
            width: 680px;
            max-width: min(94vw, 680px);
            border-color: #f3f4f6;
            border-radius: 0.75rem;
            box-shadow: 0 20px 25px -5px rgba(17, 24, 39, 0.1), 0 8px 10px -6px rgba(17, 24, 39, 0.1);
        }

        .kixie-mega-inner {
            padding: 0.5rem;
        }

        .kixie-mega-heading {
            margin: 0;
            padding: 0.5rem 0.75rem;
            text-transform: uppercase;
            letter-spacing: 0.05em;
            font-size: 0.75rem;
            line-height: 1rem;
            color: #9ca3af;
            font-weight: 600;
        }

        .kixie-mega-feature-list {
            display: grid;
            gap: 0;
        }

        .kixie-mega-feature-item {
            display: flex;
            align-items: flex-start;
            gap: 0.75rem;
            padding: 0.75rem;
            border-radius: 0.5rem;
            text-decoration: none;
            transition: background-color 0.2s ease;
        }

        .kixie-mega-feature-item:hover,
        .kixie-mega-feature-item:focus {
            background: #f9fafb;
        }

        .kixie-mega-icon {
            width: 2.5rem;
            height: 2.5rem;
            flex: 0 0 2.5rem;
            border-radius: 0.5rem;
            background: linear-gradient(135deg, rgba(232, 72, 63, 0.1) 0%, rgba(127, 67, 221, 0.16) 100%);
            color: #8b33e6;
            display: inline-flex;
            align-items: center;
            justify-content: center;
        }

        .kixie-mega-icon svg {
            width: 1.25rem;
            height: 1.25rem;
        }

        .kixie-mega-copy {
            display: flex;
            flex-direction: column;
            gap: 0.1rem;
            min-width: 0;
            width: auto;
        }

        .kixie-site-header .kixie-mega-platform .kixie-mega-copy {
            max-width: none !important;
            width: auto;
        }

        .kixie-mega-title {
            color: #111827;
            font-size: 1rem;
            font-weight: 500;
            line-height: 1.5rem;
            transition: color 0.2s ease;
        }

        .kixie-mega-feature-item:hover .kixie-mega-title,
        .kixie-mega-feature-item:focus .kixie-mega-title {
            color: #8b33e6;
        }

        .kixie-mega-description {
            color: #6b7280;
            font-size: 0.875rem;
            line-height: 1.25rem;
            max-width: none;
        }

        .kixie-mega-footer {
            border-top: 1px solid #e3e5ea;
            padding: 0.7rem 1rem 0.8rem;
            background: #f2f4f7;
        }

        .kixie-mega-footer-link {
            color: #8b33e6;
            text-decoration: none;
            font-weight: 500;
            font-size: 0.875rem;
        }

        .kixie-mega-footer-link:hover,
        .kixie-mega-footer-link:focus {
            color: #6d28d9;
            text-decoration: underline;
        }

        .kixie-mega-solutions-grid {
            display: grid;
            grid-template-columns: repeat(3, minmax(0, 1fr));
            gap: 1rem;
            padding: 1rem;
        }

        .kixie-mega-solutions-column {
            min-width: 0;
        }

        .kixie-mega-solutions .kixie-mega-heading {
            margin: 0;
            padding: 0.5rem 0.75rem;
            color: #9ca3af;
            font-size: 0.75rem;
            line-height: 1rem;
            letter-spacing: 0.05em;
            font-weight: 600;
        }

        .kixie-mega-solutions-column .kixie-mega-solution-item + .kixie-mega-solution-item {
            margin-top: 0.125rem;
        }

        .kixie-mega-solution-item {
            display: flex;
            align-items: center;
            gap: 0.625rem;
            padding: 0.5rem 0.75rem;
            border-radius: 0.5rem;
            text-decoration: none;
            color: #374151;
            font-size: 0.875rem;
            line-height: 1.25rem;
            font-weight: 500;
            transition: background-color 0.2s ease, color 0.2s ease;
        }

        .kixie-mega-solution-item:hover,
        .kixie-mega-solution-item:focus {
            background: #f9fafb;
            color: #8b33e6;
        }

        .kixie-mega-solution-icon {
            width: 1rem;
            height: 1rem;
            color: #8b33e6;
            flex: 0 0 1rem;
        }

        .kixie-mega-solution-icon svg {
            width: 100%;
            height: 100%;
        }

        .kixie-mega-solution-item > span {
            line-height: 1.25rem;
        }

        .kixie-site-header .kixie-nav-desktop .kixie-nav-menu > li.menu-item-has-children > a::after,
        .kixie-site-header .kixie-nav-desktop .kixie-nav-menu > li.menu-item-has-children > button::after {
            content: none !important;
            display: none !important;
        }

        @media (min-width: 1024px) {
            .kixie-site-header .kixie-nav-item.has-mega:hover > .kixie-mega-menu,
            .kixie-site-header .kixie-nav-item.has-mega:focus-within > .kixie-mega-menu {
                display: block !important;
            }

            .kixie-site-header .kixie-nav-item.has-mega:hover > .kixie-nav-trigger,
            .kixie-site-header .kixie-nav-item.has-mega:focus-within > .kixie-nav-trigger {
                color: #111827;
            }

            .kixie-site-header .kixie-nav-item.has-mega:hover > .kixie-nav-trigger .kixie-nav-chevron,
            .kixie-site-header .kixie-nav-item.has-mega:focus-within > .kixie-nav-trigger .kixie-nav-chevron {
                transform: rotate(180deg);
                color: #111827;
            }
        }

        .kixie-nav-menu .sub-menu {
            display: none;
            position: absolute;
            top: calc(100% - 2px);
            left: 0;
            margin-top: 0;
            min-width: 220px;
            background: #fff;
            border: 1px solid #e5e7eb;
            border-radius: 0.5rem;
            padding: 0.35rem;
            box-shadow: 0 12px 20px rgba(17, 24, 39, 0.09);
            z-index: 1200;
        }

        .kixie-nav-menu li:hover > .sub-menu,
        .kixie-nav-menu li:focus-within > .sub-menu {
            display: block;
        }

        .kixie-nav-menu .sub-menu li a {
            display: block;
            color: #374151;
            text-decoration: none;
            font-size: 0.875rem;
            border-radius: 0.375rem;
            padding: 0.55rem 0.65rem;
        }

        .kixie-nav-menu .sub-menu li a:hover,
        .kixie-nav-menu .sub-menu li a:focus {
            background: #f9fafb;
            color: #111827;
        }

        .kixie-cta-group {
            display: flex;
            align-items: center;
            gap: 0.5rem;
            margin-left: 0;
        }

        .kixie-cta-spacer {
            display: none;
        }

        .kixie-cta-group .kixie-contact-link {
            display: none !important;
        }

        .kixie-contact-link {
            font-size: 0.875rem;
            color: #4b5563;
            text-decoration: none;
            line-height: 1.25rem;
            padding: 0.5rem 0.75rem;
            border-radius: 0.375rem;
            transition: color 0.2s ease;
        }

        .kixie-contact-link:hover,
        .kixie-contact-link:focus {
            color: #111827;
        }

        .kixie-btn {
            display: inline-flex;
            align-items: center;
            justify-content: center;
            height: 2.25rem;
            min-height: 2.25rem;
            border-radius: 0.5rem;
            text-decoration: none;
            font-size: 0.875rem;
            font-weight: 500;
            letter-spacing: 0;
            line-height: 1.25rem;
            padding: 0 0.75rem;
            transition: all 0.2s ease;
            border: 1px solid transparent;
            white-space: nowrap;
        }

        .kixie-btn-outline {
            border-color: #e5e7eb;
            background: #fff;
            color: #111827;
        }

        .kixie-btn-outline:hover,
        .kixie-btn-outline:focus {
            background: #f9fafb;
        }

        .kixie-btn-primary {
            background: #ef4444;
            color: #fff;
        }

        .kixie-btn-primary:hover,
        .kixie-btn-primary:focus {
            background: #dc2626;
            color: #fff;
        }

        .kixie-mobile-toggle {
            display: none;
            background: transparent;
            border: 0;
            width: 2.5rem;
            height: 2.5rem;
            border-radius: 0.5rem;
            color: #111827;
            align-items: center;
            justify-content: center;
            cursor: pointer;
        }

        .kixie-mobile-toggle:hover,
        .kixie-mobile-toggle:focus {
            background: #f3f4f6;
        }

        .kixie-mobile-toggle svg {
            width: 1.4rem;
            height: 1.4rem;
        }

        .kixie-mobile-toggle .is-hidden {
            display: none;
        }

        .kixie-mobile-menu {
            background: #fff;
            border-top: 1px solid #f3f4f6;
            box-shadow: 0 14px 24px rgba(17, 24, 39, 0.08);
            max-height: 80vh;
            overflow-y: auto;
            opacity: 0;
            transform: translateY(-8px);
            transition: opacity 0.18s ease, transform 0.18s ease;
        }

        .kixie-mobile-menu.is-open {
            opacity: 1;
            transform: translateY(0);
        }

        .kixie-mobile-menu .kixie-container {
            padding-top: 1rem;
            padding-bottom: 1rem;
        }

        .kixie-mobile-menu-inner {
            display: grid;
            gap: 0.5rem;
        }

        .kixie-mobile-section {
            display: grid;
            gap: 0.25rem;
        }

        .kixie-mobile-section-divider {
            border-top: 1px solid #f3f4f6;
            padding-top: 0.5rem;
        }

        .kixie-mobile-section-heading {
            margin: 0;
            padding: 0.5rem 1rem;
            text-transform: uppercase;
            letter-spacing: 0.05em;
            color: #9ca3af;
            font-size: 0.75rem;
            line-height: 1rem;
            font-weight: 600;
        }

        .kixie-mobile-feature-link,
        .kixie-mobile-link {
            display: flex;
            align-items: center;
            gap: 0.75rem;
            padding: 0.75rem 1rem;
            text-decoration: none;
            color: #4b5563;
            border-radius: 0.5rem;
            font-size: 0.95rem;
            line-height: 1.25rem;
            transition: color 0.2s ease, background-color 0.2s ease;
        }

        .kixie-mobile-link {
            gap: 0;
        }

        .kixie-mobile-feature-link:hover,
        .kixie-mobile-feature-link:focus,
        .kixie-mobile-link:hover,
        .kixie-mobile-link:focus {
            color: #111827;
            background: #f9fafb;
        }

        .kixie-mobile-feature-icon {
            width: 1.25rem;
            height: 1.25rem;
            color: #8b33e6;
            flex: 0 0 1.25rem;
            display: inline-flex;
            align-items: center;
            justify-content: center;
        }

        .kixie-mobile-feature-icon svg {
            width: 100%;
            height: 100%;
        }

        .kixie-mobile-nav-menu > li {
            position: relative;
        }

        .kixie-mobile-nav-menu > li > a {
            display: block;
            padding: 0.85rem 1rem;
            color: #4b5563;
            text-decoration: none;
            border-radius: 0.55rem;
            font-size: 0.95rem;
            line-height: 1.2;
            padding-right: 3rem;
        }

        .kixie-mobile-nav-menu > li > a:hover,
        .kixie-mobile-nav-menu > li > a:focus {
            color: #111827;
            background: #f9fafb;
        }

        .kixie-mobile-nav-menu .sub-menu {
            margin: 0.25rem 0 0.6rem;
            padding-left: 0.65rem;
        }

        .kixie-mobile-nav-menu .sub-menu li a {
            display: block;
            padding: 0.65rem 0.75rem;
            border-radius: 0.5rem;
            color: #6b7280;
            text-decoration: none;
            font-size: 0.88rem;
        }

        .kixie-mobile-nav-menu .sub-menu li a:hover,
        .kixie-mobile-nav-menu .sub-menu li a:focus {
            background: #f9fafb;
            color: #111827;
        }

        .mobile-submenu-toggle {
            position: absolute;
            top: 0.5rem;
            right: 0.5rem;
            width: 2rem;
            height: 2rem;
            border: 0;
            border-radius: 0.45rem;
            background: transparent;
            color: #6b7280;
            display: inline-flex;
            align-items: center;
            justify-content: center;
            cursor: pointer;
        }

        .mobile-submenu-toggle:hover,
        .mobile-submenu-toggle:focus {
            background: #f3f4f6;
            color: #111827;
        }

        .menu-item-has-children.is-open > .mobile-submenu-toggle svg {
            transform: rotate(180deg);
        }

        .mobile-submenu-toggle svg {
            width: 1rem;
            height: 1rem;
            transition: transform 0.15s ease;
        }

        .kixie-mobile-cta {
            border-top: 1px solid #f3f4f6;
            margin-top: 0.5rem;
            padding-top: 1rem;
            display: grid;
            gap: 0.5rem;
        }

        .kixie-mobile-cta .kixie-contact-link {
            display: none !important;
            padding: 0.75rem 1rem;
            border-radius: 0.5rem;
        }

        .kixie-mobile-cta .kixie-btn {
            width: 100%;
            min-height: 2.25rem;
            font-size: 0.875rem;
        }

        body.kixie-mobile-menu-open {
            overflow: hidden;
        }

        #mobile-menu[hidden] {
            display: none;
        }

        .screen-reader-text {
            border: 0;
            clip: rect(1px, 1px, 1px, 1px);
            clip-path: inset(50%);
            height: 1px;
            margin: -1px;
            overflow: hidden;
            padding: 0;
            position: absolute;
            width: 1px;
            word-wrap: normal !important;
        }

        /* Guard against parent-theme nav styles leaking into this embedded header. */
        .kixie-site-header ul,
        .kixie-site-header li {
            list-style: none;
            margin: 0;
            padding: 0;
        }

        .kixie-site-header .kixie-nav-desktop .kixie-nav-menu {
            display: flex !important;
            align-items: center !important;
            justify-content: center !important;
            gap: 0.125rem !important;
        }

        .kixie-site-header .kixie-nav-desktop .kixie-nav-menu > li {
            position: relative !important;
            float: none !important;
            width: auto !important;
        }

        .kixie-site-header .kixie-nav-desktop .kixie-nav-menu > li > a {
            display: inline-flex !important;
            align-items: center !important;
        }

        .kixie-site-header .kixie-nav-desktop .kixie-nav-menu > li > button {
            display: inline-flex !important;
            align-items: center !important;
        }

        .kixie-site-header .kixie-nav-desktop .kixie-nav-menu > li > .sub-menu {
            display: none !important;
            position: absolute !important;
            top: calc(100% - 2px) !important;
            left: 0 !important;
            margin-top: 0 !important;
        }

        .kixie-site-header .kixie-nav-desktop .kixie-nav-menu > li:hover > .sub-menu,
        .kixie-site-header .kixie-nav-desktop .kixie-nav-menu > li:focus-within > .sub-menu {
            display: block !important;
        }

        /* Fallback selectors when plugins/filters rewrite menu classes/wrappers. */
        .kixie-site-header .kixie-nav-desktop > ul,
        .kixie-site-header .kixie-nav-desktop > div > ul {
            display: flex !important;
            align-items: center !important;
            justify-content: center !important;
            gap: 0.125rem !important;
            margin: 0 !important;
            padding: 0 !important;
        }

        .kixie-site-header .kixie-nav-desktop > ul > li,
        .kixie-site-header .kixie-nav-desktop > div > ul > li {
            position: relative !important;
            float: none !important;
            width: auto !important;
            margin: 0 !important;
            padding: 0 !important;
        }

        .kixie-site-header .kixie-nav-desktop > ul > li > ul,
        .kixie-site-header .kixie-nav-desktop > div > ul > li > ul {
            display: none !important;
            position: absolute !important;
            top: calc(100% - 2px) !important;
            left: 0 !important;
            min-width: 220px !important;
            margin-top: 0 !important;
            background: #fff !important;
            border: 1px solid #e5e7eb !important;
            border-radius: 0.5rem !important;
            padding: 0.35rem !important;
            box-shadow: 0 12px 20px rgba(17, 24, 39, 0.09) !important;
            z-index: 1200 !important;
        }

        .kixie-site-header .kixie-nav-desktop > ul > li:hover > ul,
        .kixie-site-header .kixie-nav-desktop > ul > li:focus-within > ul,
        .kixie-site-header .kixie-nav-desktop > div > ul > li:hover > ul,
        .kixie-site-header .kixie-nav-desktop > div > ul > li:focus-within > ul {
            display: block !important;
        }

        /* Broad fallback: hide any nested desktop menu lists until hover/focus. */
        .kixie-site-header .kixie-nav-desktop ul ul {
            display: none !important;
            position: absolute !important;
            top: calc(100% - 2px) !important;
            left: 0 !important;
            min-width: 220px !important;
            margin-top: 0 !important;
            background: #fff !important;
            border: 1px solid #e5e7eb !important;
            border-radius: 0.5rem !important;
            padding: 0.35rem !important;
            box-shadow: 0 12px 20px rgba(17, 24, 39, 0.09) !important;
            z-index: 1200 !important;
        }

        .kixie-site-header .kixie-nav-desktop li:hover > ul,
        .kixie-site-header .kixie-nav-desktop li:focus-within > ul {
            display: block !important;
        }

        .kixie-site-header #mobile-menu[hidden] {
            display: none !important;
        }

        @media (min-width: 1024px) {
            .kixie-mobile-toggle,
            .kixie-mobile-menu {
                display: none !important;
            }
        }

        @media (max-width: 1023px) {
            .kixie-nav-desktop,
            .kixie-cta-group {
                display: none;
            }

            .kixie-mega-menu {
                display: none !important;
            }

            .kixie-nav-inner {
                justify-content: space-between;
                gap: 0.75rem;
            }

            .kixie-mobile-toggle {
                display: inline-flex;
            }
        }

        @media (max-width: 767px) {
            .kixie-hello-inner {
                gap: 0.5rem;
            }

            .kixie-hello-text {
                flex-basis: 100%;
            }
        }

        @media (max-width: 782px) {
            .admin-bar .kixie-site-header {
                top: 46px;
            }
        }

/* Footer */
.kixie-site-footer,
    .kixie-site-footer * {
        box-sizing: border-box;
        font-family: 'DM Sans', system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, sans-serif;
    }

    .kixie-site-footer {
        background: radial-gradient(100% 160% at 10% 0%, #2b1f44 0%, #1f1933 45%, #181326 100%);
        color: #ffffff;
        padding: 4rem 0 2rem;
    }

    .kixie-footer-container {
        width: 100%;
        max-width: 1400px;
        margin: 0 auto;
        padding: 0 2rem;
    }

    .kixie-footer-grid {
        display: grid;
        grid-template-columns: 1.3fr repeat(4, minmax(0, 1fr));
        gap: 2rem;
        padding-bottom: 3rem;
    }

    .kixie-footer-brand-link {
        display: inline-flex;
        align-items: center;
        text-decoration: none;
        margin-bottom: 1rem;
    }

    .kixie-footer-logo-image {
        display: block;
        width: auto;
        height: 2rem;
        max-width: 10.5rem;
    }

    .kixie-footer-mark {
        width: 1.35rem;
        height: 1.35rem;
        border-radius: 0.3rem;
        background: #ef4444;
        color: #ffffff;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        font-size: 0.8rem;
        font-weight: 700;
        line-height: 1;
    }

    .kixie-footer-logo {
        color: #ffffff;
        font-size: 1.4rem;
        font-weight: 700;
        letter-spacing: -0.02em;
        line-height: 1;
        text-transform: lowercase;
    }

    .kixie-footer-copy {
        color: rgba(255, 255, 255, 0.68);
        font-size: 0.96rem;
        line-height: 1.5;
        max-width: 18rem;
        margin: 0;
    }

    .kixie-footer-title {
        margin: 0 0 0.95rem;
        color: #ffffff;
        font-size: 1rem;
        font-weight: 600;
        line-height: 1.2;
    }

    .kixie-footer-list {
        list-style: none;
        margin: 0;
        padding: 0;
        display: grid;
        gap: 0.65rem;
    }

    .kixie-footer-list a {
        color: rgba(255, 255, 255, 0.66);
        text-decoration: none;
        font-size: 0.95rem;
        line-height: 1.35;
        transition: color 0.18s ease;
    }

    .kixie-footer-list a:hover,
    .kixie-footer-list a:focus {
        color: #ffffff;
    }

    .kixie-footer-bottom {
        border-top: 1px solid rgba(255, 255, 255, 0.1);
        padding-top: 1.6rem;
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 1rem;
    }

    .kixie-footer-bottom p {
        margin: 0;
        color: rgba(255, 255, 255, 0.62);
        font-size: 0.9rem;
    }

    .kixie-footer-legal {
        display: flex;
        align-items: center;
        gap: 1.5rem;
    }

    .kixie-footer-legal a {
        color: rgba(255, 255, 255, 0.62);
        text-decoration: none;
        font-size: 0.9rem;
        transition: color 0.18s ease;
    }

    .kixie-footer-legal a:hover,
    .kixie-footer-legal a:focus {
        color: #ffffff;
    }

    @media (max-width: 1023px) {
        .kixie-footer-grid {
            grid-template-columns: repeat(2, minmax(0, 1fr));
        }

        .kixie-footer-brand {
            grid-column: 1 / -1;
        }
    }

    @media (max-width: 767px) {
        .kixie-footer-container {
            padding: 0 1.25rem;
        }

        .kixie-footer-grid {
            grid-template-columns: 1fr;
            gap: 1.6rem;
            padding-bottom: 2rem;
        }

        .kixie-footer-bottom {
            flex-direction: column;
            align-items: flex-start;
        }
    }

/* Solutions Template */
.kixie-solutions-page {
    background: #f5f6fa;
    color: #1f1533;
}

.kixie-solutions-container {
    width: 100%;
    max-width: 1280px;
    margin: 0 auto;
    padding: 0 2rem;
}

.kixie-solutions-center {
    display: flex;
    justify-content: center;
    align-items: center;
}

.kixie-solutions-hero {
    padding: 9.5rem 0 4.5rem;
    background: #ffffff;
}

.kixie-solutions-hero-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.08fr) minmax(0, 1fr);
    gap: 3rem;
    align-items: center;
}

.kixie-solutions-hero-copy {
    max-width: 44rem;
}

.kixie-solutions-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    padding: 0.45rem 0.95rem;
    font-size: 0.82rem;
    font-weight: 600;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: #6d28d9;
    background: rgba(109, 40, 217, 0.1);
}

.kixie-solutions-badge-muted {
    color: #7c3aed;
    background: rgba(124, 58, 237, 0.12);
}

.kixie-solutions-title {
    margin: 1.15rem 0 1rem;
    font-size: clamp(2rem, 4.9vw, 3.35rem);
    line-height: 1.08;
    letter-spacing: -0.03em;
    color: #1f1533;
}

.kixie-solutions-description {
    margin: 0;
    color: #5e5a78;
    font-size: clamp(1rem, 2vw, 1.2rem);
    line-height: 1.66;
    max-width: 40rem;
}

.kixie-solutions-hero-actions {
    margin-top: 2rem;
    display: flex;
    flex-wrap: wrap;
    gap: 0.85rem;
}

.kixie-solutions-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    border: 1px solid transparent;
    text-decoration: none;
    font-weight: 700;
    font-size: 0.92rem;
    min-height: 2.85rem;
    padding: 0.55rem 1.35rem;
    letter-spacing: 0.01em;
    transition: all 0.2s ease;
}

.kixie-solutions-btn-primary {
    background: #ef4444;
    color: #ffffff;
}

.kixie-solutions-btn-primary:hover,
.kixie-solutions-btn-primary:focus {
    background: #dc2626;
    color: #ffffff;
}

.kixie-solutions-btn-secondary {
    background: #ffffff;
    border-color: #d7dae6;
    color: #1f1533;
}

.kixie-solutions-btn-secondary:hover,
.kixie-solutions-btn-secondary:focus {
    border-color: #9aa5bf;
    color: #1f1533;
}

.kixie-solutions-btn-light {
    background: #ffffff;
    color: #111827;
}

.kixie-solutions-btn-light:hover,
.kixie-solutions-btn-light:focus {
    background: #f1f5f9;
    color: #0f172a;
}

.kixie-solutions-hero-media img {
    width: 100%;
    max-width: 600px;
    border-radius: 1.15rem;
    box-shadow: 0 24px 55px -35px rgba(17, 24, 39, 0.4);
}

.kixie-solutions-trusted {
    padding: 3.2rem 0;
    background: #ffffff;
}

.kixie-solutions-section-kicker {
    margin: 0 0 1.45rem;
    text-align: center;
    font-size: 0.76rem;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: #7b7991;
    font-weight: 600;
}

.kixie-solutions-marquee-shell {
    position: relative;
    overflow: hidden;
    padding: 0.3rem 0;
}

.kixie-solutions-marquee-shell::before,
.kixie-solutions-marquee-shell::after {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    width: 5rem;
    z-index: 2;
    pointer-events: none;
}

.kixie-solutions-marquee-shell::before {
    left: 0;
    background: linear-gradient(to right, #ffffff 0%, rgba(255, 255, 255, 0) 100%);
}

.kixie-solutions-marquee-shell::after {
    right: 0;
    background: linear-gradient(to left, #ffffff 0%, rgba(255, 255, 255, 0) 100%);
}

.kixie-solutions-marquee-track {
    width: max-content;
    display: flex;
    align-items: center;
    gap: 2.25rem;
    animation: kixie-solutions-marquee 36s linear infinite;
}

.kixie-solutions-marquee-track-fast {
    gap: 0.95rem;
    animation-duration: 40s;
}

.kixie-solutions-marquee-track-reverse {
    animation-name: kixie-solutions-marquee-reverse;
    animation-duration: 38s;
    margin-top: 0.75rem;
}

.kixie-solutions-logo-item {
    flex: 0 0 auto;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0.84;
    transition: opacity 0.2s ease;
}

.kixie-solutions-logo-item:hover {
    opacity: 1;
}

.kixie-solutions-logo-item img {
    height: 2.1rem;
    width: auto;
    object-fit: contain;
}

.kixie-solutions-benefits {
    padding: 5.8rem 0;
    background: linear-gradient(140deg, rgba(239, 68, 68, 0.12), #ffffff 46%, rgba(109, 40, 217, 0.16));
}

.kixie-solutions-heading {
    text-align: center;
    max-width: 54rem;
    margin: 0 auto 2.4rem;
}

.kixie-solutions-heading h2 {
    margin: 1rem 0 0.85rem;
    font-size: clamp(1.9rem, 4vw, 3rem);
    line-height: 1.16;
    letter-spacing: -0.025em;
    color: #1f1533;
}

.kixie-solutions-heading p {
    margin: 0;
    color: #5f5b77;
    font-size: 1.08rem;
    line-height: 1.64;
}

.kixie-solutions-benefits-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1.35rem;
}

.kixie-solutions-card {
    border: 1px solid #e6e8f0;
    border-radius: 1rem;
    background: #ffffff;
    padding: 1.6rem;
    box-shadow: 0 12px 26px -22px rgba(17, 24, 39, 0.35);
}

.kixie-solutions-card h3 {
    margin: 0.9rem 0 0.5rem;
    font-size: 1.2rem;
    line-height: 1.34;
    color: #1f1533;
}

.kixie-solutions-card p {
    margin: 0;
    color: #595575;
    font-size: 0.97rem;
    line-height: 1.7;
}

.kixie-solutions-icon {
    width: 3rem;
    height: 3rem;
    border-radius: 0.8rem;
    background: linear-gradient(135deg, #ef4444, #7c3aed);
    color: #ffffff;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.kixie-solutions-icon svg {
    width: 1.35rem;
    height: 1.35rem;
}

.kixie-solutions-icon-small {
    width: 2.25rem;
    height: 2.25rem;
    border-radius: 0.62rem;
}

.kixie-solutions-icon-small svg {
    width: 1rem;
    height: 1rem;
}

.kixie-solutions-platform {
    padding: 5.8rem 0;
    background: #ffffff;
}

.kixie-solutions-platform-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    column-gap: 1.5rem;
    row-gap: 2rem;
    align-items: stretch;
}

.kixie-solutions-platform-grid > * {
    margin: 0 !important;
    align-self: stretch;
}

.kixie-solutions-platform-card {
    border: 1px solid #e4e6ef;
    border-radius: 1rem;
    background: #ffffff;
    padding: 1.5rem;
    display: flex;
    flex-direction: column;
    min-height: 14.25rem;
    overflow: hidden;
    margin: 0;
    transition: transform 0.22s ease, box-shadow 0.22s ease, border-color 0.22s ease;
}

.kixie-solutions-platform-card:hover {
    transform: translateY(-4px);
    border-color: #d9bdff;
    box-shadow: 0 16px 30px -25px rgba(99, 37, 200, 0.42);
}

.kixie-solutions-platform-card h3 {
    margin: 0.8rem 0 0.42rem;
    font-size: 1rem;
    color: #1f1533;
}

.kixie-solutions-platform-card p {
    margin: 0 0 1rem;
    color: #5a5775;
    font-size: 0.88rem;
    line-height: 1.6;
}

.kixie-solutions-inline-link {
    margin-top: auto;
    display: inline-flex;
    align-items: center;
    font-size: 0.86rem;
    text-decoration: none;
    color: #1f1533;
    font-weight: 600;
}

.kixie-solutions-inline-link:hover,
.kixie-solutions-inline-link:focus {
    color: #7c3aed;
}

.kixie-solutions-testimonial {
    padding: 5.5rem 0;
    background: linear-gradient(145deg, rgba(99, 102, 241, 0.08), rgba(239, 68, 68, 0.08));
}

.kixie-solutions-testimonial blockquote {
    margin: 0 auto;
    max-width: 62rem;
    text-align: center;
    font-size: clamp(1.35rem, 2.8vw, 2.2rem);
    line-height: 1.5;
    color: #1f1533;
}

.kixie-solutions-testimonial strong {
    color: #7c3aed;
}

.kixie-solutions-quote-author {
    margin-top: 1.65rem;
    text-align: center;
}

.kixie-solutions-avatar {
    width: 2.9rem;
    height: 2.9rem;
    margin: 0 auto 0.6rem;
    border-radius: 50%;
    background: linear-gradient(135deg, #ef4444, #7c3aed);
    color: #ffffff;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
}

.kixie-solutions-author-name {
    margin: 0;
    font-weight: 700;
    color: #1f1533;
}

.kixie-solutions-author-meta {
    margin: 0.2rem 0 0;
    color: #64607f;
}

.kixie-solutions-integrations {
    padding: 5.8rem 0;
    background: #fbfbfd;
    border-top: 1px solid #ececf2;
    border-bottom: 1px solid #ececf2;
}

.kixie-solutions-integrations .kixie-solutions-marquee-shell::before {
    background: linear-gradient(to right, #fbfbfd 0%, rgba(251, 251, 253, 0) 100%);
}

.kixie-solutions-integrations .kixie-solutions-marquee-shell::after {
    background: linear-gradient(to left, #fbfbfd 0%, rgba(251, 251, 253, 0) 100%);
}

.kixie-solutions-chip {
    flex: 0 0 auto;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.65rem;
    padding: 0.58rem 0.9rem;
    border-radius: 0.8rem;
    border: 1px solid #dfe3ef;
    background: #ffffff;
    text-decoration: none;
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.kixie-solutions-chip:hover,
.kixie-solutions-chip:focus {
    border-color: #d3b2fd;
    box-shadow: 0 8px 16px -16px rgba(99, 37, 200, 0.85);
}

.kixie-solutions-chip img {
    width: auto;
    height: 2rem;
    object-fit: contain;
}

.kixie-solutions-chip span {
    color: #1f1533;
    font-size: 0.86rem;
    white-space: nowrap;
    font-weight: 600;
}

.kixie-solutions-integrations .kixie-solutions-center {
    margin-top: 1.2rem;
}

.kixie-solutions-cta {
    padding: 5.8rem 0;
}

.kixie-solutions-cta-panel {
    border-radius: 1.5rem;
    padding: 4rem 1.25rem;
    text-align: center;
    background: linear-gradient(90deg, #6b21a8 0%, #7e22ce 50%, #be185d 100%);
    background-size: 200% 100%;
    animation: kixie-solutions-gradient 10s ease-in-out infinite;
}

.kixie-solutions-cta-panel h2 {
    margin: 0;
    color: #ffffff;
    font-size: clamp(1.9rem, 3.8vw, 3rem);
    line-height: 1.16;
    letter-spacing: -0.02em;
}

.kixie-solutions-cta-panel p {
    margin: 0.85rem 0 1.6rem;
    color: rgba(255, 255, 255, 0.82);
    font-size: 1.08rem;
}

@keyframes kixie-solutions-marquee {
    0% {
        transform: translateX(0);
    }
    100% {
        transform: translateX(-50%);
    }
}

@keyframes kixie-solutions-marquee-reverse {
    0% {
        transform: translateX(-50%);
    }
    100% {
        transform: translateX(0);
    }
}

@keyframes kixie-solutions-gradient {
    0%,
    100% {
        background-position: 0% 50%;
    }
    50% {
        background-position: 100% 50%;
    }
}

@media (max-width: 1199px) {
    .kixie-solutions-platform-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

@media (max-width: 1023px) {
    .kixie-solutions-container {
        padding: 0 1.25rem;
    }

    .kixie-solutions-hero-grid {
        grid-template-columns: 1fr;
        gap: 1.8rem;
    }

    .kixie-solutions-hero {
        padding-top: 8.7rem;
    }

    .kixie-solutions-benefits-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .kixie-solutions-platform-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 767px) {
    .kixie-solutions-hero-actions {
        flex-direction: column;
        align-items: stretch;
    }

    .kixie-solutions-btn {
        width: 100%;
    }

    .kixie-solutions-benefits,
    .kixie-solutions-platform,
    .kixie-solutions-integrations,
    .kixie-solutions-cta {
        padding: 4rem 0;
    }

    .kixie-solutions-testimonial {
        padding: 4.2rem 0;
    }

    .kixie-solutions-benefits-grid,
    .kixie-solutions-platform-grid {
        grid-template-columns: 1fr;
    }

    .kixie-solutions-marquee-track {
        gap: 1.45rem;
    }

    .kixie-solutions-logo-item img {
        height: 1.65rem;
    }

    .kixie-solutions-chip {
        padding: 0.52rem 0.8rem;
    }

    .kixie-solutions-chip img {
        height: 1.7rem;
    }
}

@media (prefers-reduced-motion: reduce) {
    .kixie-solutions-marquee-track,
    .kixie-solutions-cta-panel {
        animation: none !important;
    }
}

/* Power Dialer Feature Template */
/* ========== CSS RESET & BASE ========== */
    .kixie-feature-power-dialer *, .kixie-feature-power-dialer *::before, .kixie-feature-power-dialer *::after {
      box-sizing: border-box;
      margin: 0;
      padding: 0;
    }

    .kixie-feature-power-dialer {
      /* Color System */
      --background: hsl(40, 33%, 96%);
      --foreground: hsl(270, 30%, 15%);
      --card: hsl(40, 30%, 98%);
      --card-foreground: hsl(270, 30%, 15%);
      --primary: hsl(275, 85%, 55%);
      --primary-foreground: hsl(0, 0%, 100%);
      --secondary: hsl(40, 20%, 94%);
      --muted: hsl(40, 15%, 92%);
      --muted-foreground: hsl(270, 10%, 45%);
      --border: hsl(40, 15%, 88%);
      --cta: hsl(0, 84%, 50%);
      --cta-foreground: hsl(0, 0%, 100%);
      --success: hsl(160, 60%, 45%);
      --success-foreground: hsl(0, 0%, 100%);
      --warning: hsl(38, 92%, 50%);
      --warning-foreground: hsl(0, 0%, 100%);
      --destructive: hsl(0, 84%, 60%);
      --radius: 0.75rem;
    }

    .kixie-feature-power-dialer {
      scroll-behavior: smooth;
    }

    .kixie-feature-power-dialer {
      font-family: 'DM Sans', system-ui, sans-serif;
      background-color: var(--background);
      color: var(--foreground);
      line-height: 1.6;
      overflow-x: hidden;
    }

    .kixie-feature-power-dialer h1, .kixie-feature-power-dialer h2, .kixie-feature-power-dialer h3, .kixie-feature-power-dialer h4, .kixie-feature-power-dialer h5, .kixie-feature-power-dialer h6 {
      font-family: 'DM Sans', system-ui, sans-serif;
      letter-spacing: -0.02em;
      line-height: 1.1;
    }

    .kixie-feature-power-dialer a {
      text-decoration: none;
      color: inherit;
    }

    .kixie-feature-power-dialer img {
      max-width: 100%;
      height: auto;
    }

    .kixie-feature-power-dialer .container {
      max-width: 1400px;
      margin: 0 auto;
      padding: 0 2rem;
    }

    /* ========== BUTTONS ========== */
    .kixie-feature-power-dialer .btn,
    .kixie-integration-landing-page .btn {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      gap: 0.5rem;
      padding: 0.625rem 1.5rem;
      font-size: 0.875rem;
      font-weight: 600;
      border-radius: 9999px;
      border: 1px solid transparent;
      cursor: pointer;
      transition: all 0.2s ease;
      white-space: nowrap;
    }

    .kixie-feature-power-dialer .btn-cta {
      background: var(--cta);
      color: var(--cta-foreground);
    }

    .kixie-feature-power-dialer .btn-cta:hover {
      background: hsl(0, 84%, 45%);
      transform: translateY(-1px);
      box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
    }

    .kixie-feature-power-dialer .btn-white {
      background: white;
      color: var(--foreground);
    }

    .kixie-feature-power-dialer .btn-white:hover {
      background: hsl(0, 0%, 95%);
      transform: translateY(-1px);
      box-shadow: 0 4px 20px rgba(0, 0, 0, 0.1);
    }

    .kixie-feature-power-dialer .btn-outline,
    .kixie-integration-landing-page .btn-outline {
      background: white;
      color: var(--foreground);
      border-color: var(--border);
    }

    .kixie-feature-power-dialer .btn-outline:hover,
    .kixie-integration-landing-page .btn-outline:hover {
      border-color: hsl(275, 85%, 55%, 0.3);
      box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
    }

    .kixie-feature-power-dialer .btn-lg {
      padding: 0.875rem 2rem;
      font-size: 1rem;
    }

    .kixie-feature-power-dialer .btn-sm {
      padding: 0.5rem 1rem;
      font-size: 0.875rem;
    }

    .kixie-feature-power-dialer .btn-icon {
      width: 2.5rem;
      height: 2.5rem;
      padding: 0;
      border-radius: 9999px;
    }

    /* ========== HEADER ========== */
    .kixie-feature-power-dialer .header {
      position: fixed;
      top: 0;
      left: 0;
      right: 0;
      z-index: 50;
    }

    .kixie-feature-power-dialer .hello-bar {
      background: linear-gradient(90deg, hsl(270, 50%, 30%) 0%, hsl(280, 60%, 40%) 50%, hsl(330, 60%, 45%) 100%);
      background-size: 200% 100%;
      animation: gradient-wave 11s ease-in-out infinite;
      color: white;
      padding: 0.5rem 1rem;
      text-align: center;
      font-size: 0.875rem;
    }

    .kixie-feature-power-dialer .hello-bar-content {
      display: flex;
      align-items: center;
      justify-content: center;
      gap: 0.75rem;
      flex-wrap: wrap;
    }

    .kixie-feature-power-dialer .hello-bar-link {
      display: inline-flex;
      align-items: center;
      gap: 0.25rem;
      padding: 0.25rem 0.75rem;
      background: white;
      color: var(--foreground);
      border-radius: 0.25rem;
      font-size: 0.75rem;
      font-weight: 600;
      text-transform: uppercase;
      letter-spacing: 0.05em;
    }

    .kixie-feature-power-dialer .hello-bar-link:hover {
      background: hsl(0, 0%, 95%);
    }

    .kixie-feature-power-dialer .nav {
      background: white;
      border-bottom: 1px solid hsl(0, 0%, 95%);
      padding: 0.75rem 0;
    }

    .kixie-feature-power-dialer .nav-container {
      display: flex;
      align-items: center;
      justify-content: space-between;
    }

    .kixie-feature-power-dialer .logo {
      display: flex;
      align-items: center;
      gap: 0.25rem;
    }

    .kixie-feature-power-dialer .logo-icon {
      width: 1.75rem;
      height: 1.75rem;
      background: var(--cta);
      border-radius: 0.25rem;
      display: flex;
      align-items: center;
      justify-content: center;
      color: white;
      font-size: 0.875rem;
      font-weight: 700;
    }

    .kixie-feature-power-dialer .logo-text {
      font-size: 1.25rem;
      font-weight: 700;
      letter-spacing: -0.02em;
    }

    .kixie-feature-power-dialer .nav-links {
      display: none;
      align-items: center;
      gap: 0.125rem;
    }

    @media (min-width: 1024px) {
      .kixie-feature-power-dialer .nav-links {
        display: flex;
      }
    }

    .kixie-feature-power-dialer .nav-link {
      padding: 0.5rem 0.75rem;
      font-size: 0.875rem;
      color: hsl(0, 0%, 40%);
      display: flex;
      align-items: center;
      gap: 0.25rem;
      transition: color 0.2s;
    }

    .kixie-feature-power-dialer .nav-link:hover {
      color: var(--foreground);
    }

    .kixie-feature-power-dialer .nav-link svg {
      width: 0.875rem;
      height: 0.875rem;
      color: hsl(0, 0%, 60%);
    }

    .kixie-feature-power-dialer .nav-cta {
      display: none;
      align-items: center;
      gap: 0.5rem;
    }

    @media (min-width: 1024px) {
      .kixie-feature-power-dialer .nav-cta {
        display: flex;
      }
    }

    .kixie-feature-power-dialer .nav-cta-link {
      padding: 0.5rem 0.75rem;
      font-size: 0.875rem;
      color: hsl(0, 0%, 40%);
    }

    .kixie-feature-power-dialer .nav-cta-link:hover {
      color: var(--foreground);
    }

    .kixie-feature-power-dialer .mobile-menu-btn {
      display: block;
      padding: 0.5rem;
      background: none;
      border: none;
      cursor: pointer;
    }

    @media (min-width: 1024px) {
      .kixie-feature-power-dialer .mobile-menu-btn {
        display: none;
      }
    }

    /* ========== HERO SECTION ========== */
    .kixie-feature-power-dialer .hero {
      padding-top: 10rem;
      padding-bottom: 6rem;
      background: var(--background);
      overflow: hidden;
    }

    .kixie-feature-power-dialer .hero-grid {
      display: grid;
      gap: 3rem;
      align-items: center;
    }

    @media (min-width: 1024px) {
      .kixie-feature-power-dialer .hero-grid {
        grid-template-columns: 1fr 1fr;
      }
    }

    .kixie-feature-power-dialer .hero-content {
      animation: fade-in-left 0.8s ease-out forwards;
    }

    .kixie-feature-power-dialer .hero-badge {
      display: inline-block;
      padding: 0.375rem 1rem;
      font-size: 0.875rem;
      font-weight: 500;
      color: var(--primary);
      background: hsl(275, 85%, 55%, 0.1);
      border-radius: 9999px;
      text-transform: uppercase;
      letter-spacing: 0.05em;
      margin-bottom: 1rem;
    }

    .kixie-feature-power-dialer .hero-title {
      font-size: 2.5rem;
      font-weight: 700;
      margin-bottom: 1.5rem;
      color: var(--foreground);
    }

    @media (min-width: 768px) {
      .kixie-feature-power-dialer .hero-title {
        font-size: 3rem;
      }
    }

    @media (min-width: 1024px) {
      .kixie-feature-power-dialer .hero-title {
        font-size: 3.75rem;
      }
    }

    .kixie-feature-power-dialer .hero-description {
      font-size: 1.125rem;
      color: var(--muted-foreground);
      max-width: 36rem;
      margin-bottom: 2rem;
      line-height: 1.7;
    }

    @media (min-width: 768px) {
      .kixie-feature-power-dialer .hero-description {
        font-size: 1.25rem;
      }
    }

    /* Power Dialer Dashboard Card */
    .kixie-feature-power-dialer .dialer-card {
      background: var(--card);
      border-radius: 1rem;
      box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.1);
      padding: 1.5rem;
      border: 1px solid var(--border);
      animation: fade-in-up 0.8s ease-out forwards;
    }

    .kixie-feature-power-dialer .dialer-header {
      display: flex;
      align-items: center;
      justify-content: space-between;
      margin-bottom: 1.5rem;
    }

    .kixie-feature-power-dialer .dialer-header-left {
      display: flex;
      align-items: center;
      gap: 0.75rem;
    }

    .kixie-feature-power-dialer .dialer-title {
      font-size: 1.25rem;
      font-weight: 600;
      color: var(--foreground);
    }

    .kixie-feature-power-dialer .dialer-controls {
      display: flex;
      gap: 0.25rem;
    }

    .kixie-feature-power-dialer .dialer-control-btn {
      width: 1.75rem;
      height: 1.75rem;
      border-radius: 9999px;
      border: 1px solid hsl(0, 0%, 70%);
      background: transparent;
      display: flex;
      align-items: center;
      justify-content: center;
      cursor: pointer;
      transition: background 0.2s;
    }

    .kixie-feature-power-dialer .dialer-control-btn:hover {
      background: var(--muted);
    }

    .kixie-feature-power-dialer .dialer-control-btn svg {
      width: 0.75rem;
      height: 0.75rem;
      color: hsl(0, 0%, 50%);
    }

    .kixie-feature-power-dialer .live-indicator {
      display: flex;
      align-items: center;
      gap: 0.5rem;
    }

    .kixie-feature-power-dialer .live-dot {
      width: 0.5rem;
      height: 0.5rem;
      border-radius: 9999px;
      background: var(--success);
      animation: pulse-dot 1s ease-in-out infinite;
    }

    .kixie-feature-power-dialer .live-text {
      font-size: 0.875rem;
      font-weight: 500;
      color: var(--success);
    }

    /* Stats Grid */
    .kixie-feature-power-dialer .stats-grid {
      display: grid;
      grid-template-columns: repeat(4, 1fr);
      gap: 1rem;
      margin-bottom: 1.5rem;
    }

    .kixie-feature-power-dialer .stat-card {
      background: hsl(0, 84%, 50%, 0.05);
      border-radius: 0.75rem;
      padding: 1rem;
      animation: fade-in-up 0.8s ease-out forwards;
    }

    .kixie-feature-power-dialer .stat-label {
      font-size: 0.875rem;
      color: var(--foreground);
      margin-bottom: 0.25rem;
    }

    .kixie-feature-power-dialer .stat-value {
      font-size: 1.5rem;
      font-weight: 700;
      color: var(--foreground);
      transition: all 0.3s;
    }

    /* Contact List */
    .kixie-feature-power-dialer .contact-section {
      position: relative;
      overflow: hidden;
      min-height: 280px;
    }

    .kixie-feature-power-dialer .contact-section-label {
      font-size: 0.75rem;
      color: var(--muted-foreground);
      text-transform: uppercase;
      letter-spacing: 0.05em;
      margin-bottom: 0.75rem;
    }

    .kixie-feature-power-dialer .contact-batch {
      display: flex;
      flex-direction: column;
    }

    .kixie-feature-power-dialer .contact-card {
      display: flex;
      align-items: center;
      justify-content: space-between;
      padding: 0.75rem 0.25rem 0.75rem 0;
      border-top: 1px solid var(--border);
      background: var(--card);
      animation: card-enter 0.4s ease-out forwards;
      opacity: 0;
    }

    .kixie-feature-power-dialer .contact-info {
      display: flex;
      align-items: center;
      gap: 0.75rem;
      min-width: 0;
      flex: 1;
    }

    .kixie-feature-power-dialer .contact-avatar {
      width: 2.5rem;
      height: 2.5rem;
      border-radius: 9999px;
      background: linear-gradient(135deg, var(--cta), var(--primary));
      display: flex;
      align-items: center;
      justify-content: center;
      color: white;
      font-size: 0.875rem;
      font-weight: 500;
      flex-shrink: 0;
    }

    .kixie-feature-power-dialer .contact-details {
      min-width: 0;
    }

    .kixie-feature-power-dialer .contact-name {
      font-weight: 500;
      color: var(--foreground);
      font-size: 0.875rem;
      white-space: nowrap;
      overflow: hidden;
      text-overflow: ellipsis;
    }

    .kixie-feature-power-dialer .contact-phone {
      font-size: 0.875rem;
      color: var(--muted-foreground);
    }

    .kixie-feature-power-dialer .contact-status {
      flex-shrink: 0;
      margin-right: 1.5rem;
      min-width: 130px;
      display: flex;
      justify-content: flex-end;
    }

    /* Status Indicators */
    .kixie-feature-power-dialer .status-queued {
      padding: 0.25rem 0.5rem;
      font-size: 0.75rem;
      font-weight: 500;
      border-radius: 9999px;
      background: var(--muted);
      color: var(--muted-foreground);
    }

    .kixie-feature-power-dialer .status-dialing {
      display: flex;
      align-items: center;
      gap: 0.5rem;
      animation: fade-in 0.3s ease-out forwards;
    }

    .kixie-feature-power-dialer .dialing-dots {
      display: flex;
      gap: 0.25rem;
    }

    .kixie-feature-power-dialer .dialing-dot {
      width: 0.375rem;
      height: 0.375rem;
      border-radius: 9999px;
      background: var(--cta);
      animation: dialing-dots 0.8s ease-in-out infinite;
    }

    .kixie-feature-power-dialer .dialing-dot:nth-child(2) {
      animation-delay: 0.15s;
    }

    .kixie-feature-power-dialer .dialing-dot:nth-child(3) {
      animation-delay: 0.3s;
    }

    .kixie-feature-power-dialer .dialing-text {
      font-size: 0.875rem;
      color: var(--cta);
      font-weight: 500;
    }

    .kixie-feature-power-dialer .status-connected, .kixie-feature-power-dialer .status-voicemail, .kixie-feature-power-dialer .status-sms-sent, .kixie-feature-power-dialer .status-busy, .kixie-feature-power-dialer .status-wrong-number, .kixie-feature-power-dialer .status-completed {
      display: flex;
      align-items: center;
      gap: 0.5rem;
      animation: status-pop 0.4s ease-out forwards;
    }

    .kixie-feature-power-dialer .status-icon {
      width: 2rem;
      height: 2rem;
      border-radius: 9999px;
      display: flex;
      align-items: center;
      justify-content: center;
    }

    .kixie-feature-power-dialer .status-icon svg {
      width: 1rem;
      height: 1rem;
    }

    .kixie-feature-power-dialer .status-connected .status-icon {
      background: var(--success);
      animation: connected-pulse 0.6s ease-in-out infinite;
    }

    .kixie-feature-power-dialer .status-connected .status-icon svg {
      color: var(--success-foreground);
    }

    .kixie-feature-power-dialer .status-connected .status-text {
      font-size: 0.875rem;
      font-weight: 500;
      color: var(--success);
    }

    .kixie-feature-power-dialer .status-completed {
      animation: fade-in 0.3s ease-out forwards;
    }

    .kixie-feature-power-dialer .status-completed .status-text {
      font-size: 0.875rem;
      color: var(--success);
      display: flex;
      align-items: center;
      gap: 0.25rem;
    }

    .kixie-feature-power-dialer .status-voicemail .status-icon {
      background: var(--warning);
    }

    .kixie-feature-power-dialer .status-voicemail .status-icon svg {
      color: var(--warning-foreground);
    }

    .kixie-feature-power-dialer .status-voicemail .status-text {
      font-size: 0.875rem;
      font-weight: 500;
      color: var(--warning);
    }

    .kixie-feature-power-dialer .status-sms-sent .status-icon {
      background: var(--primary);
    }

    .kixie-feature-power-dialer .status-sms-sent .status-icon svg {
      color: var(--primary-foreground);
    }

    .kixie-feature-power-dialer .status-sms-sent .status-text {
      font-size: 0.875rem;
      font-weight: 500;
      color: var(--primary);
    }

    .kixie-feature-power-dialer .status-busy .status-icon {
      background: var(--muted);
    }

    .kixie-feature-power-dialer .status-busy .status-icon svg {
      color: var(--muted-foreground);
    }

    .kixie-feature-power-dialer .status-busy .status-text {
      font-size: 0.875rem;
      font-weight: 500;
      color: var(--muted-foreground);
    }

    .kixie-feature-power-dialer .status-wrong-number .status-icon {
      background: hsl(0, 84%, 60%, 0.2);
    }

    .kixie-feature-power-dialer .status-wrong-number .status-icon svg {
      color: var(--destructive);
    }

    .kixie-feature-power-dialer .status-wrong-number .status-text {
      font-size: 0.875rem;
      font-weight: 500;
      color: var(--destructive);
    }

    /* ========== TRUSTED BY SECTION ========== */
    .kixie-feature-power-dialer .trusted-by,
    .kixie-integration-landing-page .trusted-by,
    .kixie-solutions-page .trusted-by {
      padding: 4rem 0;
      background: white;
    }

    .kixie-feature-power-dialer .trusted-by-label,
    .kixie-integration-landing-page .trusted-by-label,
    .kixie-solutions-page .trusted-by-label {
      text-align: center;
      font-size: 0.875rem;
      color: var(--muted-foreground);
      text-transform: uppercase;
      letter-spacing: 0.05em;
      margin-bottom: 2rem;
    }

    .kixie-feature-power-dialer .logo-scroll,
    .kixie-integration-landing-page .logo-scroll,
    .kixie-solutions-page .logo-scroll {
      position: relative;
      overflow: hidden;
    }

    .kixie-feature-power-dialer .logo-scroll::before,
    .kixie-feature-power-dialer .logo-scroll::after,
    .kixie-integration-landing-page .logo-scroll::before,
    .kixie-integration-landing-page .logo-scroll::after,
    .kixie-solutions-page .logo-scroll::before,
    .kixie-solutions-page .logo-scroll::after {
      content: '';
      position: absolute;
      top: 0;
      bottom: 0;
      width: 6rem;
      z-index: 10;
      pointer-events: none;
    }

    .kixie-feature-power-dialer .logo-scroll::before,
    .kixie-integration-landing-page .logo-scroll::before,
    .kixie-solutions-page .logo-scroll::before {
      left: 0;
      background: linear-gradient(to right, var(--background), transparent);
    }

    .kixie-feature-power-dialer .logo-scroll::after,
    .kixie-integration-landing-page .logo-scroll::after,
    .kixie-solutions-page .logo-scroll::after {
      right: 0;
      background: linear-gradient(to left, var(--background), transparent);
    }

    .kixie-feature-power-dialer .logo-track,
    .kixie-integration-landing-page .logo-track,
    .kixie-solutions-page .logo-track {
      display: flex;
      align-items: center;
      animation: marquee 40s linear infinite;
    }

    .kixie-feature-power-dialer .logo-track:hover,
    .kixie-integration-landing-page .logo-track:hover,
    .kixie-solutions-page .logo-track:hover {
      animation-play-state: paused;
    }

    .kixie-feature-power-dialer .logo-item,
    .kixie-integration-landing-page .logo-item,
    .kixie-solutions-page .logo-item {
      flex-shrink: 0;
      margin: 0 2.5rem;
      opacity: 0.7;
      transition: opacity 0.3s;
      height: 2.5rem;
      display: flex;
      align-items: center;
    }

    .kixie-feature-power-dialer .logo-item:hover,
    .kixie-integration-landing-page .logo-item:hover,
    .kixie-solutions-page .logo-item:hover {
      opacity: 1;
    }

    .kixie-feature-power-dialer .logo-item img,
    .kixie-integration-landing-page .logo-item img,
    .kixie-solutions-page .logo-item img {
      height: 100%;
      width: auto;
      object-fit: contain;
    }

    /* ========== BENEFITS SECTION ========== */
    .kixie-feature-power-dialer .benefits {
      padding: 6rem 0;
      background: linear-gradient(135deg, hsl(0, 84%, 50%, 0.1) 0%, white 50%, hsl(275, 85%, 55%, 0.1) 100%);
      overflow: hidden;
    }

    .kixie-feature-power-dialer .section-header,
    .kixie-integration-landing-page .section-header {
      text-align: center;
      max-width: 48rem;
      margin: 0 auto 4rem;
    }

    .kixie-feature-power-dialer .section-title,
    .kixie-integration-landing-page .section-title {
      font-size: 1.875rem;
      font-weight: 700;
      margin-bottom: 1rem;
      color: var(--foreground);
    }

    @media (min-width: 768px) {
      .kixie-feature-power-dialer .section-title,
      .kixie-integration-landing-page .section-title {
        font-size: 2.25rem;
      }
    }

    @media (min-width: 1024px) {
      .kixie-feature-power-dialer .section-title,
      .kixie-integration-landing-page .section-title {
        font-size: 3rem;
      }
    }

    .kixie-feature-power-dialer .section-subtitle,
    .kixie-integration-landing-page .section-subtitle {
      font-size: 1.125rem;
      color: var(--muted-foreground);
    }

    .kixie-feature-power-dialer .benefits-grid {
      display: grid;
      gap: 2rem;
    }

    @media (min-width: 768px) {
      .kixie-feature-power-dialer .benefits-grid {
        grid-template-columns: repeat(3, 1fr);
      }
    }

    .kixie-feature-power-dialer .benefit-card {
      padding: 2rem;
      border-radius: 1rem;
      background: white;
      box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.05);
      border: 1px solid hsl(0, 0%, 90%);
      transition: all 0.3s ease;
    }

    .kixie-feature-power-dialer .benefit-card:hover {
      border-color: hsl(0, 84%, 50%, 0.3);
      box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.1);
      transform: translateY(-4px);
    }

    .kixie-feature-power-dialer .benefit-icon {
      width: 3.5rem;
      height: 3.5rem;
      border-radius: 0.75rem;
      background: linear-gradient(135deg, var(--cta), var(--primary));
      display: flex;
      align-items: center;
      justify-content: center;
      margin-bottom: 1.5rem;
    }

    .kixie-feature-power-dialer .benefit-icon svg {
      width: 1.75rem;
      height: 1.75rem;
      color: white;
    }

    .kixie-feature-power-dialer .benefit-title {
      font-size: 1.25rem;
      font-weight: 600;
      margin-bottom: 0.75rem;
      color: var(--foreground);
    }

    .kixie-feature-power-dialer .benefit-description {
      font-size: 1rem;
      color: var(--muted-foreground);
      line-height: 1.6;
    }

    /* ========== FEATURES SECTION ========== */
    .kixie-feature-power-dialer .features {
      padding: 6rem 0;
      background: linear-gradient(180deg, hsl(258, 40%, 98%) 0%, hsl(258, 30%, 96%) 100%);
      overflow: hidden;
    }

    .kixie-feature-power-dialer .features-grid {
      display: grid;
      gap: 1.5rem;
    }

    @media (min-width: 768px) {
      .kixie-feature-power-dialer .features-grid {
        grid-template-columns: 1fr 1fr;
      }
    }

    .kixie-feature-power-dialer .feature-card-large {
      padding: 2.5rem;
      border-radius: 1rem;
      background: white;
      border: 1px solid var(--border);
      display: flex;
      flex-direction: column;
      justify-content: space-between;
      transition: all 0.3s ease;
    }

    @media (min-width: 768px) {
      .kixie-feature-power-dialer .feature-card-large {
        grid-row: span 2;
      }
    }

    .kixie-feature-power-dialer .feature-card-large:hover {
      border-color: hsl(0, 84%, 50%, 0.3);
      box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.1);
    }

    .kixie-feature-power-dialer .feature-icon-sm {
      width: 3.5rem;
      height: 3.5rem;
      border-radius: 0.75rem;
      background: hsl(0, 84%, 50%, 0.1);
      display: flex;
      align-items: center;
      justify-content: center;
      margin-bottom: 1.5rem;
    }

    .kixie-feature-power-dialer .feature-icon-sm svg {
      width: 1.75rem;
      height: 1.75rem;
      color: var(--cta);
    }

    .kixie-feature-power-dialer .feature-title {
      font-size: 1.5rem;
      font-weight: 600;
      margin-bottom: 1rem;
      color: var(--foreground);
    }

    .kixie-feature-power-dialer .feature-description {
      font-size: 1rem;
      color: var(--muted-foreground);
      line-height: 1.6;
      margin-bottom: 2rem;
    }

    .kixie-feature-power-dialer .feature-cards-stack {
      display: flex;
      flex-direction: column;
      gap: 1.5rem;
    }

    .kixie-feature-power-dialer .feature-card-small {
      padding: 2rem;
      border-radius: 1rem;
      background: white;
      border: 1px solid var(--border);
      flex: 1;
      transition: all 0.3s ease;
    }

    .kixie-feature-power-dialer .feature-card-small:hover {
      border-color: hsl(0, 84%, 50%, 0.3);
      box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.1);
    }

    .kixie-feature-power-dialer .feature-card-small-content {
      display: flex;
      gap: 1.25rem;
    }

    .kixie-feature-power-dialer .feature-card-small .feature-icon-sm {
      width: 3rem;
      height: 3rem;
      flex-shrink: 0;
    }

    .kixie-feature-power-dialer .feature-card-small .feature-icon-sm svg {
      width: 1.5rem;
      height: 1.5rem;
    }

    .kixie-feature-power-dialer .feature-card-small .feature-title {
      font-size: 1.25rem;
      margin-bottom: 0.5rem;
    }

    .kixie-feature-power-dialer .feature-card-small .feature-description {
      margin-bottom: 1rem;
    }

    /* ========== TESTIMONIAL SECTION ========== */
    .kixie-feature-power-dialer .testimonials,
    .kixie-integration-landing-page .testimonials {
      padding: 6rem 0;
      background: linear-gradient(135deg, hsl(210, 40%, 98%) 0%, hsl(200, 30%, 96%) 50%, hsl(210, 35%, 95%) 100%);
      overflow: hidden;
    }

    .kixie-feature-power-dialer .testimonial-carousel,
    .kixie-integration-landing-page .testimonial-carousel {
      max-width: 64rem;
      margin: 0 auto;
    }

    .kixie-feature-power-dialer .testimonial-card,
    .kixie-integration-landing-page .testimonial-card {
      background: rgba(255, 255, 255, 0.7);
      backdrop-filter: blur(20px);
      border: 1px solid hsl(200, 50%, 92%);
      border-radius: 1rem;
      padding: 2.5rem;
      box-shadow: 0 4px 6px -1px hsl(200, 50%, 92%, 0.5);
    }

    .kixie-feature-power-dialer .testimonial-stars,
    .kixie-integration-landing-page .testimonial-stars {
      display: flex;
      gap: 0.25rem;
      margin-bottom: 1.5rem;
    }

    .kixie-feature-power-dialer .testimonial-stars svg,
    .kixie-integration-landing-page .testimonial-stars svg {
      width: 1rem;
      height: 1rem;
      fill: hsl(45, 93%, 58%);
      color: hsl(45, 93%, 58%);
    }

    .kixie-feature-power-dialer .testimonial-quote,
    .kixie-integration-landing-page .testimonial-quote {
      font-size: 1.25rem;
      color: var(--foreground);
      line-height: 1.7;
      margin-bottom: 2rem;
    }

    .kixie-feature-power-dialer .testimonial-author,
    .kixie-integration-landing-page .testimonial-author {
      display: flex;
      align-items: center;
      gap: 1rem;
    }

    .kixie-feature-power-dialer .testimonial-avatar,
    .kixie-integration-landing-page .testimonial-avatar {
      width: 3rem;
      height: 3rem;
      border-radius: 9999px;
      background: linear-gradient(135deg, hsl(200, 50%, 92%) 0%, hsl(210, 45%, 90%) 100%);
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 1.125rem;
      font-weight: 700;
      color: hsl(200, 60%, 40%);
    }

    .kixie-feature-power-dialer .testimonial-name,
    .kixie-integration-landing-page .testimonial-name {
      font-weight: 600;
      color: var(--foreground);
    }

    .kixie-feature-power-dialer .testimonial-role,
    .kixie-integration-landing-page .testimonial-role {
      font-size: 0.875rem;
      color: var(--muted-foreground);
    }

    .kixie-feature-power-dialer .testimonial-nav,
    .kixie-integration-landing-page .testimonial-nav {
      display: flex;
      align-items: center;
      justify-content: center;
      gap: 1rem;
      margin-top: 2rem;
    }

    .kixie-feature-power-dialer .testimonial-nav-btn,
    .kixie-integration-landing-page .testimonial-nav-btn {
      width: 2.5rem;
      height: 2.5rem;
      border-radius: 9999px;
      background: white;
      border: 1px solid hsl(200, 50%, 88%);
      display: flex;
      align-items: center;
      justify-content: center;
      cursor: pointer;
      transition: all 0.2s;
    }

    .kixie-feature-power-dialer .testimonial-nav-btn:hover,
    .kixie-integration-landing-page .testimonial-nav-btn:hover {
      background: hsl(200, 50%, 96%);
      border-color: hsl(200, 50%, 80%);
    }

    .kixie-feature-power-dialer .testimonial-nav-btn svg,
    .kixie-integration-landing-page .testimonial-nav-btn svg {
      width: 1.25rem;
      height: 1.25rem;
      color: var(--foreground);
    }

    .kixie-feature-power-dialer .testimonial-dots,
    .kixie-integration-landing-page .testimonial-dots {
      display: flex;
      gap: 0.5rem;
    }

    .kixie-feature-power-dialer .testimonial-dot,
    .kixie-integration-landing-page .testimonial-dot {
      height: 0.625rem;
      border-radius: 9999px;
      background: hsl(200, 50%, 85%);
      cursor: pointer;
      transition: all 0.3s;
      border: none;
      padding: 0;
    }

    .kixie-feature-power-dialer .testimonial-dot.active,
    .kixie-integration-landing-page .testimonial-dot.active {
      background: hsl(200, 60%, 55%);
      width: 2rem;
    }

    .kixie-feature-power-dialer .testimonial-dot:not(.active),
    .kixie-integration-landing-page .testimonial-dot:not(.active) {
      width: 0.625rem;
    }

    .kixie-feature-power-dialer .testimonial-dot:hover:not(.active),
    .kixie-integration-landing-page .testimonial-dot:hover:not(.active) {
      background: hsl(200, 50%, 75%);
    }

    /* ========== CRM INTEGRATIONS SECTION ========== */
    .kixie-feature-power-dialer .integrations,
    .kixie-integration-landing-page .integrations {
      padding: 6rem 0;
      background: var(--card);
      border-top: 1px solid var(--border);
      border-bottom: 1px solid var(--border);
      overflow: hidden;
    }

    .kixie-feature-power-dialer .integrations-scroll,
    .kixie-integration-landing-page .integrations-scroll {
      position: relative;
      overflow: hidden;
      margin-bottom: 1.5rem;
    }

    .kixie-feature-power-dialer .integrations-scroll::before,
    .kixie-feature-power-dialer .integrations-scroll::after,
    .kixie-integration-landing-page .integrations-scroll::before,
    .kixie-integration-landing-page .integrations-scroll::after {
      content: '';
      position: absolute;
      top: 0;
      bottom: 0;
      width: 6rem;
      z-index: 10;
      pointer-events: none;
    }

    .kixie-feature-power-dialer .integrations-scroll::before,
    .kixie-integration-landing-page .integrations-scroll::before {
      left: 0;
      background: linear-gradient(to right, var(--card), transparent);
    }

    .kixie-feature-power-dialer .integrations-scroll::after,
    .kixie-integration-landing-page .integrations-scroll::after {
      right: 0;
      background: linear-gradient(to left, var(--card), transparent);
    }

    .kixie-feature-power-dialer .integrations-track,
    .kixie-integration-landing-page .integrations-track {
      display: flex;
      align-items: center;
    }

    .kixie-feature-power-dialer .integrations-track.forward,
    .kixie-integration-landing-page .integrations-track.forward {
      animation: marquee 40s linear infinite;
    }

    .kixie-feature-power-dialer .integrations-track.reverse,
    .kixie-integration-landing-page .integrations-track.reverse {
      animation: marquee-reverse 40s linear infinite;
    }

    .kixie-feature-power-dialer .integrations-track:hover,
    .kixie-integration-landing-page .integrations-track:hover {
      animation-play-state: paused;
    }

    .kixie-feature-power-dialer .integration-item,
    .kixie-integration-landing-page .integration-item {
      flex-shrink: 0;
      margin: 0 1rem;
      display: flex;
      align-items: center;
      gap: 0.75rem;
      padding: 0.5rem 1rem;
      background: white;
      border: 1px solid var(--border);
      border-radius: 0.75rem;
      transition: all 0.3s;
    }

    .kixie-feature-power-dialer .integration-item:hover,
    .kixie-integration-landing-page .integration-item:hover {
      border-color: hsl(275, 85%, 55%, 0.3);
      box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.1);
    }

    .kixie-feature-power-dialer .integration-logo,
    .kixie-integration-landing-page .integration-logo {
      width: 2rem;
      height: 2rem;
      border-radius: 0.375rem;
      background: hsl(0, 0%, 95%);
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 0.625rem;
      font-weight: 700;
      color: var(--muted-foreground);
      overflow: hidden;
      flex-shrink: 0;
    }

    .kixie-feature-power-dialer .integration-logo img,
    .kixie-integration-landing-page .integration-logo img {
      width: 100%;
      height: 100%;
      object-fit: contain;
      display: block;
    }

    .kixie-feature-power-dialer .integration-name,
    .kixie-integration-landing-page .integration-name {
      font-size: 0.875rem;
      font-weight: 500;
      color: var(--foreground);
      white-space: nowrap;
    }

    .kixie-feature-power-dialer .integrations-cta,
    .kixie-integration-landing-page .integrations-cta {
      text-align: center;
      margin-top: 2.5rem;
    }

    /* ========== CTA SECTION ========== */
    .kixie-feature-power-dialer .cta-section {
      padding: 6rem 0;
    }

    .kixie-feature-power-dialer .cta-card {
      background: linear-gradient(90deg, hsl(270, 50%, 30%) 0%, hsl(280, 60%, 40%) 50%, hsl(330, 60%, 45%) 100%);
      background-size: 200% 100%;
      animation: gradient-wave 11s ease-in-out infinite;
      border-radius: 1.5rem;
      padding: 5rem 1.5rem;
      text-align: center;
    }

    .kixie-feature-power-dialer .cta-content {
      max-width: 40rem;
      margin: 0 auto;
    }

    .kixie-feature-power-dialer .cta-title {
      font-size: 1.875rem;
      font-weight: 700;
      color: white;
      margin-bottom: 1rem;
    }

    @media (min-width: 768px) {
      .kixie-feature-power-dialer .cta-title {
        font-size: 2.25rem;
      }
    }

    @media (min-width: 1024px) {
      .kixie-feature-power-dialer .cta-title {
        font-size: 3rem;
      }
    }

    .kixie-feature-power-dialer .cta-description {
      font-size: 1.125rem;
      color: rgba(255, 255, 255, 0.7);
      margin-bottom: 2rem;
    }

    /* ========== FOOTER ========== */
    .kixie-feature-power-dialer .footer {
      background: var(--foreground);
      color: white;
      padding: 4rem 0 2rem;
    }

    .kixie-feature-power-dialer .footer-grid {
      display: grid;
      grid-template-columns: repeat(2, 1fr);
      gap: 2rem;
      padding-bottom: 3rem;
    }

    @media (min-width: 768px) {
      .kixie-feature-power-dialer .footer-grid {
        grid-template-columns: 1fr repeat(4, 1fr);
      }
    }

    .kixie-feature-power-dialer .footer-brand {
      grid-column: span 2;
    }

    @media (min-width: 768px) {
      .kixie-feature-power-dialer .footer-brand {
        grid-column: span 1;
      }
    }

    .kixie-feature-power-dialer .footer-logo {
      display: flex;
      align-items: center;
      gap: 0.5rem;
      margin-bottom: 1rem;
    }

    .kixie-feature-power-dialer .footer-logo-icon {
      width: 1.5rem;
      height: 1.5rem;
      background: var(--primary);
      border-radius: 0.25rem;
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 0.75rem;
      font-weight: 700;
    }

    .kixie-feature-power-dialer .footer-logo-text {
      font-size: 1.25rem;
      font-weight: 700;
    }

    .kixie-feature-power-dialer .footer-tagline {
      font-size: 0.875rem;
      color: rgba(255, 255, 255, 0.6);
    }

    .kixie-feature-power-dialer .footer-col-title {
      font-weight: 600;
      margin-bottom: 1rem;
    }

    .kixie-feature-power-dialer .footer-links {
      list-style: none;
      display: flex;
      flex-direction: column;
      gap: 0.5rem;
    }

    .kixie-feature-power-dialer .footer-link {
      font-size: 0.875rem;
      color: rgba(255, 255, 255, 0.6);
      transition: color 0.2s;
    }

    .kixie-feature-power-dialer .footer-link:hover {
      color: white;
    }

    .kixie-feature-power-dialer .footer-bottom {
      display: flex;
      flex-direction: column;
      align-items: center;
      justify-content: space-between;
      gap: 1rem;
      padding-top: 2rem;
      border-top: 1px solid rgba(255, 255, 255, 0.1);
    }

    @media (min-width: 768px) {
      .kixie-feature-power-dialer .footer-bottom {
        flex-direction: row;
      }
    }

    .kixie-feature-power-dialer .footer-copyright {
      font-size: 0.875rem;
      color: rgba(255, 255, 255, 0.6);
    }

    .kixie-feature-power-dialer .footer-legal {
      display: flex;
      gap: 1.5rem;
    }

    .kixie-feature-power-dialer .footer-legal a {
      font-size: 0.875rem;
      color: rgba(255, 255, 255, 0.6);
      transition: color 0.2s;
    }

    .kixie-feature-power-dialer .footer-legal a:hover {
      color: white;
    }

    /* ========== ANIMATIONS ========== */
    @keyframes gradient-wave {
      0% { background-position: 0% 50%; }
      50% { background-position: 100% 50%; }
      100% { background-position: 0% 50%; }
    }

    @keyframes marquee {
      0% { transform: translateX(0); }
      100% { transform: translateX(-50%); }
    }

    @keyframes marquee-reverse {
      0% { transform: translateX(-50%); }
      100% { transform: translateX(0); }
    }

    @keyframes fade-in-left {
      from {
        opacity: 0;
        transform: translateX(-30px);
      }
      to {
        opacity: 1;
        transform: translateX(0);
      }
    }

    @keyframes fade-in-up {
      from {
        opacity: 0;
        transform: translateY(40px);
      }
      to {
        opacity: 1;
        transform: translateY(0);
      }
    }

    @keyframes fade-in {
      from { opacity: 0; }
      to { opacity: 1; }
    }

    @keyframes pulse-dot {
      0%, 100% { opacity: 1; }
      50% { opacity: 0.4; }
    }

    @keyframes dialing-dots {
      0%, 100% { opacity: 0.4; }
      50% { opacity: 1; }
    }

    @keyframes connected-pulse {
      0%, 100% { transform: scale(1); }
      50% { transform: scale(1.1); }
    }

    @keyframes status-pop {
      0% { 
        opacity: 0; 
        transform: scale(0.8);
      }
      50% {
        transform: scale(1.05);
      }
      100% { 
        opacity: 1; 
        transform: scale(1);
      }
    }

    @keyframes card-enter {
      from {
        opacity: 0;
        transform: translateX(-10px);
      }
      to {
        opacity: 1;
        transform: translateX(0);
      }
    }

    @keyframes batch-slide-in {
      from {
        opacity: 0;
        transform: translateY(20px);
      }
      to {
        opacity: 1;
        transform: translateY(0);
      }
    }

    @keyframes batch-slide-out {
      from {
        opacity: 1;
        transform: translateY(0);
      }
      to {
        opacity: 0;
        transform: translateY(-20px);
      }
    }

    .kixie-feature-power-dialer .batch-enter {
      animation: batch-slide-in 0.4s ease-out forwards;
    }

    .kixie-feature-power-dialer .batch-exit {
      animation: batch-slide-out 0.4s ease-out forwards;
    }

/* =========================================================
   Features Page Template
   ========================================================= */

.kixie-features-page {
    --kixie-feature-bg: #fff;
    --kixie-feature-ink: #2b2240;
    --kixie-feature-muted: #6d6482;
    --kixie-feature-border: #e4deef;
    --kixie-feature-cta: #e8483f;
    --kixie-feature-cta-hover: #cf372f;
    --kixie-feature-primary: #7f43dd;
    --kixie-feature-primary-soft: #f0e8ff;
    background: var(--kixie-feature-bg);
    color: var(--kixie-feature-ink);
}

.kixie-features-container {
    width: min(1200px, calc(100% - 3rem));
    margin: 0 auto;
}

.kixie-features-hero {
    padding: 9rem 0 4rem;
    background: #fff;
}

.kixie-features-hero-grid {
    display: grid;
    grid-template-columns: 1.05fr 1fr;
    gap: 3rem;
    align-items: center;
}

.kixie-features-hero-content h1 {
    margin: 0;
    font-size: clamp(2rem, 4.6vw, 4rem);
    line-height: 1.08;
    letter-spacing: -0.02em;
    color: var(--kixie-feature-ink);
}

.kixie-features-hero-content p {
    margin: 1.5rem 0 0;
    font-size: clamp(1rem, 1.8vw, 1.25rem);
    line-height: 1.38;
    color: var(--kixie-feature-muted);
    max-width: 34rem;
}

.kixie-features-hero-actions {
    margin-top: 2rem;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 1rem 1.4rem;
}

.kixie-features-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 2.3rem;
    padding: 0.5rem 1.2rem;
    border-radius: 0.75rem;
    border: 0;
    text-decoration: none;
    font-size: 0.76rem;
    font-weight: 700;
    letter-spacing: 0.015em;
    line-height: 1.1;
    text-transform: uppercase;
    color: #fff;
    background: var(--kixie-feature-cta);
    transition: transform 0.2s ease, background-color 0.2s ease, box-shadow 0.2s ease;
}

.kixie-features-btn:hover,
.kixie-features-btn:focus {
    background: var(--kixie-feature-cta-hover);
    color: #fff;
    transform: translateY(-1px);
    box-shadow: 0 8px 20px rgba(232, 72, 63, 0.28);
}

.kixie-features-meta {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.9rem;
    color: var(--kixie-feature-muted);
}

.kixie-features-check {
    width: 1.15rem;
    height: 1.15rem;
    display: inline-flex;
    color: #1f9e63;
}

.kixie-features-check svg {
    width: 100%;
    height: 100%;
}

.kixie-features-hero-card {
    position: relative;
    border-radius: 1.6rem;
    padding: clamp(1.5rem, 2vw, 2.5rem);
    background: linear-gradient(135deg, #f2eff8 0%, #f9f7fd 100%);
    border: 1px solid #ede8f6;
    overflow: hidden;
}

.kixie-features-dashboard {
    border-radius: 1rem;
    background: #fff;
    border: 1px solid var(--kixie-feature-border);
    box-shadow: 0 25px 45px rgba(38, 28, 64, 0.14);
    padding: 1.25rem;
    position: relative;
    z-index: 2;
}

.kixie-features-window-dots {
    display: flex;
    gap: 0.5rem;
    margin-bottom: 1rem;
}

.kixie-features-window-dots span {
    width: 0.7rem;
    height: 0.7rem;
    border-radius: 999px;
}

.kixie-features-window-dots span:nth-child(1) {
    background: rgba(232, 72, 63, 0.65);
}

.kixie-features-window-dots span:nth-child(2) {
    background: #f5be4d;
}

.kixie-features-window-dots span:nth-child(3) {
    background: #21b26f;
}

.kixie-features-chart {
    height: 8.5rem;
    display: flex;
    align-items: flex-end;
    gap: 0.5rem;
    margin-bottom: 1rem;
}

.kixie-features-bar {
    flex: 1;
    border-radius: 0.45rem 0.45rem 0 0;
    background: linear-gradient(180deg, rgba(232, 72, 63, 0.65) 0%, rgba(232, 72, 63, 1) 100%);
    height: var(--kixie-feature-bar-height);
    transform: scaleY(0);
    transform-origin: bottom;
    animation: kixie-feature-bars 0.52s ease-out forwards;
    animation-delay: var(--kixie-feature-bar-delay);
}

.kixie-features-chart-stats {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.75rem;
}

.kixie-features-chart-stats div {
    text-align: center;
}

.kixie-features-chart-stats span {
    display: block;
    font-size: 0.72rem;
    color: var(--kixie-feature-muted);
}

.kixie-features-chart-stats strong {
    display: block;
    margin-top: 0.2rem;
    font-size: 1rem;
    color: var(--kixie-feature-ink);
}

.kixie-features-floating-card {
    position: absolute;
    border-radius: 0.9rem;
    border: 1px solid var(--kixie-feature-border);
    background: #fff;
    box-shadow: 0 14px 30px rgba(35, 26, 58, 0.12);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--kixie-feature-muted);
    z-index: 3;
}

.kixie-features-floating-card svg {
    width: 55%;
    height: 55%;
}

.kixie-features-floating-settings {
    width: 3.75rem;
    height: 3.75rem;
    top: 1.25rem;
    left: 1.1rem;
    animation: kixie-feature-float-up 3.2s ease-in-out infinite;
}

.kixie-features-floating-phone {
    width: 4.5rem;
    height: 4.5rem;
    right: 1.3rem;
    bottom: 1.1rem;
    color: var(--kixie-feature-cta);
    animation: kixie-feature-float-down 3.8s ease-in-out infinite;
}

.kixie-features-person {
    position: absolute;
    left: 2rem;
    bottom: 1.8rem;
    width: 4rem;
    z-index: 1;
    opacity: 0.9;
}

.kixie-features-person-head {
    display: block;
    width: 2.2rem;
    height: 2.2rem;
    margin: 0 auto 0.25rem;
    border-radius: 999px;
    background: linear-gradient(135deg, #f0e6d4 0%, #dbc8ad 100%);
}

.kixie-features-person-body {
    display: block;
    width: 2.85rem;
    height: 2.5rem;
    margin: 0 auto;
    border-radius: 1.4rem 1.4rem 0.6rem 0.6rem;
    background: linear-gradient(135deg, #cab5e8 0%, #b19bd8 100%);
}

.kixie-features-plant {
    position: absolute;
    right: 4.4rem;
    bottom: 1.5rem;
    width: 2rem;
    height: 3rem;
    z-index: 1;
}

.kixie-features-plant span {
    display: block;
    width: 100%;
    height: 100%;
    border-radius: 1.4rem 1.4rem 0.2rem 0.2rem;
    background: linear-gradient(180deg, #81c7a0 0%, #53a777 100%);
}

.kixie-features-accordion {
    padding: 0 0 4rem;
    background: #fff;
}

.kixie-feature-category {
    border-bottom: 1px solid var(--kixie-feature-border);
}

.kixie-feature-heading {
    margin: 0;
}

.kixie-feature-toggle {
    width: 100%;
    border: 0;
    background: transparent;
    color: inherit;
    text-align: left;
    padding: 1.45rem 0.25rem;
    display: flex;
    align-items: center;
    gap: 0.9rem;
    font-size: clamp(1.35rem, 2.3vw, 2.05rem);
    font-weight: 700;
    letter-spacing: -0.01em;
    cursor: pointer;
}

.kixie-feature-toggle:hover {
    color: #3d2d5d;
}

.kixie-feature-chevron {
    width: 1.2rem;
    height: 1.2rem;
    display: inline-flex;
    flex-shrink: 0;
    transition: transform 0.2s ease;
}

.kixie-feature-chevron svg {
    width: 100%;
    height: 100%;
}

.kixie-feature-category.is-open .kixie-feature-chevron {
    transform: rotate(90deg);
}

.kixie-feature-panel {
    padding: 0.3rem 0 1.8rem 2rem;
}

.kixie-feature-panel[hidden] {
    display: none;
}

.kixie-feature-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1.35rem 1.7rem;
}

.kixie-feature-item h3 {
    margin: 0;
    color: var(--kixie-feature-primary);
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    font-size: 1.02rem;
    font-weight: 700;
}

.kixie-feature-external {
    width: 0.82rem;
    height: 0.82rem;
    opacity: 0.45;
    transition: opacity 0.2s ease;
}

.kixie-feature-item:hover .kixie-feature-external {
    opacity: 1;
}

.kixie-feature-external svg {
    width: 100%;
    height: 100%;
}

.kixie-feature-item p {
    margin: 0.45rem 0 0;
    font-size: 0.92rem;
    line-height: 1.55;
    color: var(--kixie-feature-muted);
}

.kixie-features-cta {
    padding: 2.5rem 0 5.4rem;
    background: #fff;
}

.kixie-feature-platform {
    padding: 5.8rem 0;
    background: #fff;
}

.kixie-feature-platform-heading {
    text-align: center;
    max-width: 54rem;
    margin: 0 auto 2.4rem;
}

.kixie-feature-platform-heading h2 {
    margin: 1rem 0 0.85rem;
    font-size: clamp(1.9rem, 4vw, 3rem);
    line-height: 1.16;
    letter-spacing: -0.025em;
    color: #1f1533;
}

.kixie-feature-platform-heading p {
    margin: 0;
    color: #5f5b77;
    font-size: 1.08rem;
    line-height: 1.64;
}

.kixie-feature-platform-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    column-gap: 1.5rem;
    row-gap: 2rem;
    align-items: stretch;
}

.kixie-feature-platform-card {
    border: 1px solid #e4e6ef;
    border-radius: 1rem;
    background: #ffffff;
    padding: 1.5rem;
    display: flex;
    flex-direction: column;
    min-height: 14.25rem;
    overflow: hidden;
    margin: 0;
    transition: transform 0.22s ease, box-shadow 0.22s ease, border-color 0.22s ease;
}

.kixie-feature-platform-card:hover {
    transform: translateY(-4px);
    border-color: #d9bdff;
    box-shadow: 0 16px 30px -25px rgba(99, 37, 200, 0.42);
}

.kixie-feature-platform-icon {
    width: 2.25rem;
    height: 2.25rem;
    border-radius: 0.62rem;
    background: linear-gradient(135deg, #ef4444, #7c3aed);
    color: #ffffff;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.kixie-feature-platform-icon svg {
    width: 1rem;
    height: 1rem;
}

.kixie-feature-platform-card h3 {
    margin: 0.8rem 0 0.42rem;
    font-size: 1rem;
    color: #1f1533;
}

.kixie-feature-platform-card p {
    margin: 0 0 1rem;
    color: #5a5775;
    font-size: 0.88rem;
    line-height: 1.6;
}

.kixie-feature-platform-link {
    margin-top: auto;
    display: inline-flex;
    align-items: center;
    font-size: 0.86rem;
    text-decoration: none;
    color: #1f1533;
    font-weight: 600;
}

.kixie-feature-platform-link:hover,
.kixie-feature-platform-link:focus {
    color: #7c3aed;
}

.kixie-features-cta-inner {
    text-align: center;
    max-width: 44rem;
    margin: 0 auto;
}

.kixie-features-cta-inner h2 {
    margin: 0;
    font-size: clamp(1.9rem, 3.8vw, 2.7rem);
    line-height: 1.18;
    letter-spacing: -0.01em;
}

.kixie-features-btn-cta {
    margin-top: 1.5rem;
    padding: 0.9rem 2.3rem;
}

@keyframes kixie-feature-bars {
    from {
        transform: scaleY(0);
    }
    to {
        transform: scaleY(1);
    }
}

@keyframes kixie-feature-float-up {
    0%, 100% {
        transform: translateY(0);
    }
    50% {
        transform: translateY(-8px);
    }
}

@keyframes kixie-feature-float-down {
    0%, 100% {
        transform: translateY(0);
    }
    50% {
        transform: translateY(9px);
    }
}

@media (max-width: 1024px) {
    .kixie-features-hero-grid {
        grid-template-columns: 1fr;
    }

    .kixie-features-hero-illustration {
        order: 2;
    }

    .kixie-features-hero-content {
        order: 1;
    }
}

@media (max-width: 820px) {
    .kixie-features-container {
        width: min(1200px, calc(100% - 2rem));
    }

    .kixie-features-hero {
        padding-top: 8rem;
    }

    .kixie-feature-panel {
        padding-left: 0.4rem;
    }

    .kixie-feature-grid {
        grid-template-columns: 1fr;
        gap: 1rem;
    }

    .kixie-feature-toggle {
        font-size: 1.45rem;
        padding: 1.15rem 0.15rem;
    }

    .kixie-feature-platform-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 560px) {
    .kixie-features-hero-actions {
        align-items: flex-start;
        flex-direction: column;
    }

    .kixie-features-btn {
        width: 100%;
    }

    .kixie-features-floating-settings {
        width: 3rem;
        height: 3rem;
        left: 0.8rem;
        top: 0.8rem;
    }

    .kixie-features-floating-phone {
        width: 3.45rem;
        height: 3.45rem;
        right: 0.9rem;
        bottom: 0.9rem;
    }

    .kixie-feature-platform-grid {
        grid-template-columns: 1fr;
    }
}

.kixie-feature-faq {
    padding: 5.5rem 0 4.25rem;
    background: #fff;
}

.kixie-feature-faq-header {
    max-width: 60rem;
    margin: 0 auto 2.4rem;
    text-align: center;
}

.kixie-feature-faq-header h2 {
    margin: 0;
    color: #201438;
    font-size: clamp(2rem, 5vw, 4rem);
    line-height: 1.05;
    letter-spacing: -0.03em;
}

.kixie-feature-faq-header p {
    margin: 1.3rem auto 0;
    max-width: 56rem;
    color: #6d6884;
    font-size: clamp(1.04rem, 2.1vw, 1.2rem);
}

.kixie-feature-faq-list {
    display: grid;
    gap: 1rem;
}

.kixie-feature-faq-item {
    border: 1px solid #e1dee8;
    border-radius: 1.16rem;
    background: #fff;
}

.kixie-feature-faq-question-wrap {
    margin: 0;
}

.kixie-feature-faq-trigger {
    width: 100%;
    border: 0;
    background: transparent;
    cursor: pointer;
    padding: 1.55rem 1.75rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    text-align: left;
    color: #201438;
    font-size: clamp(1.02rem, 2.05vw, 1.08rem);
    font-weight: 700;
}

.kixie-feature-faq-chevron {
    width: 1.08rem;
    height: 1.08rem;
    color: #2a203f;
    transition: transform 0.2s ease;
    flex-shrink: 0;
}

.kixie-feature-faq-chevron svg {
    width: 100%;
    height: 100%;
}

.kixie-feature-faq-item.is-open .kixie-feature-faq-chevron {
    transform: rotate(180deg);
}

.kixie-feature-faq-answer {
    padding: 0 1.75rem 1.45rem;
}

.kixie-feature-faq-answer > * {
    margin-top: 0;
    margin-bottom: 0.85rem;
}

.kixie-feature-faq-answer > *:last-child {
    margin-bottom: 0;
}

.kixie-feature-faq-answer p {
    color: #5f5a73;
    font-size: 1rem;
    line-height: 1.7;
}

.kixie-feature-faq-answer iframe {
    display: block;
    width: min(100%, 760px);
    max-width: 100%;
    aspect-ratio: 16 / 9;
    height: auto;
    border: 0;
    border-radius: 0.75rem;
}

@media (max-width: 820px) {
    .kixie-feature-faq {
        padding: 4.5rem 0 3.5rem;
    }

    .kixie-feature-faq-header {
        margin-bottom: 1.65rem;
    }

    .kixie-feature-faq-trigger {
        padding: 1.3rem 1.05rem;
    }

    .kixie-feature-faq-answer {
        padding: 0 1.05rem 1.15rem;
    }
}

/* Hybrid Gutenberg content zones for feature + solutions templates. */
.kixie-feature-editor-content,
.kixie-solutions-editor-content {
    background: #ffffff;
    padding: 2.5rem 0;
}

.kixie-editor-content-body {
    display: grid;
    gap: 1.2rem;
}

.kixie-editor-content-body > *:first-child {
    margin-top: 0;
}

.kixie-editor-content-body > *:last-child {
    margin-bottom: 0;
}

.kixie-editor-content-body .wp-block-group,
.kixie-editor-content-body .wp-block-columns,
.kixie-editor-content-body .wp-block-media-text {
    margin-block: 0.65rem;
}

.kixie-editor-content-body .wp-block-image img {
    border-radius: 16px;
}

.kixie-editor-content-body .wp-block-separator {
    margin-block: 1.8rem;
}

.kixie-editor-content-body .wp-block-buttons {
    margin-top: 0.45rem;
}

@media (max-width: 768px) {
    .kixie-feature-editor-content,
    .kixie-solutions-editor-content {
        padding: 2rem 0;
    }
}

/* Feature hero media modes: image + looping video. */
.kixie-feature-hero-media-shell {
    padding: 0;
    overflow: hidden;
    min-height: 28rem;
}

.kixie-feature-hero-media-asset {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.kixie-feature-hero-media-shell-video .kixie-feature-hero-media-asset {
    background: #0f1320;
}

@media (max-width: 1024px) {
    .kixie-feature-hero-media-shell {
        min-height: 20rem;
    }
}

/* Home hero section for the Home Page template. */
.kixie-home-container {
    width: 100%;
    max-width: 1280px;
    margin: 0 auto;
    padding: 0 2rem;
}

.kixie-home-page-template .kixie-home-hero {
    background: #ffffff;
    padding: 6.8rem 0 3.8rem;
}

.kixie-home-page-template .kixie-home-hero-intro {
    max-width: 52rem;
    margin: 0 auto 2.2rem;
    text-align: center;
}

.kixie-home-page-template .kixie-home-hero-intro h1 {
    margin: 0;
    color: #26193e;
    letter-spacing: -0.03em;
    font-size: clamp(2.2rem, 5vw, 4.15rem);
    line-height: 1.06;
}

.kixie-home-page-template .kixie-home-hero-intro p {
    margin: 1.2rem auto 0;
    max-width: 48rem;
    color: #665f7d;
    font-size: clamp(1.02rem, 1.8vw, 1.45rem);
    line-height: 1.56;
}

.kixie-home-page-template .kixie-home-hero-actions {
    margin-top: 1.7rem;
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 0.85rem;
    flex-wrap: wrap;
}

.kixie-home-page-template .kixie-home-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
    border-radius: 999px;
    min-height: 3.1rem;
    padding: 0.62rem 1.6rem;
    font-size: 1.02rem;
    font-weight: 700;
    transition: all 0.18s ease;
    border: 1px solid transparent;
}

.kixie-home-page-template .kixie-home-btn-primary {
    background: #ff1f1f;
    color: #ffffff;
}

.kixie-home-page-template .kixie-home-btn-primary:hover,
.kixie-home-page-template .kixie-home-btn-primary:focus {
    background: #e11d1d;
    color: #ffffff;
}

.kixie-home-page-template .kixie-home-btn-secondary {
    background: #ffffff;
    color: #2a1d43;
    border-color: #dedbe8;
}

.kixie-home-page-template .kixie-home-btn-secondary:hover,
.kixie-home-page-template .kixie-home-btn-secondary:focus {
    border-color: #c6bfd8;
    color: #2a1d43;
}

.kixie-home-page-template .kixie-home-hero-card {
    max-width: 840px;
    margin: 0 auto;
    background: #ffffff;
    border: 1px solid #ebe6f3;
    border-radius: 1rem;
    box-shadow: 0 24px 54px -44px rgba(18, 13, 30, 0.55);
    overflow: hidden;
}

.kixie-home-page-template .kixie-home-hero-card-head {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 0.8rem;
    padding: 1rem 1.1rem 0.8rem;
}

.kixie-home-page-template .kixie-home-hero-card-head h3 {
    margin: 0;
    color: #24173a;
    font-size: 1.86rem;
    letter-spacing: -0.01em;
}

.kixie-home-page-template .kixie-home-hero-card-tabs {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    flex-wrap: wrap;
}

.kixie-home-page-template .kixie-home-hero-card-tabs span {
    padding: 0.38rem 0.68rem;
    border-radius: 999px;
    font-size: 0.78rem;
    color: #7e7894;
    background: transparent;
}

.kixie-home-page-template .kixie-home-hero-card-tabs .is-active {
    background: #f0edf5;
    color: #2b1d43;
    font-weight: 600;
}

.kixie-home-page-template .kixie-home-hero-stats {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0.75rem;
    padding: 0 1.1rem 1.02rem;
}

.kixie-home-page-template .kixie-home-hero-stat {
    border-radius: 0.75rem;
    background: #fbf7fa;
    border: 1px solid #f1ecf6;
    padding: 0.72rem 0.72rem 0.6rem;
}

.kixie-home-page-template .kixie-home-hero-stat p {
    margin: 0;
    color: #4b4463;
    font-size: 0.77rem;
    line-height: 1.28;
}

.kixie-home-page-template .kixie-home-hero-stat strong {
    display: block;
    margin-top: 0.26rem;
    color: #2a1c42;
    font-size: 0.96rem;
    letter-spacing: -0.01em;
}

.kixie-home-page-template .kixie-home-hero-stat small {
    display: block;
    margin-top: 0.2rem;
    font-size: 0.7rem;
    line-height: 1.25;
}

.kixie-home-page-template .kixie-home-hero-stat .is-up {
    color: #1ca475;
}

.kixie-home-page-template .kixie-home-hero-stat .is-down {
    color: #ef4444;
}

.kixie-home-page-template .kixie-home-hero-list {
    border-top: 1px solid #ece8f2;
    padding: 0 1.1rem 0.65rem;
}

.kixie-home-page-template .kixie-home-hero-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    padding: 0.65rem 0;
    border-bottom: 1px solid #f0edf5;
}

.kixie-home-page-template .kixie-home-hero-row:last-child {
    border-bottom: 0;
}

.kixie-home-page-template .kixie-home-hero-contact {
    min-width: 0;
    display: flex;
    align-items: center;
    gap: 0.6rem;
}

.kixie-home-page-template .kixie-home-hero-avatar {
    width: 2rem;
    height: 2rem;
    border-radius: 999px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: #ffffff;
    font-size: 0.74rem;
    font-weight: 700;
    background: linear-gradient(145deg, #ff2d55, #8b2cff);
    flex-shrink: 0;
}

.kixie-home-page-template .kixie-home-hero-name {
    margin: 0;
    color: #22173a;
    font-size: 0.92rem;
    font-weight: 700;
    line-height: 1.24;
}

.kixie-home-page-template .kixie-home-hero-phone {
    margin: 0.1rem 0 0;
    color: #7d7693;
    font-size: 0.82rem;
    line-height: 1.22;
}

.kixie-home-page-template .kixie-home-hero-outcome {
    min-width: 0;
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.78rem;
    color: #6f6886;
}

.kixie-home-page-template .kixie-home-hero-tag {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.19rem 0.45rem;
    border-radius: 999px;
    border: 1px solid #f0ecf6;
    background: #f7f4fb;
    color: #7a6b93;
    font-size: 0.7rem;
    white-space: nowrap;
}

.kixie-home-page-template .kixie-home-hero-duration {
    white-space: nowrap;
}

.kixie-home-page-template .kixie-home-hero-status {
    white-space: nowrap;
}

.kixie-home-page-template .kixie-home-hero-status.is-done,
.kixie-home-page-template .kixie-home-hero-status.is-ai {
    color: #16a774;
}

@media (max-width: 980px) {
    .kixie-home-page-template .kixie-home-hero {
        padding-top: 6rem;
    }

    .kixie-home-page-template .kixie-home-hero-stats {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 760px) {
    .kixie-home-container {
        padding: 0 1rem;
    }

    .kixie-home-page-template .kixie-home-hero-intro h1 {
        font-size: clamp(1.95rem, 8vw, 2.7rem);
    }

    .kixie-home-page-template .kixie-home-hero-card-head {
        flex-direction: column;
        align-items: flex-start;
    }

    .kixie-home-page-template .kixie-home-hero-row {
        flex-direction: column;
        align-items: flex-start;
    }

    .kixie-home-page-template .kixie-home-hero-outcome {
        width: 100%;
        justify-content: space-between;
    }
}

/* Mobile hardening for Features + Solutions page templates. */
.kixie-features-page,
.kixie-solutions-page {
    width: 100%;
    max-width: 100%;
    overflow-x: hidden;
    overflow-x: clip;
}

.kixie-solutions-page,
.kixie-solutions-page *,
.kixie-solutions-page *::before,
.kixie-solutions-page *::after {
    box-sizing: border-box;
}

.kixie-feature-toggle-label {
    flex: 1;
    min-width: 0;
    overflow-wrap: anywhere;
}

.kixie-feature-item h3 {
    display: flex;
    align-items: flex-start;
    flex-wrap: wrap;
}

.kixie-feature-item-title-text {
    min-width: 0;
}

a.kixie-feature-item-title-text {
    color: inherit;
    text-decoration: none;
}

a.kixie-feature-item-title-text:hover {
    text-decoration: underline;
}

.kixie-feature-external {
    margin-top: 0.1rem;
    flex: 0 0 auto;
}

.kixie-solutions-hero-media {
    display: flex;
    justify-content: center;
}

.kixie-solutions-hero-image {
    width: 100%;
    max-width: 600px;
}

@media (max-width: 1023px) {
    .kixie-features-hero {
        padding-top: 10rem;
    }

    .kixie-solutions-hero {
        padding-top: 8.9rem;
    }

    .kixie-feature-panel {
        padding-left: 0;
    }

    .kixie-features-hero-grid,
    .kixie-solutions-hero-grid {
        gap: 2rem;
    }

    .kixie-solutions-card,
    .kixie-solutions-platform-card {
        min-height: 0;
    }
}

@media (max-width: 767px) {
    .kixie-features-container {
        width: min(1200px, calc(100% - 1.5rem));
    }

    .kixie-solutions-container {
        padding: 0 0.75rem;
    }

    .kixie-features-hero {
        padding-top: 11.2rem;
        padding-bottom: 3rem;
    }

    .kixie-solutions-hero {
        padding-top: 8.75rem;
        padding-bottom: 3rem;
    }

    .kixie-solutions-hero-actions {
        width: 100%;
    }

    .kixie-feature-toggle {
        align-items: flex-start;
        gap: 0.65rem;
        font-size: clamp(1.2rem, 6vw, 1.42rem);
    }

    .kixie-feature-panel {
        padding: 0.2rem 0 1.15rem;
    }

    .kixie-features-chart {
        height: 7.1rem;
        gap: 0.35rem;
    }

    .kixie-features-chart-stats {
        grid-template-columns: 1fr;
        gap: 0.5rem;
    }

    .kixie-features-chart-stats div {
        display: flex;
        align-items: baseline;
        justify-content: space-between;
        text-align: left;
    }

    .kixie-features-chart-stats strong {
        margin-top: 0;
    }

    .kixie-features-floating-settings,
    .kixie-features-floating-phone,
    .kixie-features-person,
    .kixie-features-plant {
        display: none;
    }

    .kixie-solutions-title {
        font-size: clamp(1.85rem, 8vw, 2.55rem);
    }

    .kixie-solutions-heading {
        margin-bottom: 1.8rem;
    }

    .kixie-solutions-heading p {
        font-size: 0.98rem;
    }

    .kixie-solutions-card,
    .kixie-solutions-platform-card {
        padding: 1.2rem;
    }

    .kixie-solutions-btn {
        width: 100%;
        max-width: 100%;
        box-sizing: border-box;
    }

    .kixie-solutions-marquee-shell::before,
    .kixie-solutions-marquee-shell::after {
        width: 2.4rem;
    }
}

@media (max-width: 560px) {
    .kixie-feature-item h3 {
        font-size: 0.98rem;
    }

    .kixie-feature-item p {
        font-size: 0.9rem;
        line-height: 1.5;
    }

    .kixie-solutions-btn {
        font-size: 0.88rem;
        min-height: 2.65rem;
    }
}

/* Mobile hardening for feature detail template (Power Dialer pages). */
.kixie-feature-power-dialer {
    width: 100%;
    max-width: 100%;
    overflow-x: hidden;
    overflow-x: clip;
}

.kixie-feature-power-dialer .hero-content,
.kixie-feature-power-dialer .dialer-card,
.kixie-feature-power-dialer .stat-card,
.kixie-feature-power-dialer .contact-info,
.kixie-feature-power-dialer .contact-details {
    min-width: 0;
}

@media (max-width: 1023px) {
    .kixie-feature-power-dialer .hero {
        padding-top: 10.8rem;
        padding-bottom: 4rem;
    }

    .kixie-feature-power-dialer .hero-grid {
        gap: 2rem;
    }

    .kixie-feature-power-dialer .stats-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 767px) {
    .kixie-feature-power-dialer .container {
        padding: 0 0.9rem;
    }

    .kixie-feature-power-dialer .hero {
        padding-top: 11.6rem;
        padding-bottom: 3rem;
    }

    .kixie-feature-power-dialer .hero-title {
        font-size: clamp(1.9rem, 9vw, 2.5rem);
        margin-bottom: 1rem;
        overflow-wrap: anywhere;
    }

    .kixie-feature-power-dialer .hero-description {
        font-size: 1rem;
        margin-bottom: 1.4rem;
        max-width: 100%;
        overflow-wrap: anywhere;
    }

    .kixie-feature-power-dialer .btn-lg {
        width: 100%;
    }

    .kixie-feature-power-dialer .dialer-card {
        padding: 1rem;
    }

    .kixie-feature-power-dialer .dialer-header {
        flex-direction: column;
        align-items: flex-start;
        gap: 0.6rem;
        margin-bottom: 1rem;
    }

    .kixie-feature-power-dialer .dialer-header-left {
        width: 100%;
        justify-content: space-between;
    }

    .kixie-feature-power-dialer .dialer-title {
        font-size: 1rem;
    }

    .kixie-feature-power-dialer .stats-grid {
        gap: 0.6rem;
        margin-bottom: 1rem;
    }

    .kixie-feature-power-dialer .stat-card {
        padding: 0.75rem;
    }

    .kixie-feature-power-dialer .stat-value {
        font-size: 1.28rem;
    }

    .kixie-feature-power-dialer .contact-section {
        min-height: 0;
    }

    .kixie-feature-power-dialer .contact-card {
        flex-direction: column;
        align-items: flex-start;
        gap: 0.65rem;
        padding-right: 0;
    }

    .kixie-feature-power-dialer .contact-status {
        margin-right: 0;
        min-width: 0;
        width: 100%;
        justify-content: flex-start;
    }
}

@media (max-width: 420px) {
    .kixie-feature-power-dialer .stats-grid {
        grid-template-columns: 1fr;
    }
}

/* Integrations Directory Template */
.kixie-integrations-page {
    background: #f5f6fa;
    color: #1f1533;
}

.kixie-integrations-container {
    width: 100%;
    max-width: 1280px;
    margin: 0 auto;
    padding: 0 2rem;
}

.kixie-integrations-hero {
    padding: 9.6rem 0 4.2rem;
    background: #ffffff;
    border-bottom: 1px solid #ececf2;
}

.kixie-integrations-hero h1 {
    margin: 0;
    text-align: center;
    font-size: clamp(2rem, 5vw, 3.7rem);
    line-height: 1.08;
    letter-spacing: -0.035em;
    color: #1f1533;
}

.kixie-integrations-hero p {
    margin: 1.1rem auto 0;
    max-width: 46rem;
    text-align: center;
    color: #5b5774;
    font-size: clamp(1rem, 2vw, 1.22rem);
    line-height: 1.62;
}

.kixie-integrations-directory {
    padding: 3.2rem 0 5rem;
    background: #ffffff;
}

.kixie-integrations-layout {
    display: grid;
    grid-template-columns: 14.5rem minmax(0, 1fr);
    gap: 2.15rem;
    align-items: flex-start;
}

.kixie-integrations-sidebar {
    position: sticky;
    top: 6.5rem;
}

.kixie-integrations-sidebar-title {
    margin: 0 0 0.85rem;
    font-size: 0.73rem;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: #706c86;
    font-weight: 700;
}

.kixie-integrations-category-nav {
    display: flex;
    flex-direction: column;
    gap: 0.2rem;
}

.kixie-integrations-category-button {
    width: 100%;
    border: 0;
    border-left: 2px solid transparent;
    border-radius: 0.6rem;
    background: transparent;
    color: #67647f;
    font-size: 0.9rem;
    font-weight: 500;
    line-height: 1.3;
    text-align: left;
    padding: 0.5rem 0.75rem;
    cursor: pointer;
    transition: color 0.18s ease, background-color 0.18s ease, border-color 0.18s ease;
}

.kixie-integrations-category-button:hover,
.kixie-integrations-category-button:focus {
    color: #1f1533;
    background: #f7f7fb;
    outline: none;
}

.kixie-integrations-category-button.is-active {
    color: #dc2626;
    border-left-color: #dc2626;
    background: rgba(220, 38, 38, 0.08);
    font-weight: 700;
}

.kixie-integrations-grid-wrap {
    min-width: 0;
}

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

.kixie-integration-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    text-decoration: none;
    border-radius: 1rem;
    border: 1px solid #e3e6f0;
    background: #ffffff;
    padding: 1.55rem 1.25rem;
    min-height: 13.8rem;
    transition: transform 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease;
}

.kixie-integration-card:hover,
.kixie-integration-card:focus {
    transform: translateY(-3px);
    border-color: #cfd6e6;
    box-shadow: 0 14px 30px -24px rgba(31, 21, 51, 0.35);
}

.kixie-integration-card[hidden] {
    display: none !important;
}

.kixie-integration-logo-wrap {
    width: 100%;
    height: 5rem;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 1rem;
}

.kixie-integration-logo-wrap img {
    max-width: 8.8rem;
    max-height: 3.6rem;
    width: auto;
    height: auto;
    object-fit: contain;
}

.kixie-integration-logo-fallback {
    width: 3.2rem;
    height: 3.2rem;
    border-radius: 0.8rem;
    background: linear-gradient(135deg, #ef4444, #7c3aed);
    color: #ffffff;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 0.95rem;
    font-weight: 700;
    letter-spacing: 0.04em;
}

.kixie-integration-tags {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 0.36rem;
    margin-bottom: 0.85rem;
}

.kixie-integration-tag {
    border-radius: 999px;
    padding: 0.25rem 0.56rem;
    border: 1px solid transparent;
    font-size: 0.72rem;
    font-weight: 600;
    line-height: 1.2;
    white-space: nowrap;
}

.kixie-integration-tag-native {
    color: #047857;
    background: #ecfdf5;
    border-color: #a7f3d0;
}

.kixie-integration-tag-custom {
    color: #b45309;
    background: #fffbeb;
    border-color: #fcd34d;
}

.kixie-integration-tag-category {
    color: #67647f;
    background: #f6f7fb;
    border-color: #e4e7f1;
}

.kixie-integration-name {
    margin: 0;
    color: #1f1533;
    font-size: 1rem;
    line-height: 1.32;
}

.kixie-integrations-empty {
    margin: 0;
    padding: 3.2rem 0 1.25rem;
    text-align: center;
    color: #6a677f;
    font-size: 0.98rem;
}

.kixie-integrations-note {
    padding: 2.7rem 0;
    border-top: 1px solid #ececf2;
    border-bottom: 1px solid #ececf2;
    background: #fbfbfd;
}

.kixie-integrations-note p {
    margin: 0 auto;
    max-width: 63rem;
    text-align: center;
    font-size: 0.93rem;
    line-height: 1.8;
    color: #6a677f;
}

@media (max-width: 1199px) {
    .kixie-integrations-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 1023px) {
    .kixie-integrations-container {
        padding: 0 1.25rem;
    }

    .kixie-integrations-hero {
        padding-top: 8.8rem;
    }

    .kixie-integrations-layout {
        grid-template-columns: 1fr;
        gap: 1.25rem;
    }

    .kixie-integrations-sidebar {
        position: static;
    }

    .kixie-integrations-category-nav {
        flex-direction: row;
        flex-wrap: wrap;
    }

    .kixie-integrations-category-button {
        width: auto;
        border-left-width: 1px;
        border-left-color: #e3e6f0;
        border-radius: 999px;
    }
}

@media (max-width: 767px) {
    .kixie-integrations-directory {
        padding-top: 2.3rem;
    }

    .kixie-integrations-grid {
        grid-template-columns: 1fr;
    }

    .kixie-integration-card {
        min-height: 12.8rem;
    }

    .kixie-integrations-note {
        padding: 2rem 0;
    }
}

/* Integration Landing Template */
.kixie-integration-landing-page {
    --background: hsl(40, 33%, 96%);
    --foreground: hsl(270, 30%, 15%);
    --card: hsl(40, 30%, 98%);
    --muted-foreground: hsl(270, 10%, 45%);
    --border: hsl(40, 15%, 88%);
    background: #f6f7fb;
    color: #1f1533;
}

.kixie-int-container {
    width: 100%;
    max-width: 1280px;
    margin: 0 auto;
    padding: 0 2rem;
}

.kixie-int-hero {
    background: #ffffff;
    padding: 8.9rem 0 4.2rem;
    border-bottom: 1px solid #ececf2;
}

.kixie-int-hero-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    gap: 2.5rem;
    align-items: center;
}

.kixie-int-hero-media {
    position: relative;
}

.kixie-int-hero-composition {
    position: relative;
    max-width: 44rem;
    width: 88%;
    transform-origin: top left;
}

.kixie-int-crm-shell {
    border-radius: 1rem;
    overflow: hidden;
    background: #ffffff;
    border: 1px solid #d8dde8;
    box-shadow: 0 25px 50px -34px rgba(15, 23, 42, 0.5);
    font-size: 11px;
    line-height: 1.35;
}

.kixie-int-crm-topbar {
    background: #2d3e50;
    padding: 0.65rem 0.95rem;
}

.kixie-int-crm-topbar-left {
    display: flex;
    align-items: center;
    gap: 0.65rem;
}

.kixie-int-crm-topbar-item {
    color: rgba(255, 255, 255, 0.84);
    font-size: 0.75rem;
    font-weight: 500;
}

.kixie-int-crm-topbar-item.is-strong {
    color: #ffffff;
    font-weight: 600;
}

.kixie-int-crm-topbar-divider {
    color: rgba(255, 255, 255, 0.36);
    font-size: 0.7rem;
}

.kixie-int-crm-main {
    display: grid;
    grid-template-columns: 11rem minmax(0, 1fr) 8.7rem;
}

.kixie-int-crm-sidebar {
    border-right: 1px solid #e3e8f2;
    background: #f8f9fc;
    padding: 0.8rem 0.58rem 0.75rem;
}

.kixie-int-crm-contact {
    display: flex;
    align-items: center;
    gap: 0.42rem;
    margin-bottom: 0.6rem;
}

.kixie-int-crm-avatar {
    width: 2.15rem;
    height: 2.15rem;
    border-radius: 999px;
    background: linear-gradient(135deg, #8b5cf6, #f43f5e);
    color: #ffffff;
    font-size: 0.67rem;
    font-weight: 700;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.kixie-int-crm-contact-meta {
    min-width: 0;
}

.kixie-int-crm-name {
    margin: 0;
    font-size: 0.58rem;
    color: #201533;
    font-weight: 700;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.kixie-int-crm-role {
    margin: 0.1rem 0 0;
    font-size: 0.49rem;
    color: #7c3aed;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.kixie-int-crm-quick-actions {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 0.2rem;
    margin-bottom: 0.62rem;
}

.kixie-int-crm-quick-actions button {
    appearance: none;
    border: 1px solid #e0e5f1;
    border-radius: 0.35rem;
    background: #ffffff;
    padding: 0.24rem 0.1rem;
    color: #64748b;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 0.1rem;
    min-height: 1.7rem;
}

.kixie-int-crm-quick-actions button span {
    font-size: 0.47rem;
    line-height: 1;
    font-weight: 700;
}

.kixie-int-crm-quick-actions button em {
    font-style: normal;
    font-size: 0.41rem;
    line-height: 1;
}

.kixie-int-crm-about-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 0.3rem;
}

.kixie-int-crm-about-head span:first-child {
    color: #1f1533;
    font-size: 0.52rem;
    font-weight: 600;
}

.kixie-int-crm-about-head span:last-child {
    color: #7c3aed;
    font-size: 0.48rem;
}

.kixie-int-crm-fields {
    margin: 0;
    display: grid;
    gap: 0.28rem;
}

.kixie-int-crm-fields div {
    margin: 0;
}

.kixie-int-crm-fields dt {
    color: #7a8598;
    font-size: 0.46rem;
    margin: 0;
    line-height: 1.25;
}

.kixie-int-crm-fields dd {
    margin: 0.03rem 0 0;
    color: #334155;
    font-size: 0.5rem;
    line-height: 1.25;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.kixie-int-crm-fields dd.is-link {
    color: #7c3aed;
}

.kixie-int-crm-feed {
    min-width: 0;
}

.kixie-int-crm-tabs {
    display: flex;
    gap: 0.85rem;
    border-bottom: 1px solid #e3e8f2;
    padding: 0.4rem 0.7rem 0;
}

.kixie-int-crm-tabs button {
    appearance: none;
    border: 0;
    background: transparent;
    color: #69758b;
    font-size: 0.62rem;
    font-weight: 500;
    padding: 0 0 0.42rem;
    border-bottom: 2px solid transparent;
}

.kixie-int-crm-tabs button.is-active {
    color: #1f1533;
    border-bottom-color: #7c3aed;
}

.kixie-int-crm-search-area {
    border-bottom: 1px solid #e3e8f2;
    background: #fafbfe;
    padding: 0.44rem 0.7rem;
    display: flex;
    align-items: center;
    gap: 0.35rem;
}

.kixie-int-crm-search {
    flex: 1 1 auto;
    border: 1px solid #e0e5f1;
    border-radius: 0.34rem;
    background: #ffffff;
    color: #7a8598;
    font-size: 0.5rem;
    line-height: 1;
    padding: 0.3rem 0.47rem;
}

.kixie-int-crm-collapse {
    appearance: none;
    border: 0;
    border-radius: 0.3rem;
    background: #7c3aed;
    color: #ffffff;
    padding: 0.26rem 0.42rem;
    font-size: 0.48rem;
    line-height: 1;
}

.kixie-int-crm-filters {
    padding: 0.35rem 0.7rem;
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 0.42rem;
    border-bottom: 1px solid #eef1f7;
}

.kixie-int-crm-filters span {
    color: #7a8598;
    font-size: 0.52rem;
    line-height: 1;
}

.kixie-int-crm-filters span.is-active {
    color: #1f1533;
    font-weight: 600;
}

.kixie-int-crm-activities {
    padding: 0.52rem 0.7rem 0.88rem;
}

.kixie-int-crm-month {
    margin: 0 0 0.38rem;
    color: #7a8598;
    font-size: 0.52rem;
    line-height: 1;
}

.kixie-int-crm-activity-list {
    display: grid;
    gap: 0.33rem;
    max-height: 14rem;
    overflow: hidden;
}

.kixie-int-crm-activity-item {
    border: 1px solid transparent;
    border-radius: 0.45rem;
    padding: 0.42rem;
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 0.42rem;
    transition: background-color 0.2s ease, border-color 0.2s ease;
}

.kixie-int-crm-activity-item:hover {
    background: #f8f9fc;
}

.kixie-int-activity-new {
    border-color: #89d8af;
    background: #f0fdf5;
    box-shadow: 0 8px 18px -16px rgba(5, 150, 105, 0.55);
}

.kixie-int-crm-activity-main {
    min-width: 0;
}

.kixie-int-crm-activity-title {
    margin: 0;
    color: #1f1533;
    font-size: 0.52rem;
    font-weight: 600;
    line-height: 1.2;
}

.kixie-int-crm-activity-text {
    margin: 0.14rem 0 0;
    color: #69758b;
    font-size: 0.5rem;
    line-height: 1.35;
}

.kixie-int-crm-activity-text span {
    color: #7c3aed;
}

.kixie-int-crm-activity-meta {
    display: flex;
    align-items: center;
    gap: 0.32rem;
    flex-shrink: 0;
}

.kixie-int-crm-activity-time {
    color: #7a8598;
    font-size: 0.45rem;
    white-space: nowrap;
    line-height: 1;
}

.kixie-int-activity-sync-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.15rem;
    border-radius: 999px;
    padding: 0.15rem 0.28rem;
    background: rgba(16, 185, 129, 0.14);
    color: #059669;
    font-size: 0.42rem;
    line-height: 1;
    font-weight: 700;
    animation: kixie-int-synced-badge 0.3s ease-out both;
}

.kixie-int-activity-sync-badge span {
    font-size: 0.44rem;
    line-height: 1;
}

.kixie-int-crm-rail {
    border-left: 1px solid #e3e8f2;
    background: #f8f9fc;
    padding: 0.52rem 0.45rem;
    display: grid;
    gap: 0.6rem;
}

.kixie-int-crm-rail-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 0.25rem;
}

.kixie-int-crm-rail-head span:first-child {
    color: #1f1533;
    font-size: 0.5rem;
    font-weight: 600;
}

.kixie-int-crm-rail-head span:last-child {
    color: #7c3aed;
    font-size: 0.45rem;
}

.kixie-int-crm-company {
    border: 1px solid #e0e5f1;
    background: #ffffff;
    border-radius: 0.38rem;
    padding: 0.37rem;
    display: flex;
    align-items: center;
    gap: 0.33rem;
}

.kixie-int-crm-company-icon {
    width: 1.25rem;
    height: 1.25rem;
    border-radius: 0.26rem;
    background: rgba(124, 58, 237, 0.12);
    color: #7c3aed;
    font-size: 0.5rem;
    font-weight: 700;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.kixie-int-crm-company p {
    margin: 0;
    color: #1f1533;
    font-size: 0.49rem;
    font-weight: 600;
    line-height: 1.2;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.kixie-int-crm-company span {
    display: block;
    margin-top: 0.06rem;
    color: #7c3aed;
    font-size: 0.44rem;
    line-height: 1.2;
}

.kixie-int-crm-empty {
    border: 1px dashed #d8deea;
    border-radius: 0.37rem;
    color: #7a8598;
    font-size: 0.45rem;
    text-align: center;
    padding: 0.46rem 0.28rem;
    line-height: 1.2;
}

.kixie-int-dialer {
    position: absolute;
    top: 2.6rem;
    right: -0.78rem;
    width: 9rem;
    border-radius: 0.95rem;
    border: 1px solid #d8dde8;
    overflow: hidden;
    background: #ffffff;
    box-shadow: 0 25px 50px -18px rgba(15, 23, 42, 0.35);
    z-index: 2;
}

.kixie-int-dialer-head {
    background: #201533;
    color: #ffffff;
    padding: 0.46rem 0.58rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.kixie-int-dialer-brand {
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
    font-size: 0.67rem;
    font-weight: 700;
}

.kixie-int-dialer-mark {
    width: 1rem;
    height: 1rem;
    border-radius: 0.2rem;
    background: #f6323e;
    color: #ffffff;
    font-size: 0.54rem;
    line-height: 1;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.kixie-int-dialer-live {
    display: inline-flex;
    align-items: center;
    gap: 0.18rem;
    color: #34d399;
    font-size: 0.46rem;
    line-height: 1;
}

.kixie-int-live-dot {
    width: 0.32rem;
    height: 0.32rem;
    border-radius: 999px;
    background: #34d399;
    animation: kixie-int-live-pulse 2s ease-in-out infinite;
}

.kixie-int-dialer-contact {
    display: flex;
    align-items: center;
    gap: 0.38rem;
    padding: 0.5rem 0.58rem;
    background: #f8f9fc;
    border-bottom: 1px solid #e3e8f2;
}

.kixie-int-dialer-avatar {
    width: 1.45rem;
    height: 1.45rem;
    border-radius: 999px;
    background: linear-gradient(135deg, #8b5cf6, #f43f5e);
    color: #ffffff;
    font-size: 0.48rem;
    font-weight: 700;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.kixie-int-dialer-contact p {
    margin: 0;
    font-size: 0.58rem;
    color: #201533;
    font-weight: 600;
    line-height: 1.2;
}

.kixie-int-dialer-contact span {
    display: block;
    margin-top: 0.05rem;
    font-size: 0.47rem;
    color: #7a8598;
    line-height: 1.2;
}

.kixie-int-dialer-pad {
    padding: 0.44rem 0.5rem 0.5rem;
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.26rem;
}

.kixie-int-dialer-pad button {
    appearance: none;
    border: 0;
    width: 1.55rem;
    height: 1.55rem;
    margin: 0 auto;
    border-radius: 999px;
    background: #f3f5fb;
    color: #1f1533;
    font-size: 0.52rem;
    font-weight: 600;
    line-height: 1;
}

.kixie-int-dialer-actions {
    padding: 0 0.5rem 0.5rem;
    display: grid;
    gap: 0.3rem;
}

.kixie-int-dialer-call,
.kixie-int-dialer-sms {
    appearance: none;
    border-radius: 999px;
    border: 1px solid #e0e5f1;
    width: 100%;
    height: 1.88rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.3rem;
    padding: 0 0.65rem;
    font-size: 0.62rem;
    font-weight: 600;
    line-height: 1;
}

.kixie-int-dialer-call {
    border-color: #34d399;
    background: #34d399;
    color: #ffffff;
}

.kixie-int-dialer-call[disabled] {
    opacity: 0.9;
}

.kixie-int-call-icon {
    width: 0.48rem;
    height: 0.48rem;
    border: 2px solid #ffffff;
    border-left: 0;
    border-top: 0;
    border-radius: 0 0 0.6rem 0;
    transform: rotate(45deg);
    margin-top: -0.1rem;
}

.kixie-int-dialer-call-default,
.kixie-int-dialer-call-live {
    display: inline-flex;
    align-items: center;
    gap: 0.28rem;
}

.kixie-int-dialer-call-live {
    display: none;
}

.kixie-int-dialer-call.is-dialing .kixie-int-dialer-call-default {
    display: none;
}

.kixie-int-dialer-call.is-dialing .kixie-int-dialer-call-live {
    display: inline-flex;
}

.kixie-int-calling-dots {
    display: inline-flex;
    align-items: center;
    gap: 0.12rem;
}

.kixie-int-calling-dots span {
    width: 0.22rem;
    height: 0.22rem;
    border-radius: 999px;
    background: #ffffff;
    animation: kixie-int-calling-dots 1s ease-in-out infinite;
}

.kixie-int-calling-dots span:nth-child(2) {
    animation-delay: 0.15s;
}

.kixie-int-calling-dots span:nth-child(3) {
    animation-delay: 0.3s;
}

.kixie-int-dialer-sms {
    background: #ffffff;
    color: #1f1533;
}

@keyframes kixie-int-hero-float {
    0%,
    100% {
        transform: translateY(0);
    }
    50% {
        transform: translateY(-6px);
    }
}

.kixie-int-hero-float {
    animation: kixie-int-hero-float 5s ease-in-out infinite;
}

@keyframes kixie-int-dialer-slide-in {
    0% {
        opacity: 0;
        transform: translateX(1.6rem) scale(0.9);
    }
    100% {
        opacity: 1;
        transform: translateX(0) scale(1);
    }
}

.kixie-int-dialer-slide-in {
    animation: kixie-int-dialer-slide-in 0.6s ease-out 0.4s both;
}

@keyframes kixie-int-content-fade-in {
    0% {
        opacity: 0;
        transform: translateY(1.8rem);
    }
    100% {
        opacity: 1;
        transform: translateY(0);
    }
}

.kixie-int-content-fade-in {
    animation: kixie-int-content-fade-in 0.6s ease-out both;
}

@keyframes kixie-int-activity-slide-in {
    0% {
        opacity: 0;
        transform: translateX(-1rem) scale(0.95);
    }
    100% {
        opacity: 1;
        transform: translateX(0) scale(1);
    }
}

.kixie-int-activity-slide-in {
    animation: kixie-int-activity-slide-in 0.4s cubic-bezier(0.34, 1.56, 0.64, 1) both;
}

@keyframes kixie-int-synced-badge {
    0% {
        transform: scale(0);
    }
    50% {
        transform: scale(1.1);
    }
    100% {
        transform: scale(1);
    }
}

@keyframes kixie-int-live-pulse {
    0%,
    100% {
        opacity: 1;
        transform: scale(1);
    }
    50% {
        opacity: 0.5;
        transform: scale(1.2);
    }
}

@keyframes kixie-int-calling-dots {
    0%,
    100% {
        opacity: 1;
    }
    50% {
        opacity: 0.4;
    }
}

.kixie-int-hero-copy {
    max-width: 38.75rem;
}

.kixie-int-hero-badges {
    display: inline-flex;
    gap: 0.55rem;
    margin-bottom: 1rem;
}

.kixie-int-pill {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 1px solid #e1e5f0;
    border-radius: 0.55rem;
    padding: 0.44rem 0.95rem;
    font-size: 0.9rem;
    line-height: 1;
    font-weight: 600;
    color: #6a677f;
    background: #f6f7fb;
}

.kixie-int-pill-primary {
    color: #ffffff;
    border-color: #7c3aed;
    background: #7c3aed;
}

.kixie-int-hero-copy h1 {
    margin: 0 0 1.5rem;
    font-size: 2.25rem;
    line-height: 1.1;
    letter-spacing: -0.025em;
    color: #1f1533;
    font-weight: 700;
}

.kixie-int-hero-copy p {
    margin: 0;
    font-size: 1.125rem;
    line-height: 1.625;
    color: #615d79;
}

.kixie-int-hero-actions {
    margin-top: 2rem;
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 1rem;
}

.kixie-int-hero-actions .kixie-solutions-btn {
    min-height: 2.75rem;
    height: 2.75rem;
    padding: 0 1.75rem;
    font-size: 1rem;
    font-weight: 600;
    letter-spacing: 0;
}

@media (min-width: 768px) {
    .kixie-int-hero-copy h1 {
        font-size: 2.9rem;
    }

    .kixie-int-hero-copy p {
        font-size: 1.2rem;
    }
}

@media (min-width: 1024px) {
    .kixie-int-hero-copy h1 {
        font-size: 3.36rem;
    }
}

.kixie-int-btn-icon {
    width: 0.88rem;
    height: 0.88rem;
    margin-left: 0.45rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.kixie-int-btn-icon svg {
    width: 100%;
    height: 100%;
}

.kixie-int-benefits {
    padding: 5.6rem 0;
    background: linear-gradient(145deg, rgba(239, 68, 68, 0.16), #ffffff 45%, rgba(124, 58, 237, 0.18));
}

.kixie-int-heading {
    text-align: center;
    max-width: 52rem;
    margin: 0 auto 2.4rem;
}

.kixie-int-heading h2 {
    margin: 0;
    font-size: clamp(1.9rem, 4vw, 3.15rem);
    line-height: 1.14;
    letter-spacing: -0.03em;
    color: #1f1533;
}

.kixie-int-heading p {
    margin: 0.95rem 0 0;
    font-size: 1.04rem;
    line-height: 1.67;
    color: #635f7c;
}

.kixie-int-benefits-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1.35rem;
}

.kixie-int-benefit-card {
    border-radius: 1rem;
    border: 1px solid #e4e8f1;
    background: #ffffff;
    padding: 1.4rem;
    box-shadow: 0 15px 30px -28px rgba(17, 24, 39, 0.35);
}

.kixie-int-check {
    width: 2.75rem;
    height: 2.75rem;
    border-radius: 0.75rem;
    background: linear-gradient(135deg, #ef4444, #7c3aed);
    color: #ffffff;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.kixie-int-check svg {
    width: 1.2rem;
    height: 1.2rem;
}

.kixie-int-benefit-card p {
    margin: 0.95rem 0 0;
    color: #595676;
    font-size: 0.95rem;
    line-height: 1.72;
}

.kixie-int-details {
    padding: 5.8rem 0;
    background: #ffffff;
}

.kixie-int-details-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1.08fr);
    gap: 2.8rem;
    align-items: start;
}

.kixie-int-details-media {
    position: relative;
    min-height: 100%;
}

.kixie-int-details-media-sticky {
    position: sticky;
    top: 8rem;
    width: 28.125rem;
    max-width: 100%;
    border-radius: 0;
    overflow: visible;
    border: 0;
    box-shadow: none;
    background: transparent;
}

.kixie-int-details-demo-shell {
    position: relative;
    width: 100%;
    min-height: 22.5rem;
}

.kixie-int-details-demo-scale {
    position: relative;
    width: 33rem;
    transform: scale(0.85);
    transform-origin: top left;
}

.kixie-int-crm-shell-compact {
    font-size: 10px;
    box-shadow: 0 20px 40px -16px rgba(15, 23, 42, 0.35);
}

.kixie-int-crm-shell-compact .kixie-int-crm-main {
    grid-template-columns: 8.75rem minmax(0, 1fr) 6.25rem;
}

.kixie-int-crm-shell-compact .kixie-int-crm-activity-list {
    max-height: 8.6rem;
}

.kixie-int-dialer-compact {
    top: 2rem;
    right: -0.2rem;
    width: 8.125rem;
    box-shadow: 0 20px 40px -10px rgba(15, 23, 42, 0.3);
}

.kixie-int-dialer-compact .kixie-int-dialer-pad {
    gap: 0.2rem;
}

.kixie-int-dialer-compact .kixie-int-dialer-pad button {
    width: 1.45rem;
    height: 1.45rem;
}

.kixie-int-details-content {
    display: grid;
    gap: 2.4rem;
}

.kixie-int-detail-block {
    padding-bottom: 2rem;
    border-bottom: 1px solid #eceff6;
}

.kixie-int-detail-block:last-child {
    border-bottom: 0;
    padding-bottom: 0;
}

.kixie-int-detail-eyebrow {
    display: inline-block;
    font-size: 0.75rem;
    line-height: 1;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: #7c3aed;
    font-weight: 700;
    margin-bottom: 0.65rem;
}

.kixie-int-detail-block h3 {
    margin: 0;
    font-size: clamp(1.35rem, 2.9vw, 2rem);
    line-height: 1.2;
    color: #1f1533;
}

.kixie-int-detail-block p {
    margin: 0.95rem 0 0;
    color: #5f5b78;
    font-size: 1rem;
    line-height: 1.72;
}

.kixie-int-detail-block ul {
    margin: 1rem 0 0;
    padding-left: 1.1rem;
}

.kixie-int-detail-block li {
    color: #5f5b78;
    margin-bottom: 0.8rem;
    line-height: 1.68;
}

.kixie-int-detail-block li strong {
    color: #1f1533;
}

.kixie-int-testimonials {
    padding: 5.6rem 0;
    background: linear-gradient(160deg, rgba(14, 165, 233, 0.08), rgba(99, 102, 241, 0.08));
}

.kixie-int-testimonials-carousel {
    max-width: 62rem;
    margin: 0 auto;
}

.kixie-int-testimonial-slide {
    border-radius: 1.25rem;
    border: 1px solid #dce9fb;
    padding: 2.15rem;
    background: rgba(255, 255, 255, 0.86);
    backdrop-filter: blur(8px);
}

.kixie-int-stars {
    display: flex;
    gap: 0.3rem;
    color: #f59e0b;
    margin-bottom: 1rem;
}

.kixie-int-stars span {
    width: 1rem;
    height: 1rem;
    display: inline-flex;
}

.kixie-int-stars svg {
    width: 100%;
    height: 100%;
}

.kixie-int-testimonial-slide blockquote {
    margin: 0;
    color: #1f1533;
    font-size: clamp(1.05rem, 2.1vw, 1.35rem);
    line-height: 1.7;
}

.kixie-int-testimonial-author {
    margin-top: 1.6rem;
    display: flex;
    align-items: center;
    gap: 0.75rem;
}

.kixie-int-testimonial-avatar {
    width: 2.65rem;
    height: 2.65rem;
    border-radius: 999px;
    background: linear-gradient(135deg, #bae6fd, #bfdbfe);
    color: #1d4ed8;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 1rem;
    font-weight: 700;
}

.kixie-int-testimonial-author p {
    margin: 0;
    color: #1f1533;
    font-weight: 700;
    font-size: 0.97rem;
}

.kixie-int-testimonial-author span {
    color: #606086;
    font-size: 0.88rem;
}

.kixie-int-testimonial-nav {
    margin-top: 1.35rem;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.85rem;
}

.kixie-int-testimonial-btn {
    width: 2.35rem;
    height: 2.35rem;
    border-radius: 999px;
    border: 1px solid #bfdbfe;
    background: #ffffff;
    color: #1f1533;
    font-size: 1rem;
    cursor: pointer;
    transition: background-color 0.2s ease, border-color 0.2s ease;
}

.kixie-int-testimonial-btn:hover,
.kixie-int-testimonial-btn:focus {
    border-color: #7dd3fc;
    background: #f0f9ff;
    outline: none;
}

.kixie-int-testimonial-dots {
    display: flex;
    align-items: center;
    gap: 0.42rem;
}

.kixie-int-dot {
    width: 0.62rem;
    height: 0.62rem;
    border-radius: 999px;
    border: 0;
    background: #bae6fd;
    cursor: pointer;
    transition: width 0.2s ease, background-color 0.2s ease;
}

.kixie-int-dot.is-active {
    width: 1.65rem;
    background: #0ea5e9;
}

.kixie-int-platform {
    padding: 5.6rem 0;
    background: #ffffff;
}

.kixie-int-platform-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1.15rem;
}

.kixie-int-platform-card {
    border-radius: 1rem;
    border: 1px solid #e4e8f1;
    background: #ffffff;
    padding: 1.35rem;
    display: flex;
    flex-direction: column;
    transition: border-color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease;
}

.kixie-int-platform-card:hover {
    transform: translateY(-3px);
    border-color: #d0b7fb;
    box-shadow: 0 14px 28px -24px rgba(76, 29, 149, 0.4);
}

.kixie-int-platform-icon {
    width: 2.65rem;
    height: 2.65rem;
    border-radius: 0.8rem;
    background: linear-gradient(135deg, rgba(239, 68, 68, 0.15), rgba(124, 58, 237, 0.2));
    color: #7c3aed;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.kixie-int-platform-icon svg {
    width: 1.2rem;
    height: 1.2rem;
}

.kixie-int-platform-card h3 {
    margin: 0.9rem 0 0.5rem;
    color: #1f1533;
    font-size: 1.01rem;
    line-height: 1.35;
}

.kixie-int-platform-card p {
    margin: 0;
    color: #5d5976;
    font-size: 0.9rem;
    line-height: 1.65;
}

.kixie-int-platform-card a {
    margin-top: auto;
    padding-top: 1rem;
    color: #7c3aed;
    text-decoration: none;
    font-weight: 600;
    font-size: 0.84rem;
    display: inline-flex;
    align-items: center;
    gap: 0.36rem;
}

.kixie-int-platform-card a span {
    width: 0.78rem;
    height: 0.78rem;
    display: inline-flex;
}

.kixie-int-platform-card a svg {
    width: 100%;
    height: 100%;
}

.kixie-int-platform-cta {
    margin-top: 2rem;
    text-align: center;
}

.kixie-int-platform-cta .kixie-solutions-btn {
    min-height: 2.75rem;
    height: 2.75rem;
    padding: 0 2rem;
    border-radius: 999px;
    font-size: 1rem;
    font-weight: 600;
    letter-spacing: 0;
    gap: 0.5rem;
}

.kixie-int-platform-cta .kixie-solutions-btn.kixie-solutions-btn-primary {
    background: #eb1414;
}

.kixie-int-platform-cta .kixie-solutions-btn.kixie-solutions-btn-primary:hover,
.kixie-int-platform-cta .kixie-solutions-btn.kixie-solutions-btn-primary:focus {
    background: rgba(235, 20, 20, 0.9);
}

.kixie-int-platform-cta .kixie-int-btn-icon {
    width: 1rem;
    height: 1rem;
    margin-left: 0;
}

.kixie-int-platform-cta p {
    margin: 0.65rem 0 0;
    color: #686582;
    font-size: 0.88rem;
}

@media (max-width: 1199px) {
    .kixie-int-hero-grid {
        grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
        gap: 2.2rem;
    }

    .kixie-int-hero-composition {
        max-width: 41rem;
        width: 100%;
    }

    .kixie-int-crm-main {
        grid-template-columns: 10rem minmax(0, 1fr);
    }

    .kixie-int-crm-rail {
        display: none;
    }

    .kixie-int-dialer {
        right: -0.3rem;
        top: 2.15rem;
        width: 9rem;
    }

    .kixie-int-platform-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

@media (max-width: 1023px) {
    .kixie-int-container {
        padding: 0 1.25rem;
    }

    .kixie-int-hero-grid {
        grid-template-columns: 1fr;
        gap: 1.4rem;
    }

    .kixie-int-hero {
        padding-top: 8.2rem;
    }

    .kixie-int-hero-composition {
        max-width: 100%;
    }

    .kixie-int-hero-media {
        order: 2;
    }

    .kixie-int-hero-copy {
        order: 1;
        max-width: none;
    }

    .kixie-int-crm-main {
        grid-template-columns: 9.4rem minmax(0, 1fr);
    }

    .kixie-int-crm-sidebar {
        padding-left: 0.45rem;
        padding-right: 0.45rem;
    }

    .kixie-int-dialer {
        right: -0.1rem;
        top: 1.9rem;
    }

    .kixie-int-benefits-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .kixie-int-details-grid {
        grid-template-columns: 1fr;
    }

    .kixie-int-details-media {
        display: none;
    }

    .kixie-int-platform-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 767px) {
    .kixie-int-hero-float {
        animation: none;
    }

    .kixie-int-hero-actions {
        flex-direction: column;
        align-items: stretch;
    }

    .kixie-int-hero-actions .kixie-solutions-btn {
        width: 100%;
    }

    .kixie-int-crm-main {
        grid-template-columns: 1fr;
    }

    .kixie-int-crm-sidebar,
    .kixie-int-crm-rail {
        display: none;
    }

    .kixie-int-crm-tabs {
        padding-left: 0.55rem;
        padding-right: 0.55rem;
        gap: 0.55rem;
    }

    .kixie-int-crm-search-area,
    .kixie-int-crm-filters {
        padding-left: 0.55rem;
        padding-right: 0.55rem;
    }

    .kixie-int-crm-activities {
        padding-left: 0.55rem;
        padding-right: 0.55rem;
    }

    .kixie-int-dialer {
        position: relative;
        top: auto;
        right: auto;
        width: 100%;
        max-width: 13rem;
        margin: 0.75rem auto 0;
    }

    .kixie-int-benefits,
    .kixie-int-details,
    .kixie-int-testimonials,
    .kixie-int-platform {
        padding: 4.1rem 0;
    }

    .kixie-int-benefits-grid,
    .kixie-int-platform-grid {
        grid-template-columns: 1fr;
    }

    .kixie-int-testimonial-slide {
        padding: 1.35rem;
    }
}

/* Pricing page template */
.kixie-pricing-page-template {
    padding-top: 8.3rem;
    padding-bottom: 5rem;
    background: #fff;
}

.admin-bar .kixie-pricing-page-template {
    padding-top: calc(8.3rem + 32px);
}

.kixie-pricing-wrap {
    max-width: 1220px;
    margin: 0 auto;
    padding: 0 1rem;
}

.kixie-pricing-hero {
    max-width: 880px;
    margin: 0 auto;
    text-align: center;
    padding-bottom: 2rem;
}

.kixie-pricing-hero h1 {
    margin: 0;
    color: #1f1533;
    font-size: clamp(2.2rem, 4.9vw, 3.45rem);
    line-height: 1.08;
    letter-spacing: -0.02em;
}

.kixie-pricing-hero p {
    margin: 1.2rem auto 0;
    max-width: 840px;
    color: #6a5f82;
    font-size: clamp(1.05rem, 1.7vw, 1.25rem);
    line-height: 1.55;
}

.kixie-pricing-hero p a {
    color: #612dd5;
    text-decoration: underline;
}

.kixie-pricing-hero-note {
    margin: 2rem auto 0;
    max-width: 980px;
    border: 1px solid #e5dff3;
    border-radius: 1.15rem;
    background: #f7f4fd;
    padding: 1.2rem 1.4rem;
    color: #2f2546;
    line-height: 1.6;
}

.kixie-pricing-plans {
    padding: 1rem 0 2rem;
}

.kixie-pricing-plans-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1.35rem;
}

.kixie-pricing-plan {
    position: relative;
    border: 2px solid #e5dfef;
    border-radius: 1.25rem;
    background: #fff;
    box-shadow: 0 16px 32px -28px rgba(32, 18, 57, 0.5);
    padding: 1.3rem 1.25rem 1.2rem;
    display: flex;
    flex-direction: column;
    transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
}

.kixie-pricing-plan:hover {
    transform: translateY(-3px);
    border-color: #cabef1;
    box-shadow: 0 20px 42px -30px rgba(44, 29, 82, 0.55);
}

.kixie-pricing-plan.is-popular {
    border-color: #7446d9;
}

.kixie-pricing-badge {
    position: absolute;
    top: -0.72rem;
    left: 50%;
    transform: translateX(-50%);
    background: linear-gradient(90deg, #5f2dcf 0%, #7a2fcd 45%, #d038a4 100%);
    color: #fff;
    border-radius: 999px;
    padding: 0.28rem 0.8rem;
    font-size: 0.68rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    font-weight: 700;
    white-space: nowrap;
}

.kixie-pricing-plan-head {
    text-align: center;
    border-bottom: 1px solid #ece7f4;
    padding-bottom: 1rem;
    margin-bottom: 0.95rem;
}

.kixie-pricing-plan-head h3 {
    margin: 0;
    color: #201535;
    font-size: 1.2rem;
    line-height: 1.25;
}

.kixie-pricing-plan-head p {
    margin: 0.45rem 0 0;
    color: #6f6586;
    font-size: 0.92rem;
    line-height: 1.4;
}

.kixie-pricing-plan-features {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 0.58rem;
    min-height: 14.5rem;
}

.kixie-pricing-plan-features li {
    display: flex;
    align-items: flex-start;
    gap: 0.55rem;
    color: #2f2546;
    font-size: 0.92rem;
    line-height: 1.35;
}

.kixie-pricing-check {
    width: 1.1rem;
    height: 1.1rem;
    border-radius: 999px;
    background: #e6fbef;
    color: #159647;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 0.76rem;
    flex: 0 0 1.1rem;
    margin-top: 0.08rem;
}

.kixie-pricing-plan-features small {
    display: block;
    margin-top: 0.2rem;
    color: #7a7191;
    font-size: 0.76rem;
}

.kixie-pricing-plan-minutes {
    border-radius: 0.85rem;
    background: #f5f2fc;
    margin-top: 1rem;
    padding: 0.75rem 0.75rem;
    text-align: center;
}

.kixie-pricing-plan-minutes strong {
    color: #1f1533;
    font-size: 0.9rem;
    line-height: 1.2;
}

.kixie-pricing-plan-minutes span {
    display: block;
    margin-top: 0.2rem;
    color: #716887;
    font-size: 0.78rem;
    line-height: 1.3;
}

.kixie-pricing-plan-cta {
    margin-top: 0.95rem;
    border-radius: 999px;
    min-height: 2.75rem;
    padding: 0.55rem 0.95rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.35rem;
    text-decoration: none;
    font-weight: 700;
    letter-spacing: 0.02em;
    text-transform: uppercase;
    color: #fff;
    background: #23183a;
    transition: filter 0.2s ease, transform 0.2s ease;
}

.kixie-pricing-plan.is-popular .kixie-pricing-plan-cta {
    background: linear-gradient(90deg, #5f2dcf 0%, #7a2fcd 45%, #d038a4 100%);
}

.kixie-pricing-plan-cta:hover,
.kixie-pricing-plan-cta:focus {
    transform: translateY(-1px);
    filter: brightness(1.02);
}

.kixie-pricing-addons {
    margin-top: 1rem;
    padding: 4.4rem 0;
    background: linear-gradient(130deg, #f7f4fe 0%, #ffffff 45%, #f1eefb 100%);
}

.kixie-pricing-section-head {
    text-align: center;
    margin: 0 auto 1.7rem;
    max-width: 760px;
}

.kixie-pricing-section-head h2 {
    margin: 0;
    color: #201535;
    font-size: clamp(1.9rem, 3.2vw, 2.8rem);
    line-height: 1.15;
    letter-spacing: -0.02em;
}

.kixie-pricing-section-head p {
    margin: 0.75rem 0 0;
    color: #6d6481;
    font-size: 1.07rem;
    line-height: 1.45;
}

.kixie-pricing-addons-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1.35rem;
}

.kixie-pricing-addon {
    border: 1px solid #e6e0ef;
    border-radius: 1.15rem;
    background: #fff;
    box-shadow: 0 18px 34px -30px rgba(36, 23, 66, 0.55);
    padding: 1.25rem;
    text-decoration: none;
    transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
}

.kixie-pricing-addon:hover,
.kixie-pricing-addon:focus {
    transform: translateY(-3px);
    border-color: #cfc2f2;
    box-shadow: 0 22px 40px -30px rgba(52, 35, 90, 0.6);
}

.kixie-pricing-addon-icon {
    width: 3rem;
    height: 3rem;
    border-radius: 0.8rem;
    background: linear-gradient(130deg, #f10606 0%, #7a2fcd 90%);
    color: #fff;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 1.3rem;
}

.kixie-pricing-addon h3 {
    margin: 0.9rem 0 0;
    color: #1f1533;
    font-size: 1.18rem;
    line-height: 1.3;
}

.kixie-pricing-addon p {
    margin: 0.5rem 0 0;
    color: #6f6586;
    font-size: 0.95rem;
    line-height: 1.45;
}

.kixie-pricing-addon-badge {
    margin-top: 0.9rem;
    display: inline-flex;
    align-items: center;
    gap: 0.28rem;
    color: #612dd5;
    font-size: 0.9rem;
    font-weight: 600;
}

.kixie-pricing-compare {
    padding: 4.4rem 0 0;
    background: #fff;
}

.kixie-pricing-table-wrap {
    overflow-x: auto;
    border: 1px solid #e8e2f2;
    border-radius: 0.95rem;
}

.kixie-pricing-table {
    width: 100%;
    min-width: 860px;
    border-collapse: collapse;
    background: #fff;
}

.kixie-pricing-table th,
.kixie-pricing-table td {
    border-bottom: 1px solid #ece6f4;
    padding: 0.8rem 0.8rem;
    font-size: 0.92rem;
    line-height: 1.35;
}

.kixie-pricing-table thead th {
    color: #2a1d44;
    font-weight: 700;
    background: #f8f5fc;
}

.kixie-pricing-table th:first-child,
.kixie-pricing-table td:first-child {
    text-align: left;
}

.kixie-pricing-table th:not(:first-child),
.kixie-pricing-table td:not(:first-child) {
    text-align: center;
}

.kixie-pricing-group-row td {
    background: #f3effb;
    color: #2a1d44;
    font-weight: 700;
    text-transform: none;
}

.kixie-pricing-cell-icon {
    width: 1.2rem;
    height: 1.2rem;
    border-radius: 999px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 0.85rem;
    font-weight: 700;
}

.kixie-pricing-cell-icon.is-yes {
    color: #159647;
    background: #e6fbef;
}

.kixie-pricing-cell-icon.is-no {
    color: #837897;
    background: #f0edf6;
}

.kixie-pricing-cell-text {
    color: #2f2546;
    font-weight: 600;
}

.kixie-pricing-cta {
    padding: 4.4rem 0 0;
}

.kixie-pricing-cta-panel {
    border-radius: 1.4rem;
    background: linear-gradient(90deg, #551fbf 0%, #732cc9 52%, #b533b3 100%);
    padding: 3rem 1.2rem;
    text-align: center;
}

.kixie-pricing-cta-panel h2 {
    margin: 0;
    color: #fff;
    font-size: clamp(2rem, 3.8vw, 3.1rem);
    line-height: 1.1;
    letter-spacing: -0.02em;
}

.kixie-pricing-cta-panel p {
    margin: 0.95rem auto 0;
    color: rgba(255, 255, 255, 0.82);
    font-size: clamp(1rem, 1.8vw, 1.18rem);
    line-height: 1.45;
    max-width: 800px;
}

.kixie-pricing-cta-btn {
    margin-top: 1.35rem;
    border-radius: 999px;
    min-height: 3.05rem;
    padding: 0.62rem 1.5rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.35rem;
    background: #fff;
    color: #1f1533;
    text-decoration: none;
    font-weight: 700;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.kixie-pricing-cta-btn:hover,
.kixie-pricing-cta-btn:focus {
    transform: translateY(-1px);
    box-shadow: 0 12px 26px -18px rgba(0, 0, 0, 0.45);
}

@media (max-width: 1080px) {
    .kixie-pricing-plans-grid,
    .kixie-pricing-addons-grid {
        grid-template-columns: 1fr;
        max-width: 640px;
        margin: 0 auto;
    }
}

@media (max-width: 782px) {
    .kixie-pricing-page-template {
        padding-top: 9.2rem;
        padding-bottom: 3.4rem;
    }

    .admin-bar .kixie-pricing-page-template {
        padding-top: calc(9.2rem + 46px);
    }

    .kixie-pricing-hero-note {
        padding: 1rem 1rem;
    }

    .kixie-pricing-addons,
    .kixie-pricing-compare,
    .kixie-pricing-cta {
        padding-top: 3.2rem;
    }
}

/* Reusable integrations marquee fallback styles
   Keeps the section usable outside feature/integration landing wrappers. */
.integrations {
    padding: 96px 0;
    background: #f7f6fb;
}

.integrations .section-header {
    text-align: center;
    max-width: 840px;
    margin: 0 auto 40px;
}

.integrations .section-title {
    margin: 0 0 12px;
    font-size: clamp(36px, 4vw, 56px);
    line-height: 1.05;
    font-weight: 700;
    color: #231942;
}

.integrations .section-subtitle {
    margin: 0;
    color: #6f6884;
    font-size: 20px;
    line-height: 1.5;
}

.integrations .integrations-scroll {
    position: relative;
    overflow: hidden;
    margin-bottom: 20px;
}

.integrations .integrations-scroll::before,
.integrations .integrations-scroll::after {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    width: 72px;
    z-index: 3;
    pointer-events: none;
}

.integrations .integrations-scroll::before {
    left: 0;
    background: linear-gradient(to right, #f7f6fb, rgba(247, 246, 251, 0));
}

.integrations .integrations-scroll::after {
    right: 0;
    background: linear-gradient(to left, #f7f6fb, rgba(247, 246, 251, 0));
}

.integrations .integrations-track {
    display: flex;
    gap: 14px;
    width: max-content;
    will-change: transform;
}

.integrations .integrations-track.forward {
    animation: kixie-integrations-forward 36s linear infinite;
}

.integrations .integrations-track.reverse {
    animation: kixie-integrations-reverse 42s linear infinite;
}

.integrations .integrations-track:hover {
    animation-play-state: paused;
}

.integrations .integration-item {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    min-height: 56px;
    padding: 10px 16px;
    border: 1px solid #e0dbea;
    border-radius: 14px;
    background: #fff;
    color: #20183f;
}

.integrations .integration-logo {
    width: 34px;
    height: 34px;
    border-radius: 8px;
    overflow: hidden;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: #5135a8;
    font-weight: 700;
    font-size: 13px;
}

.integrations .integration-logo img {
    width: auto;
    height: auto;
    max-width: 100%;
    max-height: 30px;
    object-fit: contain;
    display: block;
}

.integrations .integration-name {
    white-space: nowrap;
    font-weight: 700;
    color: #20183f;
    font-size: 16px;
}

.integrations .integrations-cta {
    margin-top: 30px;
    text-align: center;
}

.integrations .integrations-cta .btn.btn-outline {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    border: 1px solid #d4cee3;
    border-radius: 999px;
    padding: 12px 26px;
    text-decoration: none;
    color: #20183f;
    background: #fff;
    font-weight: 700;
}

.integrations .integrations-cta .btn.btn-outline:hover {
    border-color: #bfb2db;
    color: #20183f;
}

@keyframes kixie-integrations-forward {
    0% {
        transform: translateX(0);
    }

    100% {
        transform: translateX(-50%);
    }
}

@keyframes kixie-integrations-reverse {
    0% {
        transform: translateX(-50%);
    }

    100% {
        transform: translateX(0);
    }
}

@media (max-width: 768px) {
    .integrations {
        padding: 72px 0;
    }

    .integrations .section-subtitle {
        font-size: 18px;
    }
}

/* Brand page */
.kixie-brand-page {
    padding-top: 7.5rem;
    padding-bottom: 5rem;
    background: #f7f7fa;
    color: #2a2243;
}

.admin-bar .kixie-brand-page {
    padding-top: calc(7.5rem + 32px);
}

.kixie-brand-container {
    max-width: 1120px;
}

.kixie-brand-hero {
    border-top: 1px solid #ebe9f2;
    border-bottom: 1px solid #ebe9f2;
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
}

.kixie-brand-hero-inner {
    margin: 0 auto;
    max-width: 860px;
    text-align: center;
    padding: 6rem 0 6.5rem;
}

.kixie-brand-hero-inner h1 {
    margin: 0 0 1rem;
    font-size: clamp(2.1rem, 4vw, 3.25rem);
    line-height: 1.12;
    letter-spacing: -0.03em;
    color: #1f1533;
}

.kixie-brand-hero-inner p {
    margin: 0;
    font-size: 1.03rem;
    line-height: 1.65;
    color: #5f5872;
}

.kixie-brand-section {
    padding: 3.75rem 0 0;
}

.kixie-brand-section h2 {
    margin: 0 0 1.65rem;
    font-size: clamp(1.85rem, 2.8vw, 2.6rem);
    line-height: 1.16;
    letter-spacing: -0.03em;
    color: #1f1533;
}

.kixie-brand-accordion {
    display: grid;
    gap: 0.7rem;
}

.kixie-brand-accordion-item {
    border: 1px solid #e6e3ef;
    background: #fff;
    border-radius: 0.55rem;
    overflow: hidden;
}

.kixie-brand-accordion-item summary {
    position: relative;
    list-style: none;
    cursor: pointer;
    padding: 1rem 2.8rem 1rem 1.1rem;
    color: #423a56;
    font-size: 1rem;
    font-weight: 600;
}

.kixie-brand-accordion-item summary::-webkit-details-marker {
    display: none;
}

.kixie-brand-accordion-item summary::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 1rem;
    width: 0.55rem;
    height: 0.55rem;
    border-right: 2px solid #7e78a3;
    border-bottom: 2px solid #7e78a3;
    transform: translateY(-62%) rotate(45deg);
    transition: transform 0.16s ease;
}

.kixie-brand-accordion-item[open] summary::after {
    transform: translateY(-28%) rotate(-135deg);
}

.kixie-brand-accordion-content {
    border-top: 1px solid #eeecf4;
    padding: 1.1rem 1.1rem 1.15rem;
}

.kixie-brand-accordion-content p {
    margin: 0;
    color: #554f66;
    line-height: 1.62;
}

.kixie-brand-accordion-content p + p {
    margin-top: 0.72rem;
}

.kixie-brand-logo-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 2.5rem;
    align-items: center;
}

.kixie-brand-copy p {
    margin: 0 0 1.15rem;
    color: #554f66;
    line-height: 1.62;
}

.kixie-brand-copy p em {
    font-style: italic;
}

.kixie-brand-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.35rem;
    margin-top: 0.2rem;
    min-height: 2.5rem;
    padding: 0.5rem 1.05rem;
    border-radius: 999px;
    border: 1px solid #d8d2e6;
    background: #fff;
    color: #1f1533;
    font-size: 0.86rem;
    font-weight: 700;
    letter-spacing: 0.03em;
    text-transform: uppercase;
    text-decoration: none;
    transition: border-color 0.15s ease, background-color 0.15s ease;
}

.kixie-brand-button:hover,
.kixie-brand-button:focus {
    border-color: #bfb5d8;
    background: #faf8ff;
    color: #1f1533;
}

.kixie-brand-logo-images img {
    display: block;
    width: 100%;
    height: auto;
}

.kixie-brand-logo-images img + img {
    margin-top: 1.35rem;
}

.kixie-brand-cards-section {
    padding-top: 3rem;
}

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

.kixie-brand-card {
    background: #fff;
    border: 1px solid #e6e3ef;
    border-radius: 0.8rem;
    padding: 1.4rem;
    box-shadow: 0 12px 28px rgba(31, 21, 51, 0.06);
}

.kixie-brand-card h3 {
    margin: 0 0 0.7rem;
    font-size: 1.45rem;
    line-height: 1.2;
    letter-spacing: -0.02em;
    color: #1f1533;
}

.kixie-brand-card p {
    margin: 0;
    color: #554f66;
    line-height: 1.62;
}

.kixie-brand-swatch {
    display: block;
    width: 2rem;
    height: 2rem;
    border-top-left-radius: 0.68rem;
    border-top-right-radius: 0.68rem;
    border-bottom-right-radius: 0.68rem;
    margin-bottom: 1rem;
}

.kixie-brand-swatch-red {
    background: #f10606;
}

.kixie-brand-swatch-blue {
    background: #0098c7;
}

.kixie-brand-assets-section {
    padding-top: 3.8rem;
}

.kixie-brand-assets-section p {
    margin: 0 0 1.6rem;
    color: #554f66;
    line-height: 1.62;
}

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

.kixie-brand-assets-grid img {
    display: block;
    width: 100%;
    height: auto;
}

@media (max-width: 1023px) {
    .kixie-brand-page {
        padding-bottom: 4.2rem;
    }

    .kixie-brand-logo-grid {
        grid-template-columns: 1fr;
        gap: 1.75rem;
    }

    .kixie-brand-cards-grid,
    .kixie-brand-assets-grid {
        grid-template-columns: 1fr 1fr;
    }
}

@media (max-width: 782px) {
    .kixie-brand-page {
        padding-top: 8.5rem;
    }

    .admin-bar .kixie-brand-page {
        padding-top: calc(8.5rem + 46px);
    }

    .kixie-brand-hero-inner {
        padding: 4.2rem 0;
    }

    .kixie-brand-section {
        padding-top: 2.8rem;
    }

    .kixie-brand-accordion-item summary {
        padding-left: 0.95rem;
    }

    .kixie-brand-cards-grid,
    .kixie-brand-assets-grid {
        grid-template-columns: 1fr;
    }
}

/* Feature detail mobile hero top-offset override (must beat inline head fix). */
@media (max-width: 1023px) {
    body.page-template-template-feature-page .kixie-feature-power-dialer .hero {
        padding-top: 10.8rem !important;
    }
}

@media (max-width: 767px) {
    body.page-template-template-feature-page .kixie-feature-power-dialer .hero {
        padding-top: 11.6rem !important;
    }
}
