/* =========================================================
   Entitle Guard — component stylesheet
   Loaded after style.css and the parent (Kadence) stylesheet.
   Variables are defined in style.css :root.
   ========================================================= */

/* Suppress the parent (Kadence) header/footer so our [eg_header]/[eg_footer]
   are the only chrome on every page. Phase 2 will swap to a properly wired
   Kadence header/footer builder element so we can drop these. */
#wrapper > header.site-header,
#wrapper > footer.site-footer,
.site > header.site-header,
.site > footer.site-footer,
body.kadence-elementor-colors > header.site-header,
.site-header.site-header-default,
.site-footer { display: none !important; }
body { padding-top: 0 !important; }
#eg-main { display: block; }

/* --- Base resets --- */
* { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; }
body {
    font-family: var(--eg-font-sans);
    font-size: var(--eg-text-base);
    line-height: var(--eg-leading-body);
    color: var(--eg-near-black);
    background: var(--eg-white);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}
img, video, svg { max-width: 100%; height: auto; display: block; }
h1, h2, h3, h4, h5 { font-family: var(--eg-font-sans); font-weight: 700; line-height: var(--eg-leading-tight); letter-spacing: var(--eg-track-tight); margin: 0 0 var(--eg-space-4); color: var(--eg-near-black); }
h1 { font-weight: 800; }
p  { margin: 0 0 var(--eg-space-4); }
a  { color: var(--eg-blue); text-decoration: underline; text-underline-offset: 3px; transition: color var(--eg-dur) var(--eg-ease); }
a:hover, a:focus { color: var(--eg-blue-700); }
:focus-visible { outline: 2px solid var(--eg-blue); outline-offset: 3px; border-radius: 4px; }

.eg-skip-link {
    position: absolute; left: -9999px; top: -9999px;
}
.eg-skip-link:focus {
    position: fixed; left: 1rem; top: 1rem; z-index: 1000;
    background: var(--eg-blue); color: white; padding: 0.75rem 1rem; border-radius: 6px; text-decoration: none;
}

/* --- Buttons --- */
.eg-btn {
    display: inline-flex; align-items: center; justify-content: center; gap: 0.5rem;
    padding: 0.875rem 1.5rem;
    font-weight: 600; font-size: 0.9375rem; line-height: 1;
    border-radius: 10px; border: 1.5px solid transparent;
    cursor: pointer; text-decoration: none;
    transition: background var(--eg-dur) var(--eg-ease), transform var(--eg-dur) var(--eg-ease), box-shadow var(--eg-dur) var(--eg-ease), color var(--eg-dur) var(--eg-ease);
    white-space: nowrap;
}
.eg-btn:focus-visible { outline-offset: 4px; }
.eg-btn--primary { background: var(--eg-blue); color: var(--eg-white); }
.eg-btn--primary:hover, .eg-btn--primary:focus { background: var(--eg-blue-700); color: var(--eg-white); transform: translateY(-1px); box-shadow: var(--eg-shadow); }
.eg-btn--ghost { background: transparent; color: var(--eg-near-black); border-color: var(--eg-slate-300); }
.eg-btn--ghost:hover, .eg-btn--ghost:focus { border-color: var(--eg-near-black); color: var(--eg-near-black); }
.eg-btn--ghost-light { background: transparent; color: var(--eg-white); border-color: rgba(255,255,255,0.4); }
.eg-btn--ghost-light:hover { border-color: white; color: white; }
.eg-btn--lg { padding: 1.125rem 2rem; font-size: 1.0625rem; }
.eg-btn--block { display: flex; width: 100%; }

