/*
Theme Name: eMarketingExpert-Theme01
Theme URI: https://emarketingexperts.net/
Author: eMarketingExperts
Author URI: https://emarketingexperts.net/
Description: Custom WordPress theme for eMarketingExperts with dropdown navigation, dark mode, animations, and a clean agency-style layout.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.9
Requires PHP: 7.4
Text Domain: emarketingexperts-theme
*/

:root {
    --eme-primary: #0B4EA2;
    --eme-accent: #6B7280;
    --eme-text: #111827;
    --eme-text-soft: #6B7280;
    --eme-bg: #F7F7F8;
    --eme-surface: #FFFFFF;
    --eme-surface-2: #EEF2F7;
    --eme-border: rgba(17, 24, 39, 0.08);
    --eme-shadow: 0 16px 40px rgba(11, 78, 162, 0.10);
    --eme-radius: 14px;
    --eme-radius-lg: 24px;
    --eme-container: 1280px;
    --eme-transition: 220ms ease;
    --eme-header-height: 86px;
}

html[data-theme="dark"] {
    --eme-primary: #6AA8FF;
    --eme-accent: #AAB4C3;
    --eme-text: #F5F7FA;
    --eme-text-soft: #AAB4C3;
    --eme-bg: #0B1220;
    --eme-surface: #121B2B;
    --eme-surface-2: #172235;
    --eme-border: rgba(255, 255, 255, 0.08);
    --eme-shadow: 0 18px 44px rgba(0, 0, 0, 0.32);
}

*,
*::before,
*::after {
    box-sizing: border-box;
}

html {
    scroll-behavior: smooth;
}

body {
    margin: 0;
    color: var(--eme-text);
    background: var(--eme-bg);
    font-family: "DM Sans", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    line-height: 1.6;
    text-rendering: optimizeLegibility;
}

body.menu-open {
    overflow: hidden;
}

img {
    display: block;
    max-width: 100%;
    height: auto;
}

a {
    color: inherit;
    text-decoration: none;
}

button,
input,
textarea,
select {
    font: inherit;
}

p {
    margin: 0 0 1rem;
}

h1,
h2,
h3,
h4,
h5,
h6 {
    margin: 0 0 1rem;
    line-height: 1.1;
    letter-spacing: -0.03em;
}

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

.container {
    width: min(calc(100% - 40px), var(--eme-container));
    margin-inline: auto;
}

.skip-link {
    position: absolute;
    left: -9999px;
    top: 0;
    z-index: 9999;
    background: var(--eme-primary);
    color: #fff;
    padding: 12px 16px;
}

.skip-link:focus {
    left: 16px;
    top: 16px;
}

.site-header {
    position: sticky;
    top: 0;
    z-index: 1000;
    backdrop-filter: blur(16px);
    background: color-mix(in srgb, var(--eme-bg) 88%, transparent);
    border-bottom: 1px solid var(--eme-border);
}

.site-header__inner {
    min-height: var(--eme-header-height);
    display: grid;
    grid-template-columns: auto 1fr auto;
    gap: 20px;
    align-items: center;
}

.site-branding {
    display: flex;
    align-items: center;
    min-width: 0;
}

.site-branding img {
    width: auto;
    max-width: 320px;
    max-height: 60px;
}

.site-branding__text {
    font-size: 1.25rem;
    font-weight: 700;
}

.menu-toggle {
    display: none;
    width: 46px;
    height: 46px;
    border: 1px solid var(--eme-border);
    background: var(--eme-surface);
    color: var(--eme-text);
    border-radius: 12px;
    cursor: pointer;
}

.menu-toggle span,
.menu-toggle::before,
.menu-toggle::after {
    display: block;
    width: 20px;
    height: 2px;
    background: currentColor;
    margin-inline: auto;
    transition: transform var(--eme-transition), opacity var(--eme-transition);
    content: "";
}

.menu-toggle span {
    margin-block: 5px;
}

.menu-toggle[aria-expanded="true"] span {
    opacity: 0;
}

.menu-toggle[aria-expanded="true"]::before {
    transform: translateY(7px) rotate(45deg);
}

.menu-toggle[aria-expanded="true"]::after {
    transform: translateY(-7px) rotate(-45deg);
}

.primary-nav {
    justify-self: center;
}

.primary-nav .menu {
    display: flex;
    align-items: center;
    gap: 8px;
}

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

.primary-nav .menu > li > a {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    min-height: 44px;
    padding: 10px 14px;
    border-radius: 999px;
    font-weight: 600;
    color: var(--eme-text);
    transition: background var(--eme-transition), color var(--eme-transition);
}

.primary-nav .menu > li:hover > a,
.primary-nav .menu > li:focus-within > a,
.primary-nav .current-menu-item > a,
.primary-nav .current-menu-ancestor > a {
    background: color-mix(in srgb, var(--eme-primary) 10%, transparent);
    color: var(--eme-primary);
}

.primary-nav .menu-item-has-children > a::after {
    content: "▾";
    font-size: 0.85rem;
    line-height: 1;
}

.primary-nav .sub-menu {
    position: absolute;
    left: 0;
    top: calc(100% + 10px);
    min-width: 250px;
    padding: 10px;
    background: var(--eme-surface);
    border: 1px solid var(--eme-border);
    border-radius: 18px;
    box-shadow: var(--eme-shadow);
    opacity: 0;
    visibility: hidden;
    transform: translateY(8px);
    transition: opacity var(--eme-transition), visibility var(--eme-transition), transform var(--eme-transition);
}

.primary-nav .sub-menu li + li {
    margin-top: 4px;
}

.primary-nav .sub-menu a {
    display: block;
    padding: 12px 14px;
    border-radius: 12px;
    color: var(--eme-text);
    font-weight: 500;
}

.primary-nav .sub-menu a:hover,
.primary-nav .sub-menu a:focus {
    background: color-mix(in srgb, var(--eme-primary) 8%, transparent);
    color: var(--eme-primary);
}

.primary-nav li:hover > .sub-menu,
.primary-nav li:focus-within > .sub-menu {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}

.header-actions {
    display: flex;
    align-items: center;
    gap: 12px;
}

.theme-toggle {
    width: 46px;
    height: 46px;
    border-radius: 50%;
    border: 1px solid var(--eme-border);
    background: var(--eme-surface);
    color: var(--eme-text);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: transform var(--eme-transition), background var(--eme-transition);
}

.theme-toggle:hover {
    transform: translateY(-1px);
}

.theme-toggle__icon--moon {
    display: none;
}

html[data-theme="dark"] .theme-toggle__icon--sun {
    display: none;
}

html[data-theme="dark"] .theme-toggle__icon--moon {
    display: block;
}

.eme-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    min-height: 50px;
    padding: 12px 22px;
    border-radius: 999px;
    border: 1px solid transparent;
    background: linear-gradient(135deg, var(--eme-primary), color-mix(in srgb, var(--eme-primary) 60%, var(--eme-accent)));
    color: #fff;
    font-weight: 700;
    box-shadow: var(--eme-shadow);
    transition: transform var(--eme-transition), box-shadow var(--eme-transition), opacity var(--eme-transition);
}

.eme-button:hover,
.eme-button:focus {
    transform: translateY(-2px);
    opacity: 0.97;
}

.eme-button--ghost {
    background: transparent;
    color: var(--eme-text);
    border-color: var(--eme-border);
    box-shadow: none;
}

.hero {
    padding: 72px 0 48px;
}

.hero__grid {
    display: grid;
    grid-template-columns: 1.1fr 0.9fr;
    gap: 42px;
    align-items: center;
}

.badge {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 8px 14px;
    border-radius: 999px;
    background: color-mix(in srgb, var(--eme-accent) 10%, transparent);
    color: var(--eme-accent);
    font-size: 0.95rem;
    font-weight: 700;
    letter-spacing: 0.01em;
    margin-bottom: 20px;
}

.badge::before {
    content: "";
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: currentColor;
}

.hero h1 {
    font-size: clamp(2.8rem, 7vw, 5.8rem);
    max-width: 12ch;
    margin-bottom: 20px;
}

.hero__lede {
    font-size: 1.125rem;
    max-width: 58ch;
    color: var(--eme-text-soft);
    margin-bottom: 28px;
}

.hero__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 14px;
    margin-bottom: 30px;
}

.hero__definition {
    max-width: 520px;
    padding: 20px 22px;
    border-radius: 18px;
    background: var(--eme-surface);
    border: 1px solid var(--eme-border);
    box-shadow: var(--eme-shadow);
}

.hero__definition strong {
    color: var(--eme-primary);
}

.hero__visual {
    position: relative;
}

.hero__card {
    position: relative;
    padding: 24px;
    border-radius: 28px;
    background: linear-gradient(180deg, color-mix(in srgb, var(--eme-surface) 70%, transparent), var(--eme-surface));
    border: 1px solid var(--eme-border);
    box-shadow: var(--eme-shadow);
}

.hero__image {
    width: 100%;
    aspect-ratio: 0.95 / 1;
    object-fit: contain;
    border-radius: 18px;
    background: color-mix(in srgb, var(--eme-surface-2) 75%, transparent);
    padding: 20px;
}

.hero__metric {
    position: absolute;
    padding: 14px 16px;
    border-radius: 18px;
    background: var(--eme-surface);
    border: 1px solid var(--eme-border);
    box-shadow: var(--eme-shadow);
}

.hero__metric--one {
    top: 24px;
    right: -18px;
}

.hero__metric--two {
    left: -18px;
    bottom: 28px;
}

.hero__metric-label {
    font-size: 0.85rem;
    color: var(--eme-text-soft);
    margin-bottom: 4px;
}

.hero__metric-value {
    font-size: 1.25rem;
    font-weight: 700;
}

.section {
    padding: 88px 0;
}

.section--alt {
    background: color-mix(in srgb, var(--eme-surface) 55%, transparent);
}

.section-header {
    max-width: 760px;
    margin-bottom: 40px;
}

.section-header h2 {
    font-size: clamp(2rem, 5vw, 3.4rem);
    margin-bottom: 12px;
}

.section-header p {
    color: var(--eme-text-soft);
    font-size: 1.05rem;
}

.grid {
    display: grid;
    gap: 22px;
}