/* --- Header --- */
.eg-header {
    position: sticky; top: 0; z-index: 60;
    background: rgba(255, 255, 255, 0.0);
    backdrop-filter: saturate(180%) blur(8px);
    transition: background var(--eg-dur) var(--eg-ease), box-shadow var(--eg-dur) var(--eg-ease), border-color var(--eg-dur) var(--eg-ease);
    border-bottom: 1px solid transparent;
}
.eg-header[data-scrolled="true"] {
    background: rgba(255, 255, 255, 0.96);
    border-bottom-color: var(--eg-slate-200);
    box-shadow: var(--eg-shadow-sm);
}
.eg-header__inner {
    max-width: var(--eg-content-max);
    margin: 0 auto;
    padding: 0 var(--eg-space-5);
    height: var(--eg-header-h);
    display: flex; align-items: center; gap: var(--eg-space-6);
}
.eg-header__brand img { height: 40px; width: auto; }
.eg-header__brand { flex-shrink: 0; }
.eg-header__nav { flex: 1; }
.eg-nav { list-style: none; padding: 0; margin: 0; display: flex; gap: var(--eg-space-5); align-items: center; }
.eg-nav > li { position: relative; }
.eg-nav > li > a {
    color: var(--eg-near-black); text-decoration: none; font-weight: 500; font-size: 0.9375rem;
    padding: 0.5rem 0; display: inline-flex; align-items: center; gap: 0.25rem;
}
.eg-nav > li > a:hover { color: var(--eg-blue); }
.eg-nav .sub-menu {
    position: absolute; top: calc(100% + 8px); left: 0;
    background: white; border: 1px solid var(--eg-slate-200); border-radius: 12px;
    padding: 0.5rem; min-width: 220px;
    box-shadow: var(--eg-shadow); list-style: none; margin: 0;
    opacity: 0; visibility: hidden; transform: translateY(-6px);
    transition: opacity var(--eg-dur) var(--eg-ease), transform var(--eg-dur) var(--eg-ease), visibility 0s linear var(--eg-dur);
}
.eg-nav > li:hover > .sub-menu,
.eg-nav > li:focus-within > .sub-menu {
    opacity: 1; visibility: visible; transform: translateY(0);
    transition-delay: 0s, 0s, 0s;
}
.eg-nav .sub-menu a {
    display: block; padding: 0.625rem 0.875rem; border-radius: 8px;
    color: var(--eg-near-black); text-decoration: none; font-size: 0.9375rem;
}
.eg-nav .sub-menu a:hover { background: var(--eg-slate-50); color: var(--eg-blue); }

.eg-header__actions { display: flex; align-items: center; gap: var(--eg-space-4); flex-shrink: 0; }

/* App badges. Apple SVG and Google PNG have different built-in padding.
   We compensate visually so they appear at the same optical height,
   regardless of size. */
.eg-app-badges { display: inline-flex; gap: 0.625rem; align-items: center; flex-wrap: wrap; }
.eg-app-badge { display: inline-block; line-height: 0; transition: transform var(--eg-dur) var(--eg-ease), opacity var(--eg-dur) var(--eg-ease); }
.eg-app-badge:hover { transform: translateY(-1px); opacity: 0.92; }
.eg-app-badge img { display: block; width: auto; }
.eg-app-badges--sm .eg-app-badge--ios img     { height: 40px; }
.eg-app-badges--sm .eg-app-badge--android img { height: 58px; margin: -9px 0; }
.eg-app-badges--md .eg-app-badge--ios img     { height: 52px; }
.eg-app-badges--md .eg-app-badge--android img { height: 76px; margin: -12px 0; }
.eg-app-badges--lg .eg-app-badge--ios img     { height: 64px; }
.eg-app-badges--lg .eg-app-badge--android img { height: 92px; margin: -14px 0; }

/* Sign in dropdown */
.eg-signin { position: relative; }
.eg-signin__btn {
    display: inline-flex; align-items: center; gap: 0.25rem;
    background: transparent; border: 0; cursor: pointer;
    padding: 0.5rem 0; font-weight: 500; font-size: 0.9375rem; color: var(--eg-near-black);
    font-family: inherit;
}
.eg-signin__menu {
    position: absolute; top: calc(100% + 8px); right: 0;
    background: white; border: 1px solid var(--eg-slate-200); border-radius: 12px;
    box-shadow: var(--eg-shadow); padding: 0.5rem;
    min-width: 280px; opacity: 0; visibility: hidden; transform: translateY(-6px);
    transition: opacity var(--eg-dur) var(--eg-ease), transform var(--eg-dur) var(--eg-ease), visibility 0s linear var(--eg-dur);
    z-index: 70;
}
.eg-signin[data-open="true"] .eg-signin__menu,
.eg-signin:focus-within .eg-signin__menu {
    opacity: 1; visibility: visible; transform: translateY(0); transition-delay: 0s;
}
.eg-signin__menu a {
    display: flex; flex-direction: column; gap: 2px;
    padding: 0.625rem 0.875rem; border-radius: 8px;
    text-decoration: none;
}
.eg-signin__menu a:hover { background: var(--eg-slate-50); }
.eg-signin__menu a strong { color: var(--eg-near-black); font-weight: 600; }
.eg-signin__menu a span { color: var(--eg-slate-500); font-size: 0.8125rem; }

/* Burger / mobile drawer */
.eg-burger { display: none; background: transparent; border: 0; padding: 0.5rem; cursor: pointer; }
.eg-burger span { display: block; width: 22px; height: 2px; background: var(--eg-near-black); margin: 5px 0; transition: transform var(--eg-dur) var(--eg-ease), opacity var(--eg-dur) var(--eg-ease); }
.eg-burger[aria-expanded="true"] span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.eg-burger[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
.eg-burger[aria-expanded="true"] span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

.eg-mobile-drawer {
    position: fixed; top: var(--eg-header-h); left: 0; right: 0; bottom: 0;
    background: white; padding: var(--eg-space-6) var(--eg-space-5);
    transform: translateX(100%); transition: transform var(--eg-dur) var(--eg-ease);
    overflow-y: auto; z-index: 55;
}
.eg-mobile-drawer[aria-hidden="false"] { transform: translateX(0); }
.eg-mobile-nav { list-style: none; padding: 0; margin: var(--eg-space-5) 0; }
.eg-mobile-nav li { border-bottom: 1px solid var(--eg-slate-200); }
.eg-mobile-nav a { display: block; padding: 1rem 0; color: var(--eg-near-black); text-decoration: none; font-weight: 600; }
.eg-mobile-nav .sub-menu { list-style: none; padding-left: var(--eg-space-4); margin: 0 0 var(--eg-space-3); }
.eg-mobile-nav .sub-menu a { font-weight: 400; padding: 0.5rem 0; border: 0; }
.eg-mobile-drawer__signin { display: flex; flex-direction: column; gap: 0.5rem; margin: var(--eg-space-5) 0; }
.eg-mobile-drawer__signin a { color: var(--eg-blue); text-decoration: none; font-weight: 500; }

/* Sticky mobile app bar */
.eg-sticky-app-bar {
    position: fixed; left: 0; right: 0; bottom: 0; z-index: 80;
    background: var(--eg-near-black); color: var(--eg-white);
    border-top: 1px solid rgba(255, 255, 255, 0.1);
    transform: translateY(100%); transition: transform 300ms var(--eg-ease);
}
.eg-sticky-app-bar[data-visible="true"] { transform: translateY(0); }
.eg-sticky-app-bar__inner {
    display: flex; align-items: center; gap: var(--eg-space-4);
    padding: 0.625rem 0.875rem;
    max-width: 720px; margin: 0 auto;
}
.eg-sticky-app-bar__text { margin: 0; font-size: 0.8125rem; flex: 1; line-height: 1.3; }
.eg-sticky-app-bar__close { background: transparent; border: 0; color: rgba(255,255,255,0.7); padding: 0.5rem; cursor: pointer; }
.eg-sticky-app-bar__close:hover { color: white; }

/* --- App download band (footer + mid-page) --- */
.eg-app-band { background: var(--eg-near-black); color: var(--eg-white); padding: var(--eg-space-10) var(--eg-space-5); border-top: 1px solid rgba(45, 212, 191, 0.25); }
.eg-app-band__inner {
    max-width: var(--eg-content-max); margin: 0 auto;
    display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: var(--eg-space-6);
}
.eg-app-band__eyebrow { color: var(--eg-teal); font-size: 0.8125rem; font-weight: 600; letter-spacing: 0.06em; text-transform: uppercase; margin: 0 0 0.5rem; }
.eg-app-band__title { color: var(--eg-white); font-size: clamp(1.75rem, 3vw, 2.25rem); font-weight: 700; letter-spacing: -0.02em; margin: 0 0 0.5rem; }
.eg-app-band__sub { color: rgba(255,255,255,0.75); font-size: 1rem; margin: 0; }

/* --- Footer --- */
.eg-footer {
    background: var(--eg-near-black); color: rgba(255,255,255,0.75);
    padding: var(--eg-space-12) var(--eg-space-5) var(--eg-space-6);
    font-size: 0.9375rem;
}
.eg-footer__inner {
    max-width: var(--eg-content-max); margin: 0 auto;
    display: grid; grid-template-columns: 1.5fr repeat(5, 1fr); gap: var(--eg-space-6);
}
.eg-footer__heading { color: var(--eg-white); font-size: 0.9375rem; font-weight: 600; margin: 0 0 var(--eg-space-4); letter-spacing: 0.02em; }
.eg-footer__col ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 0.625rem; }
.eg-footer__col a { color: rgba(255,255,255,0.7); text-decoration: none; transition: color var(--eg-dur) var(--eg-ease); }
.eg-footer__col a:hover, .eg-footer__col a:focus { color: var(--eg-white); }
.eg-footer__brand-link img { height: 36px; width: auto; }
.eg-footer__tagline { margin: var(--eg-space-3) 0 var(--eg-space-4); color: rgba(255,255,255,0.55); font-size: 0.875rem; }
.eg-socials { list-style: none; padding: 0; margin: 0; display: flex; gap: 0.75rem; }
.eg-socials a {
    display: inline-flex; align-items: center; justify-content: center;
    width: 36px; height: 36px; border-radius: 8px;
    background: rgba(255,255,255,0.06); color: rgba(255,255,255,0.75);
    text-decoration: none; transition: background var(--eg-dur) var(--eg-ease), color var(--eg-dur) var(--eg-ease);
}
.eg-socials a:hover, .eg-socials a:focus { background: var(--eg-blue); color: white; }
.eg-footer__baseline {
    max-width: var(--eg-content-max); margin: var(--eg-space-8) auto 0;
    padding-top: var(--eg-space-5); border-top: 1px solid rgba(255,255,255,0.08);
    color: rgba(255,255,255,0.5); font-size: 0.8125rem;
}
.eg-footer__baseline p { margin: 0; }