.grid--3 {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

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

.card {
    height: 100%;
    padding: 28px;
    border-radius: 22px;
    background: var(--eme-surface);
    border: 1px solid var(--eme-border);
    box-shadow: var(--eme-shadow);
    transition: transform var(--eme-transition), border-color var(--eme-transition);
}

.card:hover {
    transform: translateY(-4px);
    border-color: color-mix(in srgb, var(--eme-primary) 25%, var(--eme-border));
}

.card__eyebrow {
    display: inline-block;
    margin-bottom: 10px;
    color: var(--eme-accent);
    font-weight: 700;
    font-size: 0.95rem;
}

.card h3,
.card h4 {
    font-size: 1.35rem;
    margin-bottom: 10px;
}

.card p {
    color: var(--eme-text-soft);
}

.showcase {
    overflow: hidden;
    border-radius: 28px;
    background: linear-gradient(135deg, color-mix(in srgb, var(--eme-primary) 10%, transparent), color-mix(in srgb, var(--eme-accent) 8%, transparent));
    border: 1px solid var(--eme-border);
    box-shadow: var(--eme-shadow);
}

.showcase__inner {
    display: grid;
    grid-template-columns: 1.05fr 0.95fr;
    align-items: center;
    gap: 24px;
}

.showcase__content {
    padding: 40px;
}

.showcase__content p {
    color: var(--eme-text-soft);
}

.showcase__media {
    padding: 20px 20px 20px 0;
}

.showcase__media img {
    width: 100%;
    aspect-ratio: 1.4 / 1;
    object-fit: contain;
    border-radius: 22px;
    background: color-mix(in srgb, var(--eme-surface) 75%, transparent);
    padding: 16px;
}

.accordion {
    display: grid;
    gap: 16px;
}

.accordion__item {
    border: 1px solid var(--eme-border);
    border-radius: 20px;
    background: var(--eme-surface);
    box-shadow: var(--eme-shadow);
    overflow: clip;
}

.accordion__button {
    width: 100%;
    border: 0;
    background: transparent;
    color: var(--eme-text);
    text-align: left;
    padding: 22px 24px;
    display: flex;
    justify-content: space-between;
    gap: 16px;
    cursor: pointer;
}

.accordion__button h3 {
    margin: 0;
    font-size: 1.15rem;
}

.accordion__icon {
    font-size: 1.4rem;
    line-height: 1;
    color: var(--eme-primary);
}

.accordion__panel {
    padding: 0 24px 22px;
    color: var(--eme-text-soft);
}

.logos {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 18px;
}

.logo-chip {
    min-height: 92px;
    padding: 18px;
    display: grid;
    place-items: center;
    text-align: center;
    border-radius: 18px;
    background: var(--eme-surface);
    border: 1px solid var(--eme-border);
    box-shadow: var(--eme-shadow);
    font-weight: 700;
    color: var(--eme-text-soft);
}

.cta {
    padding: 42px;
    border-radius: 28px;
    background: linear-gradient(135deg, color-mix(in srgb, var(--eme-primary) 82%, #0A1A33), color-mix(in srgb, var(--eme-accent) 34%, #0A1A33));
    color: #fff;
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 20px;
    align-items: center;
    box-shadow: var(--eme-shadow);
}

.cta p {
    margin: 0;
    color: rgba(255, 255, 255, 0.82);
}

.site-footer {
    padding-top: 76px;
    border-top: 1px solid var(--eme-border);
}

.site-footer__grid {
    display: grid;
    grid-template-columns: 1.1fr 1fr 1fr;
    gap: 28px;
    padding-bottom: 34px;
}

.site-footer h3 {
    margin-bottom: 12px;
    font-size: 1.12rem;
}

.site-footer p,
.site-footer li,
.site-footer a {
    color: var(--eme-text-soft);
}

.site-footer a:hover {
    color: var(--eme-primary);
}

.site-footer__bottom {
    padding: 20px 0 34px;
    border-top: 1px solid var(--eme-border);
    display: flex;
    justify-content: space-between;
    gap: 16px;
    flex-wrap: wrap;
    color: var(--eme-text-soft);
}

.page-content-wrapper {
    padding: 72px 0;
}

.entry-content {
    max-width: 860px;
}

.reveal {
    opacity: 0;
    transform: translateY(24px);
    transition: opacity 600ms ease, transform 600ms ease;
}

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

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

    .reveal,
    .reveal.is-visible,
    .card,
    .eme-button,
    .theme-toggle {
        transition: none;
        transform: none;
        opacity: 1;
    }
}

@media (max-width: 1180px) {
    .site-header__inner {
        grid-template-columns: auto auto auto;
    }

    .menu-toggle {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        order: 3;
    }

    .header-actions {
        order: 2;
    }

    .primary-nav {
        position: fixed;
        inset: var(--eme-header-height) 0 auto 0;
        width: 100%;
        max-height: calc(100vh - var(--eme-header-height));
        overflow: auto;
        padding: 18px 20px 28px;
        background: color-mix(in srgb, var(--eme-bg) 98%, transparent);
        border-bottom: 1px solid var(--eme-border);
        opacity: 0;
        visibility: hidden;
        transform: translateY(-8px);
        transition: opacity var(--eme-transition), visibility var(--eme-transition), transform var(--eme-transition);
    }

    .primary-nav.is-open {
        opacity: 1;
        visibility: visible;
        transform: translateY(0);
    }

    .primary-nav .menu {
        flex-direction: column;
        align-items: stretch;
        gap: 6px;
    }

    .primary-nav .menu > li > a {
        width: 100%;
        justify-content: space-between;
        padding: 14px 16px;
        border-radius: 16px;
        background: var(--eme-surface);
        border: 1px solid var(--eme-border);
    }

    .primary-nav .sub-menu {
        position: static;
        min-width: 0;
        margin-top: 8px;
        padding: 8px;
        opacity: 1;
        visibility: visible;
        transform: none;
        display: none;
        box-shadow: none;
        background: color-mix(in srgb, var(--eme-surface) 80%, transparent);
    }

    .primary-nav .menu > li.is-open > .sub-menu {
        display: block;
    }

    .hero__grid,
    .grid--3,
    .grid--2,
    .showcase__inner,
    .logos,
    .site-footer__grid,
    .cta {
        grid-template-columns: 1fr;
    }

    .hero__metric--one,
    .hero__metric--two {
        position: static;
        margin-top: 14px;
    }

    .showcase__media {
        padding: 0 20px 20px;
    }

    .cta {
        padding: 30px;
    }
}

@media (max-width: 720px) {
    .site-branding img {
        max-width: 230px;
        max-height: 48px;
    }

    .header-actions .eme-button {
        display: none;
    }

    .hero {
        padding-top: 42px;
    }

    .hero h1 {
        max-width: none;
    }

    .section,
    .site-footer {
        padding-top: 64px;
    }

    .section {
        padding-bottom: 64px;
    }

    .card,
    .showcase__content,
    .cta {
        padding: 24px;
    }
}


.page-hero {
    padding: 74px 0 28px;
}

.page-hero__wrap {
    display: grid;
    gap: 20px;
    max-width: 860px;
}

.page-hero__eyebrow {
    color: var(--eme-accent);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    font-size: 0.92rem;
}

.page-hero__title {
    font-size: clamp(2.4rem, 5vw, 4.5rem);
    margin-bottom: 0;
}

.page-hero__text {
    color: var(--eme-text-soft);
    font-size: 1.08rem;
    max-width: 62ch;
}

.feature-list {
    display: grid;
    gap: 20px;
}

.case-study-list {
    display: grid;
    gap: 22px;
}

.case-study {
    padding: 30px;
    background: var(--eme-surface);
    border: 1px solid var(--eme-border);
    border-radius: 24px;
    box-shadow: var(--eme-shadow);
    transition: transform var(--eme-transition), border-color var(--eme-transition);
}

.case-study:hover {
    transform: translateY(-4px);
    border-color: color-mix(in srgb, var(--eme-primary) 25%, var(--eme-border));
}

.case-study__meta {
    color: var(--eme-accent);
    font-size: 0.95rem;
    font-weight: 700;
    margin-bottom: 10px;
}

.case-study p {
    color: var(--eme-text-soft);
}

.hero__card::before {
    content: "";
    position: absolute;
    inset: -1px;
    border-radius: 29px;
    padding: 1px;
    background: linear-gradient(135deg, color-mix(in srgb, var(--eme-primary) 28%, transparent), color-mix(in srgb, var(--eme-accent) 24%, transparent));
    -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
    -webkit-mask-composite: xor;
            mask-composite: exclude;
    pointer-events: none;
}

.card::after,
.logo-chip::after,
.case-study::after {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: inherit;
    pointer-events: none;
}

.card,
.logo-chip,
.case-study {
    position: relative;
    overflow: hidden;
}

.card::after,
.logo-chip::after,
.case-study::after {
    background: radial-gradient(circle at top right, color-mix(in srgb, var(--eme-primary) 12%, transparent), transparent 42%);
    opacity: 0;
    transition: opacity var(--eme-transition);
}

.card:hover::after,
.logo-chip:hover::after,
.case-study:hover::after {
    opacity: 1;
}

.primary-nav .menu > li > a,
.eme-button,
.theme-toggle,
.menu-toggle,
.logo-chip,
.card,
.case-study {
    will-change: transform;
}

@media (max-width: 720px) {
    .page-hero {
        padding-top: 48px;
    }

    .case-study,
    .hero__definition {
        padding: 22px;
    }
}


.primary-nav .menu > li {
    counter-increment: eme-menu;
}

.primary-nav .menu {
    counter-reset: eme-menu;
}

.primary-nav .menu > li > a {
    position: relative;
    padding-top: 24px;
}

.primary-nav .menu > li > a::before {
    content: counter(eme-menu, decimal-leading-zero);
    position: absolute;
    top: 4px;
    left: 14px;
    font-size: 0.72rem;
    line-height: 1;
    letter-spacing: 0.04em;
    color: var(--eme-text-soft);
    opacity: 0.8;
}

.primary-nav .menu > li:hover > a::before,
.primary-nav .menu > li:focus-within > a::before,
.primary-nav .current-menu-item > a::before,
.primary-nav .current-menu-ancestor > a::before {
    color: var(--eme-primary);
}

.primary-nav .sub-menu {
    min-width: 320px;
    padding: 14px;
    border-radius: 22px;
    background: color-mix(in srgb, var(--eme-surface) 95%, transparent);
}

.primary-nav .sub-menu li {
    position: relative;
}

.primary-nav .sub-menu li a {
    padding: 14px 16px;
    border-radius: 14px;
}

.primary-nav .sub-menu li a::after {
    content: "→";
    float: right;
    opacity: 0;
    transform: translateX(-6px);
    transition: opacity var(--eme-transition), transform var(--eme-transition);
}

.primary-nav .sub-menu li a:hover::after,
.primary-nav .sub-menu li a:focus::after {
    opacity: 1;
    transform: translateX(0);
}

.primary-nav .sub-menu::before {
    content: "";
    position: absolute;
    top: -8px;
    left: 28px;
    width: 16px;
    height: 16px;
    background: inherit;
    border-left: 1px solid var(--eme-border);
    border-top: 1px solid var(--eme-border);
    transform: rotate(45deg);
}

@media (max-width: 1180px) {
    .primary-nav .menu > li > a {
        padding-top: 14px;
    }

    .primary-nav .menu > li > a::before {
        position: static;
        content: none;
    }

    .primary-nav .sub-menu::before {
        display: none;
    }
}


.hero--split {
    padding: 34px 0 38px;
}

.hero__headline {
    max-width: 740px;
    margin-bottom: 36px;
}

.hero__headline .badge {
    margin-bottom: 14px;
}

.hero-split {
    display: grid;
    grid-template-columns: minmax(0, 1.25fr) minmax(420px, 0.75fr);
    align-items: end;
    gap: 0;
}

.hero-split__media {
    min-height: 520px;
    display: flex;
    align-items: stretch;
}

.hero-split__image-wrap {
    width: 100%;
    min-height: 100%;
    background: linear-gradient(180deg, color-mix(in srgb, var(--eme-surface-2) 72%, transparent), color-mix(in srgb, var(--eme-surface) 90%, transparent));
    border-radius: 0 0 0 28px;
    border: 1px solid var(--eme-border);
    box-shadow: var(--eme-shadow);
    padding: 34px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.hero-split__image {
    width: 100%;
    max-width: 520px;
    max-height: 420px;
    object-fit: contain;
}

.hero-split__content {
    margin-left: -28px;
    z-index: 2;
}

.hero-split__panel {
    padding: 42px;
    background: color-mix(in srgb, var(--eme-surface) 94%, transparent);
    border: 1px solid var(--eme-border);
    box-shadow: var(--eme-shadow);
    min-height: 610px;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.hero-split__panel h2 {
    font-size: clamp(2rem, 3.5vw, 3.6rem);
    margin-bottom: 22px;
    max-width: 12ch;
}

.utility-rail {
    position: fixed;
    left: 18px;
    top: 50%;
    transform: translateY(-50%);
    z-index: 990;
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.utility-rail__item {
    writing-mode: vertical-rl;
    transform: rotate(180deg);
    border-radius: 999px;
    border: 1px solid var(--eme-border);
    background: var(--eme-surface);
    color: var(--eme-text);
    box-shadow: var(--eme-shadow);
    padding: 14px 10px;
    min-height: 124px;
    text-align: center;
    font-weight: 700;
}

.utility-rail__switch {
    min-height: 88px;
}

.utility-rail__scroll {
    letter-spacing: 0.02em;
}

@media (max-width: 1320px) {
    .utility-rail {
        display: none;
    }
}

@media (max-width: 1180px) {
    .hero-split {
        grid-template-columns: 1fr;
        gap: 22px;
    }

    .hero-split__content {
        margin-left: 0;
    }

    .hero-split__panel,
    .hero-split__image-wrap {
        min-height: auto;
        border-radius: 24px;
    }
}


/* v5 hero refinement */

.hero--reference {
    padding: 48px 0 36px;
    position: relative;
}

.hero-reference {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(520px, 0.95fr);
    gap: 44px;
    align-items: center;
    min-height: 720px;
}

.hero-reference__left {
    max-width: 640px;
    padding-right: 20px;
}

.hero-reference__eyebrow {
    margin: 0 0 18px;
    font-size: 1.05rem;
    font-weight: 700;
    color: var(--eme-text);
    max-width: 18ch;
}

.hero-reference__left h1 {
    font-size: clamp(4.3rem, 8vw, 7.2rem);
    line-height: 0.93;
    letter-spacing: -0.065em;
    margin: 0 0 22px;
    max-width: 8ch;
    color: #0B132B;
}

html[data-theme="dark"] .hero-reference__left h1 {
    color: var(--eme-text);
}

.hero-reference__links {
    margin-bottom: 28px;
}

.hero-reference__text-link {
    font-size: 1rem;
    font-weight: 700;
    color: var(--eme-text);
    border-bottom: 1px solid transparent;
}

.hero-reference__text-link:hover,
.hero-reference__text-link:focus {
    color: var(--eme-primary);
    border-color: currentColor;
}

.hero-reference__right {
    display: flex;
    justify-content: flex-end;
}

.hero-reference__visual-card {
    width: 100%;
    max-width: 760px;
    min-height: 640px;
    padding: 44px 34px 34px;
    background: color-mix(in srgb, var(--eme-surface) 92%, transparent);
    border: 1px solid var(--eme-border);
    box-shadow: var(--eme-shadow);
    display: grid;
    align-content: space-between;
}

.hero-reference__visual {
    position: relative;
    width: 100%;
    min-height: 470px;
    overflow: hidden;
    isolation: isolate;
}

.hero-blob {
    position: absolute;
    border-radius: 42% 58% 54% 46% / 44% 34% 66% 56%;
    filter: blur(8px);
    opacity: 0.92;
    mix-blend-mode: multiply;
    animation: floatBlob 12s ease-in-out infinite;
}

.hero-blob--one {
    width: 420px;
    height: 470px;
    top: 0;
    right: 80px;
    background: radial-gradient(circle at 35% 30%, rgba(255, 245, 195, 0.9), rgba(241, 137, 198, 0.62) 70%, rgba(255,255,255,0) 100%);
}

.hero-blob--two {
    width: 360px;
    height: 360px;
    bottom: 20px;
    right: 200px;
    background: radial-gradient(circle at 30% 30%, rgba(200, 247, 228, 0.9), rgba(122, 202, 255, 0.62) 72%, rgba(255,255,255,0) 100%);
    animation-delay: -2s;
}

.hero-blob--three {
    width: 390px;
    height: 420px;
    bottom: 0;
    right: 70px;
    background: radial-gradient(circle at 40% 40%, rgba(255, 224, 176, 0.82), rgba(252, 117, 177, 0.65) 76%, rgba(255,255,255,0) 100%);
    animation-delay: -4s;
}

.hero-blob--four {
    width: 300px;
    height: 330px;
    bottom: 0;
    right: 220px;
    background: radial-gradient(circle at 35% 30%, rgba(174, 217, 255, 0.9), rgba(136, 173, 255, 0.58) 70%, rgba(255,255,255,0) 100%);
    animation-delay: -6s;
}

@keyframes floatBlob {
    0%, 100% { transform: translate3d(0, 0, 0) rotate(0deg) scale(1); }
    50% { transform: translate3d(10px, -14px, 0) rotate(4deg) scale(1.03); }
}

.hero-reference__definition {
    max-width: 620px;
    padding-top: 12px;
}

.hero-reference__definition-label {
    margin: 0 0 12px;
    font-size: 1rem;
    color: var(--eme-text);
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
    align-items: baseline;
}

.hero-reference__definition-label em {
    font-style: italic;
    font-weight: 600;
}

.hero-reference__definition-text {
    margin: 0;
    font-size: 1.1rem;
    line-height: 1.35;
    font-weight: 800;
    color: #0B132B;
    max-width: 28ch;
}

html[data-theme="dark"] .hero-reference__definition-text {
    color: var(--eme-text);
}

.site-header {
    background: color-mix(in srgb, var(--eme-bg) 96%, transparent);
}

.site-header__inner {
    grid-template-columns: auto 1fr auto;
}

.site-branding img {
    max-width: 250px;
    max-height: 52px;
}

.primary-nav {
    justify-self: end;
}

.primary-nav .menu {
    gap: 14px;
}

.primary-nav .menu > li > a {
    background: transparent !important;
    border-radius: 0;
    padding: 20px 2px 8px;
    min-height: auto;
    font-weight: 700;
}

.primary-nav .menu > li > a::before {
    left: 0;
    top: 0;
}

.primary-nav .menu > li:hover > a,
.primary-nav .menu > li:focus-within > a,
.primary-nav .current-menu-item > a,
.primary-nav .current-menu-ancestor > a {
    color: var(--eme-primary);
}

.primary-nav .sub-menu {
    top: calc(100% + 14px);
}

.utility-rail__scroll {
    opacity: 0.9;
}

@media (max-width: 1360px) {
    .hero-reference {
        grid-template-columns: minmax(0, 1fr) minmax(440px, 0.9fr);
        gap: 28px;
    }

    .hero-reference__visual-card {
        min-height: 560px;
    }

    .hero-reference__visual {
        min-height: 400px;
    }

    .hero-reference__left h1 {
        font-size: clamp(3.6rem, 7vw, 6rem);
    }
}

@media (max-width: 1180px) {
    .hero-reference {
        grid-template-columns: 1fr;
        min-height: auto;
        gap: 28px;
    }

    .hero-reference__right {
        justify-content: stretch;
    }

    .hero-reference__visual-card {
        max-width: none;
        min-height: auto;
        padding: 28px;
    }

    .hero-reference__visual {
        min-height: 360px;
    }

    .hero-reference__left {
        max-width: none;
    }

    .hero-reference__left h1 {
        max-width: 9ch;
    }
}

@media (max-width: 720px) {
    .hero--reference {
        padding-top: 28px;
    }

    .hero-reference__left h1 {
        max-width: none;
        font-size: clamp(3rem, 14vw, 4.6rem);
    }

    .hero-reference__visual {
        min-height: 280px;
    }

    .hero-blob--one {
        width: 250px;
        height: 280px;
        right: 20px;
    }

    .hero-blob--two {
        width: 220px;
        height: 220px;
        right: 120px;
        bottom: 10px;
    }

    .hero-blob--three {
        width: 260px;
        height: 270px;
        right: 20px;
    }

    .hero-blob--four {
        width: 180px;
        height: 190px;
        right: 130px;
    }
}


/* v6 layout refinements */
:root { --eme-primary-hover: #d90a2c; }
.site-header { background: color-mix(in srgb, var(--eme-bg) 96%, transparent); }
.site-header__inner { min-height: 82px; }
.site-branding img { max-width: 240px; max-height: 48px; }
.primary-nav { justify-self: end; }
.primary-nav .menu { gap: 16px; }
.primary-nav .menu > li > a { background: transparent !important; border-radius: 0; min-height: auto; padding: 22px 2px 8px; font-weight: 700; }
.primary-nav .menu > li > a::before { left: 0; top: 0; }
.primary-nav .menu > li:hover > a, .primary-nav .menu > li:focus-within > a, .primary-nav .current-menu-item > a, .primary-nav .current-menu-ancestor > a { color: var(--eme-primary-hover); }
.primary-nav .menu > li:hover > a::before, .primary-nav .menu > li:focus-within > a::before, .primary-nav .current-menu-item > a::before, .primary-nav .current-menu-ancestor > a::before { color: var(--eme-primary-hover); }
.primary-nav .sub-menu a:hover, .primary-nav .sub-menu a:focus { color: var(--eme-primary-hover); background: color-mix(in srgb, var(--eme-primary-hover) 8%, transparent); }
.hero--reference { padding: 42px 0 28px; }
.hero-reference { display: grid; grid-template-columns: minmax(0, 1fr) minmax(520px, 0.92fr); gap: 44px; align-items: center; min-height: 680px; }
.hero-reference__left { max-width: 650px; }
.hero-reference__eyebrow { margin: 0 0 18px; font-size: 1rem; font-weight: 700; max-width: 16ch; color: var(--eme-text); }
.hero-reference__left h1 { margin: 0 0 24px; max-width: 8ch; font-size: clamp(4rem, 7vw, 6.7rem); line-height: .93; letter-spacing: -.07em; color: #0f172a; }
html[data-theme="dark"] .hero-reference__left h1 { color: var(--eme-text); }
.hero-reference__links { margin-bottom: 26px; }
.hero-reference__text-link { font-size: 1rem; font-weight: 700; color: var(--eme-text); border-bottom: 1px solid transparent; }
.hero-reference__text-link:hover { color: var(--eme-primary-hover); border-color: currentColor; }
.hero-reference__right { display: flex; justify-content: flex-end; }
.hero-reference__visual-card { width: 100%; max-width: 760px; padding: 0; background: transparent; border: 0; box-shadow: none; display: grid; gap: 22px; }
.hero-reference__visual { width: 100%; min-height: 520px; overflow: hidden; background: var(--eme-surface); border: 1px solid var(--eme-border); box-shadow: var(--eme-shadow); }
.hero-reference__photo { width: 100%; height: 100%; min-height: 520px; object-fit: cover; object-position: center; }
.hero-reference__definition { max-width: 580px; }
.hero-reference__definition-label { margin: 0 0 12px; font-size: 1rem; display: flex; gap: 10px; flex-wrap: wrap; color: var(--eme-text); }
.hero-reference__definition-text { margin: 0; max-width: 28ch; font-size: 1.1rem; line-height: 1.32; font-weight: 800; color: #0f172a; }
html[data-theme="dark"] .hero-reference__definition-text { color: var(--eme-text); }
.section-kicker { display: inline-block; margin-bottom: 12px; color: var(--eme-accent); font-size: .95rem; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; }
.services-split { padding-top: 76px; }
.services-split__grid { display: grid; grid-template-columns: minmax(0, .95fr) minmax(0, 1.05fr); gap: 52px; align-items: start; }
.services-split__intro h2 { font-size: clamp(2rem, 4vw, 3.4rem); margin-bottom: 14px; }
.services-split__intro p { color: var(--eme-text-soft); max-width: 54ch; }
.services-split__list { display: grid; gap: 0; border-top: 1px solid var(--eme-border); }
.service-line { padding: 26px 0; border-bottom: 1px solid var(--eme-border); }
.service-line__kicker { display: inline-block; margin-bottom: 8px; color: var(--eme-accent); font-weight: 700; font-size: .95rem; }
.service-line h3 { font-size: 1.45rem; margin-bottom: 10px; }
.service-line p { margin: 0; color: var(--eme-text-soft); max-width: 56ch; }
.social-rail { position: fixed; right: 18px; top: 50%; transform: translateY(-50%); z-index: 990; display: flex; flex-direction: column; gap: 14px; align-items: center; }
.social-rail__label { writing-mode: vertical-rl; transform: rotate(180deg); color: var(--eme-text-soft); font-size: .88rem; font-weight: 700; letter-spacing: .04em; }
.social-rail a { color: var(--eme-text); font-weight: 700; }
.social-rail a:hover { color: var(--eme-primary-hover); }
@media (max-width: 1320px) { .social-rail, .utility-rail { display: none; } }
@media (max-width: 1180px) { .hero-reference, .services-split__grid { grid-template-columns: 1fr; gap: 28px; } .hero-reference { min-height: auto; } .hero-reference__visual { min-height: 360px; } .hero-reference__photo { min-height: 360px; } }
@media (max-width: 720px) { .hero-reference__left h1 { max-width: none; font-size: clamp(3rem, 14vw, 4.8rem); } }


/* v7 homepage corrections */
.primary-nav .menu > li > a::before,
.page-hero__eyebrow,
.card__eyebrow,
.case-study__meta,
.service-line__kicker {
    color: var(--eme-text-soft) !important;
}

.primary-nav .menu > li:hover > a,
.primary-nav .menu > li:focus-within > a,
.primary-nav .current-menu-item > a,
.primary-nav .current-menu-ancestor > a,
.primary-nav .menu > li:hover > a::before,
.primary-nav .menu > li:focus-within > a::before,
.primary-nav .current-menu-item > a::before,
.primary-nav .current-menu-ancestor > a::before {
    color: #d90a2c !important;
}

.hero-reference {
    align-items: end;
    min-height: 620px;
}

.hero-reference__left,
.hero-reference__right {
    align-self: end;
}

.hero-reference__left {
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    padding-bottom: 26px;
}

.hero-reference__left h1 {
    max-width: 7.9ch;
    margin-bottom: 18px;
}

.hero-reference__visual-card {
    max-width: 620px;
    gap: 14px;
}

.hero-reference__visual {
    min-height: 420px;
    box-shadow: none;
    border: 0;
    background: transparent;
}

.hero-reference__photo {
    min-height: 420px;
    object-fit: contain;
    object-position: center bottom;
}

.hero-reference__definition {
    max-width: 470px;
}

.hero-reference__definition-text {
    max-width: 24ch;
}

.eme-button--hero {
    position: relative;
    background: linear-gradient(135deg, #c51d3f 0%, #ef2f54 60%, #ff4b69 100%);
    color: #fff;
    box-shadow: 0 16px 34px rgba(213, 23, 63, 0.22);
}

.eme-button--hero::after {
    content: "";
    position: absolute;
    inset: 1px;
    border-radius: inherit;
    background: linear-gradient(180deg, rgba(255,255,255,0.18), rgba(255,255,255,0));
    pointer-events: none;
}

.eme-button--hero:hover {
    transform: translateY(-3px);
    box-shadow: 0 20px 40px rgba(213, 23, 63, 0.28);
}

.social-rail {
    gap: 10px;
}

.social-rail__label {
    margin-bottom: 4px;
}

@media (max-width: 1180px) {
    .hero-reference {
        align-items: start;
        min-height: auto;
    }

    .hero-reference__left {
        padding-bottom: 0;
    }

    .hero-reference__visual-card {
        max-width: none;
    }

    .hero-reference__visual,
    .hero-reference__photo {
        min-height: 300px;
    }
}



/* v8 source-aligned corrections */
:root{
  --eme-primary:#d90a2c;
  --eme-accent:#6b7280;
  --eme-text:#111013;
  --eme-text-soft:#767a86;
  --eme-bg:#ffffff;
  --eme-surface:#ffffff;
  --eme-surface-2:#f5f6f8;
  --eme-border:rgba(17,16,19,.08);
  --eme-shadow:none;
  --eme-radius:8px;
  --eme-radius-lg:8px;
}
html[data-theme="dark"]{
  --eme-primary:#d90a2c;
  --eme-accent:#aab4c3;
}
body{background:var(--eme-bg);}
.site-header{position:relative;top:auto;background:transparent;border-bottom:0;backdrop-filter:none;}
.site-header__inner{min-height:80px;display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:24px;}
.site-branding img{max-width:210px;max-height:44px;}
.primary-nav{justify-self:end;}
.primary-nav .menu{gap:20px;}
.primary-nav .menu > li > a{
  min-height:auto;padding:18px 0 6px;background:transparent!important;border-radius:0;
  font-size:.98rem;font-weight:700;color:var(--eme-text);
}
.primary-nav .menu > li > a::before{
  color:var(--eme-text-soft)!important;
  font-size:.72rem;top:0;left:0;opacity:.8;
}
.primary-nav .menu > li:hover > a,
.primary-nav .menu > li:focus-within > a,
.primary-nav .current-menu-item > a,
.primary-nav .current-menu-ancestor > a,
.primary-nav .menu > li:hover > a::before,
.primary-nav .menu > li:focus-within > a::before,
.primary-nav .current-menu-item > a::before,
.primary-nav .current-menu-ancestor > a::before{color:var(--eme-primary)!important;}
.primary-nav .sub-menu{
  top:calc(100% + 12px);min-width:310px;padding:14px;border-radius:18px;background:var(--eme-surface);
  border:1px solid var(--eme-border);box-shadow:0 18px 40px rgba(17,16,19,.08);
}
.primary-nav .sub-menu::before{display:none;}
.primary-nav .sub-menu a{padding:12px 14px;border-radius:12px;}
.primary-nav .sub-menu a:hover{background:rgba(217,10,44,.06);}
.header-actions .eme-button{display:none;}
.header-actions{gap:12px}
.theme-toggle{border:0;background:transparent;padding:0 6px}
.menu-toggle{display:none;}

.utility-rail,.social-rail{
  position:fixed;top:50%;transform:translateY(-50%);z-index:25;display:flex;flex-direction:column;gap:12px;
}
.utility-rail{left:18px;}
.social-rail{right:18px;align-items:flex-end;}
.utility-rail__item{
  writing-mode:vertical-rl;transform:rotate(180deg);background:transparent;border:0;box-shadow:none;
  color:var(--eme-text);font-weight:700;min-height:auto;padding:0;
}
.utility-rail__scroll{opacity:.9;}
.social-rail__label{
  writing-mode:vertical-rl;transform:rotate(180deg);font-size:.82rem;color:var(--eme-text-soft);
  letter-spacing:.04em;font-weight:700;
}
.social-rail a{font-weight:700;color:var(--eme-text);}
.social-rail a:hover{color:var(--eme-primary);}

.hero--reference{padding:18px 0 12px;}
.hero-reference{
  display:grid;grid-template-columns:minmax(0,1fr) minmax(420px,520px);gap:36px;align-items:end;min-height:560px;
}
.hero-reference__left{max-width:520px;padding-bottom:8px}
.hero-reference__eyebrow{font-size:1.05rem;font-weight:700;color:var(--eme-text);margin-bottom:16px;max-width:14ch}
.hero-reference__left h1{
  font-size:clamp(3.8rem,8vw,6.1rem);line-height:.93;letter-spacing:-.065em;max-width:7.5ch;color:var(--eme-text);
  margin-bottom:20px;
}
.hero-reference__links{margin-bottom:24px}
.hero-reference__text-link{font-weight:700}
.hero-reference__text-link:hover{color:var(--eme-primary);border-color:currentColor}
.eme-button--hero{
  position:relative;display:inline-flex;align-items:center;gap:10px;padding:14px 24px;border-radius:999px;color:#fff;
  background:linear-gradient(180deg,#ef4464 0%,#d90a2c 100%);
  box-shadow:0 12px 24px rgba(217,10,44,.22);
}
.eme-button--hero:hover{transform:translateY(-2px);box-shadow:0 16px 28px rgba(217,10,44,.28);}
.hero-reference__right,.hero-reference__visual-card{align-self:end}
.hero-reference__visual-card{max-width:520px;display:grid;gap:12px}
.hero-reference__visual{
  min-height:390px;border:0;background:transparent;display:flex;align-items:flex-end;justify-content:center;overflow:visible;
}
.hero-reference__photo{
  width:100%;height:auto;min-height:auto;max-height:390px;object-fit:contain;object-position:center bottom;
}
.hero-reference__definition{max-width:430px}
.hero-reference__definition-label{font-size:.98rem;gap:8px}
.hero-reference__definition-text{font-size:1.05rem;line-height:1.32;max-width:25ch;color:var(--eme-text)}

.services-split{padding:48px 0 32px}
.services-split__grid{display:grid;grid-template-columns:minmax(0,.95fr) minmax(0,1.05fr);gap:50px;align-items:start}
.section-kicker,.service-line__kicker,.page-hero__eyebrow,.card__eyebrow,.case-study__meta{color:var(--eme-text-soft)!important;}
.services-split__intro h2{font-size:clamp(2rem,4vw,3.2rem);max-width:12ch}
.services-split__list{border-top:1px solid var(--eme-border)}
.service-line{padding:24px 0;border-bottom:1px solid var(--eme-border)}
.service-line h3{font-size:1.45rem;line-height:1.15}
.service-line p{max-width:52ch}

.page-hero{padding:30px 0 12px}
.page-hero__wrap{max-width:900px}
.page-hero__eyebrow{font-size:.95rem;font-weight:700}
.page-hero__title{font-size:clamp(3rem,6vw,5rem);line-height:.95;max-width:11ch}
.page-hero__text{max-width:60ch;color:var(--eme-text-soft)}
.page-section{padding:34px 0}
.page-section--alt{background:var(--eme-surface-2)}
.page-split{display:grid;grid-template-columns:minmax(0,.95fr) minmax(0,1.05fr);gap:52px;align-items:start}
.page-split__intro h2{font-size:clamp(2rem,4vw,3rem);max-width:13ch}
.page-split__intro p{color:var(--eme-text-soft);max-width:50ch}
.page-list{border-top:1px solid var(--eme-border)}
.page-list__item{padding:24px 0;border-bottom:1px solid var(--eme-border)}
.page-list__item h3{font-size:1.4rem}
.page-list__item p{color:var(--eme-text-soft);max-width:54ch}
.metrics-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.metric-card{padding:22px;border:1px solid var(--eme-border);border-radius:18px;background:var(--eme-surface)}
.metric-card__value{font-size:2rem;line-height:1;font-weight:800;margin-bottom:8px;color:var(--eme-text)}
.metric-card__label{font-weight:700;margin-bottom:8px}
.metric-card p{margin:0;color:var(--eme-text-soft)}
.final-cta{
  display:grid;grid-template-columns:minmax(0,1fr) auto;gap:24px;align-items:center;padding:36px 0;border-top:1px solid var(--eme-border)
}
.final-cta h2{font-size:clamp(2rem,4vw,3.2rem);max-width:12ch}

.card{box-shadow:none;border-radius:18px;border:1px solid var(--eme-border);}
.case-study-list{display:grid;gap:20px}
.case-study{padding:28px;border:1px solid var(--eme-border);border-radius:18px;background:var(--eme-surface)}
.site-footer{margin-top:32px}

@media (max-width:1320px){.utility-rail,.social-rail{display:none}}
@media (max-width:1180px){
  .menu-toggle{display:block}
  .primary-nav{position:fixed;inset:80px 20px auto 20px;background:var(--eme-surface);border:1px solid var(--eme-border);padding:18px;border-radius:18px;display:none}
  .primary-nav.is-open{display:block}
  .primary-nav .menu{display:grid;gap:8px}
  .primary-nav .menu > li > a{padding:12px 0 8px}
  .hero-reference,.services-split__grid,.page-split,.final-cta{grid-template-columns:1fr}
  .hero-reference{min-height:auto}
  .hero-reference__left h1{max-width:none;font-size:clamp(3rem,14vw,4.8rem)}
  .hero-reference__visual-card,.hero-reference__definition{max-width:none}
  .hero-reference__visual{min-height:280px}
  .hero-reference__photo{max-height:280px}
  .metrics-grid{grid-template-columns:1fr}
}