/* --- Final CTA banner --- */
.eg-final-cta {
    background: linear-gradient(135deg, var(--eg-blue) 0%, var(--eg-blue-700) 100%);
    color: var(--eg-white); padding: var(--eg-space-12) var(--eg-space-5);
    text-align: center;
}
.eg-final-cta__inner { max-width: 800px; margin: 0 auto; display: flex; flex-direction: column; align-items: center; gap: var(--eg-space-5); }
.eg-final-cta__title { color: var(--eg-white); font-size: clamp(1.75rem, 3.5vw, 2.5rem); font-weight: 700; line-height: 1.2; letter-spacing: -0.02em; margin: 0; max-width: 720px; }
.eg-final-cta .eg-btn--primary { background: var(--eg-white); color: var(--eg-blue); border-color: var(--eg-white); }
.eg-final-cta .eg-btn--primary:hover { background: var(--eg-near-black); color: var(--eg-white); border-color: var(--eg-near-black); }
.eg-final-cta__sub { color: rgba(255,255,255,0.85); margin: 0; font-size: 0.9375rem; }

/* --- Layout wrappers --- */
.eg-container { max-width: var(--eg-content-max); margin-left: auto; margin-right: auto; padding-left: var(--eg-space-5); padding-right: var(--eg-space-5); }
.eg-prose      { max-width: var(--eg-prose-max); }
.eg-section    { padding-block: var(--eg-space-12); }

/* --- Hero --- */
.eg-hero { position: relative; min-height: 78vh; color: var(--eg-white); display: flex; align-items: center; overflow: hidden; }
.eg-hero__media { position: absolute; inset: 0; }
.eg-hero__media video, .eg-hero__media img { width: 100%; height: 100%; object-fit: cover; }
.eg-hero__overlay { position: absolute; inset: 0; background: linear-gradient(to bottom, rgba(15,23,42,0.15) 0%, rgba(15,23,42,0.45) 60%, rgba(15,23,42,0.78) 100%); }
.eg-hero__inner { position: relative; max-width: var(--eg-content-max); margin: 0 auto; padding: var(--eg-space-12) var(--eg-space-5); width: 100%; }
.eg-hero__title { color: var(--eg-white); font-size: clamp(2.25rem, 5.5vw, 4.25rem); font-weight: 800; line-height: 1.05; letter-spacing: -0.02em; max-width: 18ch; margin: 0 0 var(--eg-space-5); }
.eg-hero__sub { color: rgba(255,255,255,0.9); font-size: clamp(1.0625rem, 1.5vw, 1.25rem); max-width: 56ch; margin: 0 0 var(--eg-space-6); }
.eg-hero__cta { display: flex; gap: var(--eg-space-4); flex-wrap: wrap; align-items: center; }

/* --- Quiet stat band --- */
.eg-quiet-stats { background: var(--eg-slate-50); padding: var(--eg-space-12) var(--eg-space-5); }
.eg-quiet-stats__grid { max-width: var(--eg-content-max); margin: 0 auto; display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--eg-space-8); }
.eg-quiet-stat p { font-size: clamp(1.125rem, 1.6vw, 1.375rem); line-height: 1.45; color: var(--eg-near-black); margin: 0; max-width: 38ch; }

/* --- Audience selector quad --- */
.eg-quad { padding: var(--eg-space-12) var(--eg-space-5); }
.eg-quad__grid { max-width: var(--eg-content-max); margin: 0 auto; display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--eg-space-5); }
.eg-quad__card {
    background: white; border: 1px solid var(--eg-slate-200); border-radius: var(--eg-radius);
    padding: var(--eg-space-6); display: flex; flex-direction: column; gap: var(--eg-space-3);
    text-decoration: none; color: var(--eg-near-black);
    border-top: 4px solid var(--accent, var(--eg-blue));
    transition: transform var(--eg-dur) var(--eg-ease), box-shadow var(--eg-dur) var(--eg-ease), border-color var(--eg-dur) var(--eg-ease);
}
.eg-quad__card:hover { transform: translateY(-4px); box-shadow: var(--eg-shadow); }
.eg-quad__icon { width: 36px; height: 36px; color: var(--accent, var(--eg-blue)); }
.eg-quad__eyebrow { color: var(--accent, var(--eg-blue)); font-weight: 600; font-size: 0.8125rem; letter-spacing: 0.06em; text-transform: uppercase; }
.eg-quad__title { font-size: 1.375rem; font-weight: 700; margin: 0; }
.eg-quad__sub { color: var(--eg-slate-700); margin: 0; font-size: 0.9375rem; line-height: 1.55; }
.eg-quad__more { margin-top: auto; color: var(--accent, var(--eg-blue)); font-weight: 600; font-size: 0.875rem; }
.eg-quad__card[data-audience="builders"]   { --accent: var(--eg-builders); }
.eg-quad__card[data-audience="homeowners"] { --accent: var(--eg-homeowners); }
.eg-quad__card[data-audience="merchants"]  { --accent: var(--eg-merchants); }
.eg-quad__card[data-audience="oems"]       { --accent: var(--eg-oems); }

/* --- Audience deep-dive --- */
.eg-deep { padding: var(--eg-space-12) var(--eg-space-5); }
.eg-deep__row { max-width: var(--eg-content-max); margin: 0 auto var(--eg-space-12); display: grid; grid-template-columns: 1fr 1fr; gap: var(--eg-space-10); align-items: center; }
.eg-deep__row:last-child { margin-bottom: 0; }
.eg-deep__row[data-flip="true"] .eg-deep__media { order: 2; }
.eg-deep__media img { border-radius: var(--eg-radius); }
.eg-deep__eyebrow { color: var(--eg-blue); font-weight: 600; font-size: 0.8125rem; letter-spacing: 0.06em; text-transform: uppercase; margin: 0 0 var(--eg-space-3); }
.eg-deep__title { font-size: clamp(1.625rem, 3vw, 2.25rem); margin: 0 0 var(--eg-space-4); }
.eg-deep__body { font-size: 1.0625rem; line-height: 1.7; color: var(--eg-slate-700); margin: 0 0 var(--eg-space-5); }
.eg-deep__cta { color: var(--eg-blue); font-weight: 600; text-decoration: none; }
.eg-deep__cta:hover { text-decoration: underline; }

/* --- Pull quote --- */
.eg-pullquote { border-left: 4px solid var(--eg-blue); padding: var(--eg-space-2) var(--eg-space-5); margin: var(--eg-space-8) 0; }
.eg-pullquote__text { font-style: italic; font-weight: 600; font-size: 1.375rem; line-height: 1.5; color: var(--eg-near-black); margin: 0 0 var(--eg-space-3); }
.eg-pullquote__author { color: var(--eg-slate-500); font-size: 0.9375rem; margin: 0; }

/* --- How it works --- */
.eg-steps { padding: var(--eg-space-12) var(--eg-space-5); background: var(--eg-slate-50); }
.eg-steps__grid { max-width: var(--eg-content-max); margin: 0 auto; display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--eg-space-6); }
.eg-step { background: white; padding: var(--eg-space-6); border-radius: var(--eg-radius); border: 1px solid var(--eg-slate-200); }
.eg-step__num { display: inline-flex; align-items: center; justify-content: center; width: 36px; height: 36px; border-radius: 50%; background: var(--eg-blue); color: white; font-weight: 700; margin-bottom: var(--eg-space-4); }
.eg-step__title { font-size: 1.125rem; margin: 0 0 0.5rem; }
.eg-step__body  { color: var(--eg-slate-700); font-size: 0.9375rem; line-height: 1.6; margin: 0; }

/* --- Why now (dark section) --- */
.eg-whynow { background: var(--eg-near-black); color: var(--eg-white); padding: var(--eg-space-12) var(--eg-space-5); }
.eg-whynow__inner { max-width: var(--eg-content-max); margin: 0 auto; }
.eg-whynow__title { color: var(--eg-white); font-size: clamp(1.625rem, 3vw, 2.25rem); margin-bottom: var(--eg-space-8); }
.eg-whynow__grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: var(--eg-space-5); }
.eg-whynow__item { color: rgba(255,255,255,0.85); font-size: 0.9375rem; line-height: 1.5; padding-top: var(--eg-space-4); border-top: 1px solid rgba(255,255,255,0.15); }

/* --- Logo wall --- */
.eg-logos { padding: var(--eg-space-10) var(--eg-space-5); border-top: 1px solid var(--eg-slate-200); }
.eg-logos__title { text-align: center; color: var(--eg-slate-500); font-size: 0.875rem; font-weight: 500; letter-spacing: 0.08em; text-transform: uppercase; margin-bottom: var(--eg-space-6); }
.eg-logos__row { max-width: var(--eg-content-max); margin: 0 auto; display: flex; flex-wrap: wrap; align-items: center; justify-content: center; gap: var(--eg-space-8); opacity: 0.7; }

/* --- Pilot banner --- */
.eg-pilot-banner {
    background: var(--eg-blue-50); padding: var(--eg-space-10) var(--eg-space-5);
    border-top: 1px solid var(--eg-slate-200); border-bottom: 1px solid var(--eg-slate-200);
}
.eg-pilot-banner__inner { max-width: var(--eg-content-max); margin: 0 auto; display: flex; align-items: center; justify-content: space-between; gap: var(--eg-space-6); flex-wrap: wrap; }
.eg-pilot-banner__title { font-size: 1.5rem; font-weight: 700; margin: 0; color: var(--eg-near-black); }
.eg-pilot-banner__sub { color: var(--eg-slate-700); margin: 0.25rem 0 0; font-size: 1rem; }

/* --- Latest blog --- */
.eg-latest { padding: var(--eg-space-12) var(--eg-space-5); }
.eg-latest__head { max-width: var(--eg-content-max); margin: 0 auto var(--eg-space-6); display: flex; align-items: baseline; justify-content: space-between; }
.eg-latest__title { font-size: 1.875rem; margin: 0; }
.eg-latest__more { color: var(--eg-blue); font-weight: 600; text-decoration: none; }
.eg-latest__grid { max-width: var(--eg-content-max); margin: 0 auto; display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--eg-space-6); }
.eg-card { background: white; border: 1px solid var(--eg-slate-200); border-radius: var(--eg-radius); overflow: hidden; transition: transform var(--eg-dur) var(--eg-ease), box-shadow var(--eg-dur) var(--eg-ease); }
.eg-card:hover { transform: translateY(-2px); box-shadow: var(--eg-shadow); }
.eg-card a { text-decoration: none; color: inherit; }
.eg-card__img img { width: 100%; height: 200px; object-fit: cover; }
.eg-card__body { padding: var(--eg-space-5); }
.eg-card__cat  { color: var(--eg-blue); font-weight: 600; font-size: 0.8125rem; text-transform: uppercase; letter-spacing: 0.06em; }
.eg-card__title { font-size: 1.125rem; margin: 0.5rem 0 0.5rem; line-height: 1.4; color: var(--eg-near-black); }
.eg-card__meta { color: var(--eg-slate-500); font-size: 0.8125rem; }

/* --- Forms --- */
.eg-form { display: grid; gap: var(--eg-space-4); }
.eg-form__row { display: grid; gap: 0.375rem; }
.eg-form label { font-weight: 600; font-size: 0.875rem; color: var(--eg-near-black); }
.eg-form input[type=text], .eg-form input[type=email], .eg-form input[type=tel], .eg-form select, .eg-form textarea {
    width: 100%; padding: 0.75rem 0.875rem; font: inherit; color: var(--eg-near-black);
    background: white; border: 1.5px solid var(--eg-slate-200); border-radius: 8px;
    transition: border-color var(--eg-dur) var(--eg-ease), box-shadow var(--eg-dur) var(--eg-ease);
}
.eg-form input:focus, .eg-form select:focus, .eg-form textarea:focus { border-color: var(--eg-blue); box-shadow: 0 0 0 3px rgba(59, 91, 254, 0.18); outline: none; }
.eg-form textarea { min-height: 120px; resize: vertical; }
.eg-form .eg-form__hp { position: absolute; left: -9999px; top: -9999px; }
.eg-form__consent { display: flex; gap: 0.625rem; align-items: flex-start; font-size: 0.875rem; color: var(--eg-slate-700); }
.eg-form__consent input[type=checkbox] { margin-top: 4px; flex-shrink: 0; }
.eg-form__feedback { padding: 0.75rem 1rem; border-radius: 8px; font-size: 0.9375rem; }
.eg-form__feedback[data-type="success"] { background: rgba(16, 185, 129, 0.12); color: #065F46; border: 1px solid rgba(16,185,129,0.3); }
.eg-form__feedback[data-type="error"]   { background: rgba(245, 158, 11, 0.12); color: #92400E; border: 1px solid rgba(245,158,11,0.3); }
.eg-form .eg-btn--primary { justify-self: start; }

/* --- Blog category filter pills (used on /blog/ and category archives) --- */
.eg-blog-filter { display: flex; flex-wrap: wrap; gap: 0.5rem; margin-bottom: 2rem; }
.eg-blog-filter__pill {
    display: inline-flex; align-items: center; gap: 0.4rem;
    padding: 0.5rem 1rem;
    border-radius: 999px;
    background: var(--eg-slate-100); color: var(--eg-near-black);
    text-decoration: none;
    font-size: 0.875rem; font-weight: 500;
    transition: background var(--eg-dur) var(--eg-ease), color var(--eg-dur) var(--eg-ease);
}
.eg-blog-filter__pill:hover { background: var(--eg-slate-200); color: var(--eg-near-black); }
.eg-blog-filter__pill.is-active { background: var(--eg-near-black); color: var(--eg-white); }
.eg-blog-filter__pill.is-active:hover { background: var(--eg-near-black); color: var(--eg-white); }
.eg-blog-filter__count { font-size: 0.75rem; opacity: 0.7; }
.eg-blog-filter__pill.is-active .eg-blog-filter__count { opacity: 0.85; }

/* --- Team cards (used on /about/) --- */
.eg-team-card { background: white; border: 1px solid var(--eg-slate-200); border-radius: 14px; padding: 2rem 1.75rem; text-align: center; display: flex; flex-direction: column; gap: 0.5rem; align-items: center; }
.eg-team-card__avatar {
    width: 88px; height: 88px; border-radius: 50%;
    background: linear-gradient(135deg, var(--eg-blue-50), #DBEAFE);
    color: var(--eg-blue); font-size: 2.25rem; font-weight: 700;
    display: inline-flex; align-items: center; justify-content: center;
    margin-bottom: 0.75rem;
    border: 2px solid white;
    box-shadow: 0 0 0 1px var(--eg-blue-50), var(--eg-shadow-sm);
}
.eg-team-card__photo {
    width: 120px; height: 120px; border-radius: 50%; object-fit: cover;
    margin-bottom: 0.75rem;
    border: 3px solid white;
    box-shadow: 0 0 0 1px var(--eg-slate-200), var(--eg-shadow);
}
.eg-team-card__name { font-size: 1.125rem; margin: 0; color: var(--eg-near-black); }
.eg-team-card__role { color: var(--eg-blue); font-weight: 600; font-size: 0.875rem; margin: 0 0 0.5rem; letter-spacing: .02em; display:flex; flex-direction:column; gap:0.125rem; }
.eg-team-card__org { color: var(--eg-slate-500); font-weight: 500; font-size: 0.8125rem; }
.eg-team-card__bio { color: var(--eg-slate-700); font-size: 0.9375rem; line-height: 1.6; margin: 0 0 1rem; }
.eg-team-card__linkedin {
    display: inline-flex; align-items: center; gap: 0.4rem;
    margin-top: auto; padding: 0.5rem 0.875rem;
    background: var(--eg-slate-100); color: var(--eg-near-black);
    border-radius: 8px; font-size: 0.8125rem; font-weight: 600;
    text-decoration: none;
    transition: background var(--eg-dur) var(--eg-ease), color var(--eg-dur) var(--eg-ease);
}
.eg-team-card__linkedin:hover, .eg-team-card__linkedin:focus { background: var(--eg-blue); color: var(--eg-white); }
.eg-team-card__linkedin svg { flex-shrink: 0; }

/* --- YouTube embed cards (used on /resources/) --- */
.eg-yt-card { background: white; border: 1px solid var(--eg-slate-200); border-radius: 12px; overflow: hidden; display: flex; flex-direction: column; }
.eg-yt-card__embed { position: relative; aspect-ratio: 16 / 9; background: var(--eg-near-black); }
.eg-yt-card__embed iframe { position: absolute; inset: 0; width: 100%; height: 100%; border: 0; }
.eg-yt-card__body { padding: 1.25rem 1.5rem 1.5rem; display: flex; flex-direction: column; gap: 0.5rem; }
.eg-yt-card__title { font-size: 1.0625rem; margin: 0; line-height: 1.35; }
.eg-yt-card__sub { color: var(--eg-slate-700); font-size: 0.9375rem; line-height: 1.55; margin: 0; }
.eg-yt-card__more { color: var(--eg-blue); font-weight: 600; text-decoration: none; font-size: 0.875rem; margin-top: 0.25rem; }
.eg-yt-card__more:hover { text-decoration: underline; }

/* --- Cookie / legal tables --- */
.eg-cookie-table { width: 100%; border-collapse: collapse; font-size: 0.875rem; }
.eg-cookie-table thead th { text-align: left; padding: 0.625rem 0.875rem; background: var(--eg-slate-50); border-bottom: 2px solid var(--eg-slate-200); font-weight: 600; }
.eg-cookie-table tbody td { padding: 0.625rem 0.875rem; border-bottom: 1px solid var(--eg-slate-200); vertical-align: top; color: var(--eg-slate-700); }
.eg-cookie-table code { background: var(--eg-slate-100); padding: 1px 6px; border-radius: 4px; font-size: 0.8125rem; color: var(--eg-near-black); }

/* --- Legal page polish --- */
.eg-section h2 { font-size: clamp(1.375rem, 2vw, 1.625rem); margin-top: 2.5rem; margin-bottom: 0.875rem; letter-spacing: -0.01em; }
.eg-section h3 { font-size: 1.125rem; margin-top: 1.75rem; margin-bottom: 0.625rem; color: var(--eg-near-black); font-weight: 600; }
.eg-section h2:first-child, .eg-section h3:first-child { margin-top: 0; }

/* --- Responsive breakpoints --- */
@media (max-width: 1024px) {
    .eg-header__nav, .eg-signin, .eg-header__cta, .eg-header .eg-app-badges { display: none; }
    .eg-burger { display: inline-flex; flex-direction: column; }
    .eg-footer__inner { grid-template-columns: 1fr 1fr; }
    .eg-quad__grid, .eg-latest__grid { grid-template-columns: repeat(2, 1fr); }
    .eg-deep__row { grid-template-columns: 1fr; }
    .eg-deep__row[data-flip="true"] .eg-deep__media { order: -1; }
    .eg-quiet-stats__grid { grid-template-columns: 1fr; gap: var(--eg-space-5); }
    .eg-whynow__grid { grid-template-columns: repeat(2, 1fr); }
    .eg-steps__grid { grid-template-columns: 1fr; }
}
@media (max-width: 640px) {
    body { font-size: var(--eg-text-mobile); }
    .eg-footer__inner { grid-template-columns: 1fr; }
    .eg-quad__grid, .eg-latest__grid { grid-template-columns: 1fr; }
    .eg-whynow__grid { grid-template-columns: 1fr; }
    .eg-app-band__inner { flex-direction: column; align-items: flex-start; text-align: left; }
    .eg-pilot-banner__inner { flex-direction: column; align-items: flex-start; text-align: left; }
}

@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after { transition: none !important; animation: none !important; }
    .eg-hero__media video { display: none; }
}
