/**
 * Excel Inmobiliario — Theme Styles
 * Real-estate identity: emerald/teal primary + warm terracotta accent + slate.
 * Custom ei-* component system (anti-footprint vs. donor). No Tailwind blue visible.
 */

:root {
    --ei-primary: #0E6B5C;      /* emerald / teal */
    --ei-primary-dark: #0A5346;
    --ei-primary-darker: #073C33;
    --ei-primary-soft: #E6F2EF;
    --ei-accent: #C2410C;       /* terracotta */
    --ei-accent-dark: #9A3412;
    --ei-ink: #16241F;          /* near-black slate-green for text */
    --ei-slate: #475467;        /* muted body text */
    --ei-slate-light: #667085;
    --ei-line: #E4E7E5;
    --ei-bg-alt: #F4F7F5;
    --ei-white: #ffffff;
    --ei-radius: 14px;
    --ei-shadow: 0 1px 2px rgba(16,36,31,.04), 0 8px 24px rgba(16,36,31,.06);
    --ei-shadow-lg: 0 20px 50px -20px rgba(7,60,51,.35);
}

/* ===== Base ===== */
body { color: var(--ei-ink); background: var(--ei-white); }
a { color: var(--ei-primary); }
img { max-width: 100%; height: auto; }

.ei-wrap { max-width: 1180px; margin: 0 auto; padding: 0 1.25rem; }
.ei-wrap--narrow { max-width: 800px; }

.ei-section { padding: 4.5rem 0; }
.ei-section--alt { background: var(--ei-bg-alt); }
.ei-section__head { max-width: 680px; margin: 0 auto 2.75rem; text-align: center; }
.ei-section__title { font-size: clamp(1.6rem, 3vw, 2.1rem); font-weight: 700; letter-spacing: -.02em; color: var(--ei-ink); }
.ei-section__title--left { text-align: left; margin-bottom: 1.75rem; }
.ei-section__sub { margin-top: .85rem; font-size: 1.075rem; line-height: 1.6; color: var(--ei-slate); }
.ei-section__more { text-align: center; margin-top: 2.75rem; }

/* ===== Buttons ===== */
.ei-btn {
    display: inline-flex; align-items: center; gap: .55rem;
    padding: .8rem 1.5rem; border-radius: 10px;
    font-weight: 600; font-size: .98rem; line-height: 1; text-decoration: none;
    border: 1px solid transparent; cursor: pointer; transition: background .15s, color .15s, border-color .15s, transform .15s;
}
.ei-btn svg { width: 1.15rem; height: 1.15rem; }
.ei-btn--primary { background: var(--ei-primary); color: #fff; }
.ei-btn--primary:hover { background: var(--ei-primary-dark); color: #fff; }
.ei-btn--ghost { background: rgba(255,255,255,.12); color: #fff; border-color: rgba(255,255,255,.35); }
.ei-btn--ghost:hover { background: rgba(255,255,255,.22); color: #fff; }
.ei-btn--on-dark { background: #fff; color: var(--ei-primary-dark); }
.ei-btn--on-dark:hover { background: var(--ei-primary-soft); }
.ei-btn--muted { background: #EDF0EE; color: var(--ei-slate); }
.ei-btn--muted:hover { background: #E1E6E3; }

/* ===== Header ===== */
.ei-header { position: sticky; top: 0; z-index: 50; background: rgba(255,255,255,.92); backdrop-filter: saturate(180%) blur(8px); border-bottom: 1px solid var(--ei-line); }
.ei-header__inner { max-width: 1180px; margin: 0 auto; padding: 0 1.25rem; height: 4.5rem; display: flex; align-items: center; gap: 1.5rem; }
.ei-brand { display: inline-flex; align-items: center; gap: .65rem; text-decoration: none; flex-shrink: 0; }
.ei-brand__logo { height: 2.4rem; width: auto; }
.ei-brand-mark { color: var(--ei-primary); display: inline-flex; }
.ei-brand-mark svg { width: 2.1rem; height: 2.1rem; display: block; }
.ei-wordmark { font-weight: 700; font-size: 1.18rem; letter-spacing: -.02em; color: var(--ei-ink); white-space: nowrap; }
.ei-wordmark span { color: var(--ei-primary); }
.ei-nav { display: none; }
.ei-nav__list { display: flex; align-items: center; gap: 1.75rem; list-style: none; margin: 0; padding: 0; }
.ei-nav__link { color: var(--ei-slate); font-weight: 500; font-size: .96rem; text-decoration: none; transition: color .15s; white-space: nowrap; }
.ei-nav__link:hover, .current-menu-item .ei-nav__link { color: var(--ei-primary); }
.ei-header__actions { display: flex; align-items: center; gap: .75rem; margin-left: auto; }
.ei-header__cta { display: none; }

/* find / search */
.ei-find { position: relative; }
.ei-find__icon { position: absolute; left: .8rem; top: 50%; transform: translateY(-50%); width: 1rem; height: 1rem; color: var(--ei-slate-light); pointer-events: none; }
.ei-find__input { width: 100%; padding: .55rem .9rem .55rem 2.4rem; font-size: .9rem; color: var(--ei-ink); background: var(--ei-bg-alt); border: 1px solid var(--ei-line); border-radius: 10px; outline: none; transition: border-color .15s, box-shadow .15s; -webkit-appearance: none; }
.ei-find__input:focus { border-color: var(--ei-primary); box-shadow: 0 0 0 3px rgba(14,107,92,.16); background: #fff; }
.ei-find--header { display: none; }
.ei-find--header .ei-find__input { width: 14rem; }

/* burger / drawer */
.ei-burger { display: inline-flex; padding: .45rem; border: 0; background: transparent; color: var(--ei-ink); cursor: pointer; border-radius: 8px; }
.ei-burger:hover { background: var(--ei-bg-alt); }
.ei-burger svg { width: 1.6rem; height: 1.6rem; }
.ei-drawer { border-top: 1px solid var(--ei-line); padding: 1rem 1.25rem 1.5rem; background: #fff; }
.ei-drawer__list { list-style: none; margin: .75rem 0 0; padding: 0; display: flex; flex-direction: column; }
.ei-drawer__link, .ei-drawer__list a { display: block; padding: .7rem .25rem; color: var(--ei-ink); font-weight: 500; text-decoration: none; border-bottom: 1px solid var(--ei-line); }
.ei-drawer__link:hover { color: var(--ei-primary); }
.ei-drawer__cta { display: flex; justify-content: center; margin-top: 1rem; width: 100%; }

@media (min-width: 1024px) {
    .ei-nav { display: block; }
    .ei-find--header { display: block; }
    .ei-header__cta { display: inline-flex; }
    .ei-burger { display: none; }
    .ei-drawer { display: none !important; }
}

/* ===== Home Hero ===== */
.ei-hero { background: radial-gradient(120% 120% at 80% 0%, var(--ei-primary) 0%, var(--ei-primary-dark) 45%, var(--ei-primary-darker) 100%); color: #fff; position: relative; overflow: hidden; }
.ei-hero::after { content: ""; position: absolute; inset: 0; background-image: linear-gradient(rgba(255,255,255,.05) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.05) 1px, transparent 1px); background-size: 38px 38px; opacity: .5; pointer-events: none; }
.ei-hero__inner { position: relative; max-width: 880px; margin: 0 auto; padding: 5rem 1.25rem; text-align: center; }
.ei-hero__eyebrow { display: inline-block; font-size: .78rem; font-weight: 600; letter-spacing: .08em; text-transform: uppercase; color: #fff; background: rgba(255,255,255,.12); padding: .35rem .85rem; border-radius: 999px; margin-bottom: 1.4rem; }
.ei-hero__title { font-size: clamp(2rem, 5vw, 3.25rem); font-weight: 700; letter-spacing: -.025em; line-height: 1.08; }
.ei-hero__lead { margin: 1.4rem auto 0; max-width: 620px; font-size: 1.15rem; line-height: 1.6; color: rgba(255,255,255,.86); }
.ei-find--hero { max-width: 580px; margin: 2.25rem auto 0; }
.ei-find--hero .ei-find__input { padding: 1.05rem 7rem 1.05rem 2.9rem; font-size: 1rem; background: #fff; color: var(--ei-ink); border: 0; border-radius: 12px; box-shadow: var(--ei-shadow-lg); }
.ei-find--hero .ei-find__icon { left: 1.05rem; width: 1.25rem; height: 1.25rem; }
.ei-find__btn { position: absolute; right: .5rem; top: 50%; transform: translateY(-50%); background: var(--ei-accent); color: #fff; font-weight: 600; border: 0; border-radius: 9px; padding: .65rem 1.4rem; cursor: pointer; transition: background .15s; }
.ei-find__btn:hover { background: var(--ei-accent-dark); }
.ei-hero__cta-row { margin-top: 1.6rem; display: flex; justify-content: center; }
.ei-hero__stats { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 1.5rem; max-width: 520px; margin: 3rem auto 0; }
.ei-stat { text-align: center; }
.ei-stat__num { font-size: 1.9rem; font-weight: 700; color: #fff; }
.ei-stat__label { margin-top: .25rem; font-size: .85rem; color: rgba(255,255,255,.8); }

/* ===== Categories grid (offset / staggered card) ===== */
.ei-cat-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 1.1rem; }
.ei-cat-card { display: flex; align-items: center; gap: 1rem; min-width: 0; padding: 1.2rem; background: #fff; border: 1px solid var(--ei-line); border-radius: var(--ei-radius); text-decoration: none; transition: border-color .2s, box-shadow .2s, transform .2s; }
.ei-cat-card:hover { border-color: var(--ei-primary); box-shadow: var(--ei-shadow); transform: translateY(-2px); }
.ei-cat-card__icon { flex-shrink: 0; width: 3rem; height: 3rem; border-radius: 12px; display: flex; align-items: center; justify-content: center; }
.ei-cat-card__icon svg { width: 1.5rem; height: 1.5rem; }
.ei-cat-card__name { display: block; font-weight: 600; color: var(--ei-ink); overflow-wrap: anywhere; }
.ei-cat-card__count { display: block; font-size: .82rem; color: var(--ei-slate-light); margin-top: .15rem; }
@media (min-width: 768px) { .ei-cat-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); } }

/* ===== Features (horizontal rows, 2-up) ===== */
.ei-feature-grid { display: grid; grid-template-columns: 1fr; gap: 1.5rem; }
.ei-feature { display: flex; gap: 1.1rem; padding: 1.6rem; background: #fff; border: 1px solid var(--ei-line); border-radius: var(--ei-radius); }
.ei-feature__icon { flex-shrink: 0; width: 3rem; height: 3rem; border-radius: 12px; background: var(--ei-primary-soft); color: var(--ei-primary); display: flex; align-items: center; justify-content: center; }
.ei-feature__icon svg { width: 1.5rem; height: 1.5rem; }
.ei-feature__title { font-size: 1.12rem; font-weight: 600; color: var(--ei-ink); margin-bottom: .4rem; }
.ei-feature__desc { color: var(--ei-slate); line-height: 1.6; font-size: .96rem; }
@media (min-width: 768px) { .ei-feature-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); } }

/* ===== Template cards ===== */
.ei-card-grid { display: grid; grid-template-columns: 1fr; gap: 1.5rem; }
@media (min-width: 640px) { .ei-card-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); } }
@media (min-width: 1024px) { .ei-card-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); } }
.ei-card-grid--mini { gap: 1.1rem; }
@media (min-width: 768px) { .ei-card-grid--mini { grid-template-columns: repeat(2, minmax(0, 1fr)); } }
@media (min-width: 1024px) { .ei-card-grid--mini { grid-template-columns: repeat(4, minmax(0, 1fr)); } }

.ei-card { display: flex; flex-direction: column; background: #fff; border: 1px solid var(--ei-line); border-radius: var(--ei-radius); overflow: hidden; transition: box-shadow .2s, transform .2s, border-color .2s; }
.ei-card:hover { box-shadow: var(--ei-shadow); transform: translateY(-3px); border-color: #d4dad7; }
.ei-card__bar { height: 5px; width: 100%; }
.ei-card__body { padding: 1.35rem; display: flex; flex-direction: column; flex: 1; }
.ei-card__tag { align-self: flex-start; font-size: .72rem; font-weight: 600; padding: .25rem .65rem; border-radius: 999px; text-decoration: none; margin-bottom: .8rem; }
.ei-card__title { font-size: 1.05rem; font-weight: 600; line-height: 1.35; margin-bottom: .55rem; }
.ei-card__title a { color: var(--ei-ink); text-decoration: none; }
.ei-card__title a:hover { color: var(--ei-primary); }
.ei-card__desc { font-size: .9rem; color: var(--ei-slate-light); line-height: 1.55; margin-bottom: 1.1rem; flex: 1; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.ei-card__foot { display: flex; align-items: center; justify-content: space-between; font-size: .85rem; margin-top: auto; }
.ei-card__downloads { display: inline-flex; align-items: center; gap: .35rem; color: var(--ei-slate-light); }
.ei-card__downloads svg { width: 1rem; height: 1rem; }
.ei-card__link { color: var(--ei-primary); font-weight: 600; text-decoration: none; }
.ei-card__link:hover { color: var(--ei-primary-dark); }

.ei-card--mini { padding: 1.1rem; }
.ei-card--mini__link { text-decoration: none; display: block; }
.ei-card--mini__title { font-size: .98rem; font-weight: 600; color: var(--ei-ink); line-height: 1.35; margin-bottom: .75rem; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.ei-card--mini__link:hover .ei-card--mini__title { color: var(--ei-primary); }
.ei-card--mini__foot { display: flex; align-items: center; justify-content: space-between; font-size: .82rem; }
.ei-card--mini__free { color: var(--ei-primary); font-weight: 600; }

/* ===== FAQ ===== */
.ei-faq { display: flex; flex-direction: column; gap: .85rem; }
.ei-faq__item { background: #fff; border: 1px solid var(--ei-line); border-radius: 12px; overflow: hidden; }
.ei-faq__q { width: 100%; display: flex; align-items: center; justify-content: space-between; gap: 1rem; padding: 1.15rem 1.25rem; text-align: left; font-weight: 600; color: var(--ei-ink); background: transparent; border: 0; cursor: pointer; font-size: 1rem; }
.ei-faq__q:hover { background: var(--ei-bg-alt); }
.ei-faq__chevron { width: 1.25rem; height: 1.25rem; flex-shrink: 0; color: var(--ei-slate-light); transition: transform .2s; }
.faq-toggle[aria-expanded="true"] .ei-faq__chevron { transform: rotate(180deg); }
.ei-faq__a { padding: 0 1.25rem 1.25rem; color: var(--ei-slate); }

/* ===== Home CTA (dark band) ===== */
.ei-cta { background: linear-gradient(110deg, var(--ei-primary-darker), var(--ei-primary)); color: #fff; }
.ei-cta__inner { max-width: 760px; margin: 0 auto; padding: 4.5rem 1.25rem; text-align: center; }
.ei-cta__title { font-size: clamp(1.6rem, 3.5vw, 2.3rem); font-weight: 700; letter-spacing: -.02em; }
.ei-cta__lead { margin: 1rem auto 2rem; max-width: 560px; font-size: 1.1rem; color: rgba(255,255,255,.85); line-height: 1.6; }
.ei-cta__note { margin-top: 1.5rem; font-size: .85rem; color: rgba(255,255,255,.7); }

/* ===== Cookie consent ===== */
.ei-consent { position: fixed; left: 1rem; right: 1rem; bottom: 1rem; z-index: 60; background: #fff; border: 1px solid var(--ei-line); border-radius: var(--ei-radius); box-shadow: var(--ei-shadow-lg); }
.ei-consent.hidden { display: none; }
.ei-consent.show { display: block; animation: eiSlideUp .3s ease; }
.ei-consent__inner { max-width: 1100px; margin: 0 auto; padding: 1.1rem 1.35rem; display: flex; flex-direction: column; gap: 1rem; }
.ei-consent__text { font-size: .9rem; color: var(--ei-slate); line-height: 1.55; margin: 0; }
.ei-consent__link { color: var(--ei-primary); font-weight: 600; }
.ei-consent__actions { display: flex; gap: .65rem; }
.ei-consent__actions .ei-btn { padding: .6rem 1.15rem; font-size: .9rem; }
@media (min-width: 768px) { .ei-consent { left: auto; right: 1.5rem; bottom: 1.5rem; max-width: 560px; } .ei-consent__inner { flex-direction: row; align-items: center; } .ei-consent__actions { flex-shrink: 0; } }
@keyframes eiSlideUp { from { transform: translateY(20px); opacity: 0; } to { transform: translateY(0); opacity: 1; } }

/* ===== Single template (SEO landing) ===== */
.ei-tpl-hero { background: radial-gradient(110% 130% at 15% 0%, var(--ei-primary) 0%, var(--ei-primary-dark) 50%, var(--ei-primary-darker) 100%); color: #fff; padding: 3.5rem 0; }
.ei-tpl-hero__grid { display: grid; grid-template-columns: 1fr; gap: 2.5rem; align-items: center; }
@media (min-width: 1024px) { .ei-tpl-hero__grid { grid-template-columns: 1.1fr .9fr; } }
.ei-tpl-hero__cat { display: inline-block; font-size: .82rem; font-weight: 600; padding: .3rem .85rem; border-radius: 999px; background: rgba(255,255,255,.14); color: #fff; text-decoration: none; margin-bottom: 1.1rem; }
.ei-tpl-hero__cat:hover { background: rgba(255,255,255,.24); color: #fff; }
.ei-tpl-hero__title { font-size: clamp(1.8rem, 4vw, 2.85rem); font-weight: 700; letter-spacing: -.025em; line-height: 1.12; }
.ei-tpl-hero__lead { margin: 1.25rem 0; font-size: 1.1rem; color: rgba(255,255,255,.85); line-height: 1.6; }
.ei-tpl-hero__meta { list-style: none; margin: 0 0 1.6rem; padding: 0; display: flex; flex-wrap: wrap; gap: 1.25rem; }
.ei-tpl-hero__meta li { display: inline-flex; align-items: center; gap: .45rem; font-size: .9rem; color: rgba(255,255,255,.85); }
.ei-tpl-hero__meta svg { width: 1.1rem; height: 1.1rem; }
.ei-tpl-hero__shot { border-radius: var(--ei-radius); overflow: hidden; box-shadow: var(--ei-shadow-lg); border: 1px solid rgba(255,255,255,.15); }

/* byline */
.ei-byline { display: flex; flex-wrap: wrap; gap: 1.25rem; margin: 1.4rem 0; }
.ei-byline__item { display: inline-flex; align-items: center; gap: .55rem; }
.ei-byline__avatar img { width: 36px; height: 36px; max-width: none; border-radius: 50%; border: 2px solid rgba(255,255,255,.6); display: block; }
.ei-byline__txt { font-size: .88rem; font-weight: 500; color: #fff; }

/* download buttons */
.ei-dl-btn { display: inline-flex; align-items: center; justify-content: center; gap: .65rem; background: var(--ei-accent); color: #fff; font-weight: 600; text-decoration: none; border-radius: 11px; padding: .95rem 1.75rem; font-size: 1.05rem; transition: background .15s, transform .1s; box-shadow: 0 10px 24px -8px rgba(194,65,12,.5); }
.ei-dl-btn:hover { background: var(--ei-accent-dark); color: #fff; }
.ei-dl-btn svg { width: 1.35rem; height: 1.35rem; }
.ei-dl-btn--block { width: 100%; padding: .85rem 1.25rem; font-size: 1rem; }

/* content layout */
.ei-tpl-layout { display: grid; grid-template-columns: 1fr; gap: 2.5rem; }
@media (min-width: 1024px) { .ei-tpl-layout { grid-template-columns: minmax(0,1fr) 320px; align-items: start; } }
.ei-tpl-main { display: flex; flex-direction: column; gap: 2.75rem; min-width: 0; }
.ei-block__title { font-size: 1.5rem; font-weight: 700; color: var(--ei-ink); margin-bottom: 1.25rem; letter-spacing: -.015em; }
.ei-checklist { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 1rem; }
.ei-checklist li { display: flex; align-items: flex-start; gap: .75rem; }
.ei-checklist svg { width: 1.4rem; height: 1.4rem; flex-shrink: 0; color: var(--ei-primary); margin-top: .1rem; }
.ei-checklist span { color: var(--ei-slate); line-height: 1.55; }
.ei-funcs { display: grid; grid-template-columns: 1fr; gap: .9rem; }
@media (min-width: 768px) { .ei-funcs { grid-template-columns: repeat(2, minmax(0, 1fr)); } }
.ei-func { display: flex; align-items: center; gap: .7rem; padding: .95rem 1.1rem; background: var(--ei-bg-alt); border-radius: 11px; }
.ei-func svg { width: 1.25rem; height: 1.25rem; flex-shrink: 0; color: var(--ei-primary); }
.ei-func span { color: var(--ei-slate); font-size: .95rem; }

/* sidebar */
.ei-tpl-side { display: flex; flex-direction: column; gap: 1.25rem; }
@media (min-width: 1024px) { .ei-tpl-side { position: sticky; top: 5.5rem; } }
.ei-side-card { background: #fff; border: 1px solid var(--ei-line); border-radius: var(--ei-radius); padding: 1.5rem; box-shadow: var(--ei-shadow); }
.ei-side-card__title { font-size: 1.1rem; font-weight: 700; color: var(--ei-ink); margin-bottom: 1.1rem; }
.ei-side-card__specs { display: flex; flex-direction: column; gap: .7rem; margin: 0 0 1.3rem; }
.ei-side-card__specs div { display: flex; justify-content: space-between; font-size: .88rem; }
.ei-side-card__specs dt { color: var(--ei-slate-light); margin: 0; }
.ei-side-card__specs dd { margin: 0; font-weight: 600; color: var(--ei-ink); text-align: right; }
.ei-side-card__specs .ei-free { color: var(--ei-primary); }
.ei-side-card--cat { background: var(--ei-bg-alt); box-shadow: none; }
.ei-side-cat { display: flex; align-items: center; gap: .85rem; padding: .85rem; background: #fff; border-radius: 11px; text-decoration: none; }
.ei-side-cat:hover { box-shadow: var(--ei-shadow); }
.ei-side-cat__icon { width: 2.6rem; height: 2.6rem; border-radius: 10px; background: var(--ei-primary-soft); color: var(--ei-primary); display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.ei-side-cat__icon svg { width: 1.35rem; height: 1.35rem; }
.ei-side-cat__name { display: block; font-weight: 600; color: var(--ei-ink); }
.ei-side-cat__count { display: block; font-size: .82rem; color: var(--ei-slate-light); }

/* author box */
.ei-author { background: var(--ei-bg-alt); border: 1px solid var(--ei-line); border-radius: var(--ei-radius); padding: 1.75rem; }
.ei-author__heading { font-size: 1.25rem; font-weight: 700; color: var(--ei-ink); margin-bottom: 1.3rem; }
.ei-author__grid { display: grid; grid-template-columns: 1fr; gap: 1.5rem; }
@media (min-width: 640px) { .ei-author__grid { grid-template-columns: repeat(2, minmax(0, 1fr)); } }
.ei-author__card { display: flex; gap: 1rem; }
.ei-author__avatar img { width: 64px; height: 64px; max-width: none; border-radius: 50%; border: 2px solid #fff; box-shadow: var(--ei-shadow); display: block; }
.ei-author__name { font-weight: 700; color: var(--ei-ink); }
.ei-author__role { font-size: .82rem; color: var(--ei-primary); font-weight: 600; margin: .15rem 0 .4rem; }
.ei-author__bio { font-size: .88rem; color: var(--ei-slate); line-height: 1.55; }

/* ===== Archive ===== */
.ei-arch-hero { background: radial-gradient(110% 140% at 15% 0%, var(--ei-primary) 0%, var(--ei-primary-dark) 55%, var(--ei-primary-darker) 100%); color: #fff; padding: 3rem 0; }
.ei-arch-hero__title { font-size: clamp(1.8rem, 4vw, 2.6rem); font-weight: 700; letter-spacing: -.02em; }
.ei-arch-hero__lead { margin-top: .85rem; font-size: 1.1rem; color: rgba(255,255,255,.85); max-width: 640px; line-height: 1.55; }
.ei-arch-layout { display: grid; grid-template-columns: 1fr; gap: 2rem; }
@media (min-width: 1024px) { .ei-arch-layout { grid-template-columns: 260px minmax(0,1fr); align-items: start; } }
.ei-arch-side { display: flex; flex-direction: column; gap: 1.25rem; }
@media (min-width: 1024px) { .ei-arch-side { position: sticky; top: 5.5rem; } }
.ei-panel { background: #fff; border: 1px solid var(--ei-line); border-radius: var(--ei-radius); padding: 1.35rem; }
.ei-panel--filter { padding: 1.25rem; }
.ei-panel__label { font-size: .78rem; font-weight: 700; text-transform: uppercase; letter-spacing: .05em; color: var(--ei-slate-light); margin-bottom: .85rem; }
.ei-arch-search__input { width: 100%; padding: .65rem .9rem; border: 1px solid var(--ei-line); border-radius: 10px; font-size: .9rem; outline: none; }
.ei-arch-search__input:focus { border-color: var(--ei-primary); box-shadow: 0 0 0 3px rgba(14,107,92,.16); }
.ei-cat-filter { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: .25rem; }
.ei-cat-filter a { display: flex; align-items: center; justify-content: space-between; padding: .6rem .75rem; border-radius: 9px; text-decoration: none; color: var(--ei-slate); font-size: .92rem; }
.ei-cat-filter a:hover { background: var(--ei-bg-alt); }
.ei-cat-filter a.is-active { background: var(--ei-primary-soft); color: var(--ei-primary-dark); font-weight: 600; }
.ei-cat-filter__n { font-size: .8rem; color: var(--ei-slate-light); }
.ei-arch-count { color: var(--ei-slate); margin-bottom: 1.4rem; font-size: .95rem; }
.ei-empty { text-align: center; padding: 4rem 1rem; }
.ei-empty svg { width: 3rem; height: 3rem; color: var(--ei-slate-light); margin: 0 auto; }
.ei-empty h3 { margin-top: 1rem; font-size: 1.2rem; font-weight: 600; color: var(--ei-ink); }
.ei-empty p { margin-top: .5rem; color: var(--ei-slate-light); }

/* ===== Pagination ===== */
.ei-pagination { margin-top: 3rem; }
.ei-pagination .nav-links { display: flex; justify-content: center; gap: .5rem; flex-wrap: wrap; }
.ei-pagination .page-numbers { display: inline-flex; align-items: center; justify-content: center; min-width: 2.5rem; height: 2.5rem; padding: 0 .85rem; border: 1px solid var(--ei-line); border-radius: 9px; text-decoration: none; color: var(--ei-slate); background: #fff; }
.ei-pagination .page-numbers:hover { background: var(--ei-bg-alt); }
.ei-pagination .page-numbers.current { background: var(--ei-primary); color: #fff; border-color: var(--ei-primary); }

/* ===== Generic pages / legal docs ===== */
.ei-page { background: var(--ei-bg-alt); min-height: 60vh; }
.ei-page__crumbs { background: #fff; border-bottom: 1px solid var(--ei-line); padding: .9rem 0; }
.ei-page__body { padding: 3rem 1.25rem; }
.ei-panel--doc { padding: 2.25rem; }
@media (min-width: 768px) { .ei-panel--doc { padding: 3rem; } }
.ei-page__head { margin-bottom: 1.75rem; }
.ei-page__title { font-size: clamp(1.7rem, 3.5vw, 2.4rem); font-weight: 700; color: var(--ei-ink); letter-spacing: -.02em; }
.ei-page__updated { margin-top: .5rem; font-size: .85rem; color: var(--ei-slate-light); }

/* legal/about hero (used by page templates) */
.ei-doc-hero { background: radial-gradient(110% 140% at 20% 0%, var(--ei-primary) 0%, var(--ei-primary-dark) 55%, var(--ei-primary-darker) 100%); color: #fff; padding: 3.5rem 0; text-align: center; }
.ei-doc-hero__title { font-size: clamp(1.9rem, 4vw, 2.8rem); font-weight: 700; letter-spacing: -.02em; }
.ei-doc-hero__lead { margin: 1rem auto 0; max-width: 640px; font-size: 1.1rem; color: rgba(255,255,255,.85); line-height: 1.55; }
.ei-doc-hero__meta { margin-top: .85rem; font-size: .85rem; color: rgba(255,255,255,.7); }

/* breadcrumbs */
.ei-crumbs ol { list-style: none; margin: 0; padding: 0; display: flex; flex-wrap: wrap; align-items: center; gap: .25rem; font-size: .85rem; color: var(--ei-slate-light); }
.ei-crumbs a { color: var(--ei-slate); text-decoration: none; }
.ei-crumbs a:hover { color: var(--ei-primary); }
.ei-crumbs__sep { margin: 0 .4rem; color: var(--ei-slate-light); }
.ei-crumbs__current { color: var(--ei-ink); font-weight: 600; }

/* blog list */
.ei-blog { padding: 3rem 1.25rem; }
.ei-blog__list { display: flex; flex-direction: column; gap: 1.5rem; }
.ei-panel__title { font-size: 1.25rem; font-weight: 700; }
.ei-panel__title a { color: var(--ei-ink); text-decoration: none; }
.ei-panel__title a:hover { color: var(--ei-primary); }
.ei-panel__excerpt { margin-top: .6rem; color: var(--ei-slate); }

/* ===== Footer ===== */
.ei-footer { background: var(--ei-primary-darker); color: #cdd6d3; }
.ei-footer__inner { max-width: 1180px; margin: 0 auto; padding: 3.5rem 1.25rem 2rem; }
.ei-footer__top { display: grid; grid-template-columns: 1fr; gap: 2.5rem; }
@media (min-width: 900px) { .ei-footer__top { grid-template-columns: 1.4fr 2fr; } }
.ei-brand--footer .ei-brand-mark { color: #fff; }
.ei-wordmark--footer { color: #fff; }
.ei-wordmark--footer span { color: #9be3d3; }
.ei-footer__tagline { margin-top: 1rem; font-size: .92rem; color: #aebbb7; line-height: 1.55; max-width: 30rem; }
.ei-footer__disclaimer { margin-top: 1rem; font-size: .8rem; color: #8ea29c; line-height: 1.55; max-width: 32rem; }
.ei-footer__cols { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 2rem; }
@media (min-width: 640px) { .ei-footer__cols { grid-template-columns: repeat(3, minmax(0, 1fr)); } }
.ei-footer__heading { color: #fff; font-weight: 600; font-size: .95rem; margin-bottom: 1rem; }
.ei-footer__links { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: .6rem; }
.ei-footer__links a, .ei-footer .widget a { color: #c2cdc9; text-decoration: none; font-size: .92rem; transition: color .15s; }
.ei-footer__links a:hover, .ei-footer .widget a:hover { color: #fff; }
.ei-footer__bottom { margin-top: 3rem; padding-top: 1.75rem; border-top: 1px solid rgba(255,255,255,.12); display: flex; flex-direction: column; gap: .5rem; justify-content: space-between; font-size: .85rem; color: #93a39e; }
@media (min-width: 768px) { .ei-footer__bottom { flex-direction: row; align-items: center; } }
.ei-footer .widget-title { color: #fff; font-size: .95rem; text-transform: none; letter-spacing: 0; }

/* ===== Prose tweaks ===== */
.prose :where(a):not(:where([class~="not-prose"] *)) { color: var(--ei-primary); }
.prose :where(h2,h3,h4):not(:where([class~="not-prose"] *)) { color: var(--ei-ink); }

/* ===== Scroll to top ===== */
#scroll-to-top { position: fixed; bottom: 2rem; right: 2rem; width: 3rem; height: 3rem; background: var(--ei-primary); color: #fff; border: 0; border-radius: 50%; display: none; align-items: center; justify-content: center; cursor: pointer; box-shadow: var(--ei-shadow); transition: background .2s, transform .2s; z-index: 40; }
#scroll-to-top:hover { background: var(--ei-primary-dark); transform: translateY(-2px); }
#scroll-to-top.show { display: flex; }
#scroll-to-top svg { width: 1.4rem; height: 1.4rem; }

/* ===== Accessibility / misc ===== */
:focus-visible { outline: 2px solid var(--ei-primary); outline-offset: 2px; }
.download-btn { position: relative; overflow: hidden; }
.hidden { display: none !important; }
@media print { .ei-header, .ei-footer, .ei-dl-btn, #cookie-banner, #scroll-to-top { display: none !important; } body { font-size: 12pt; } }
@media (prefers-reduced-motion: reduce) { *, *::before, *::after { animation-duration: .01ms !important; transition-duration: .01ms !important; } }

/* =====================================================
   EXCEL MOCKUP STYLES (kept from engine)
   ===================================================== */
.excel-mockup-container { position: relative; transform: perspective(1000px) rotateY(-5deg) rotateX(2deg); transition: transform 0.3s ease; }
.excel-mockup-container:hover { transform: perspective(1000px) rotateY(-2deg) rotateX(1deg); }
.excel-window { background: #f3f3f3; border-radius: 8px; overflow: hidden; box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.4); font-family: 'Segoe UI', system-ui, -apple-system, sans-serif; font-size: 11px; }
.excel-titlebar { display: flex; justify-content: space-between; align-items: center; background: linear-gradient(180deg, #217346 0%, #1a5c38 100%); padding: 6px 12px; color: white; }
.excel-titlebar-left { display: flex; align-items: center; gap: 8px; }
.excel-icon { width: 18px; height: 18px; }
.excel-filename { font-size: 12px; font-weight: 500; opacity: 0.95; }
.excel-titlebar-buttons { display: flex; gap: 8px; }
.excel-btn { width: 12px; height: 12px; border-radius: 50%; }
.excel-btn.minimize { background: #f5c242; }
.excel-btn.maximize { background: #3dc04f; }
.excel-btn.close { background: #ed594a; }
.excel-ribbon { background: #217346; padding: 4px 12px; border-bottom: 1px solid #1a5c38; }
.excel-ribbon-tabs { display: flex; gap: 16px; color: white; font-size: 11px; }
.excel-ribbon-tabs span { padding: 4px 0; opacity: 0.7; cursor: pointer; }
.excel-ribbon-tabs span.active { opacity: 1; border-bottom: 2px solid white; }
.excel-formula-bar { display: flex; align-items: center; background: white; border-bottom: 1px solid #d6d6d6; padding: 4px 8px; gap: 8px; }
.excel-cell-ref { min-width: 50px; padding: 2px 6px; background: #f5f5f5; border: 1px solid #d6d6d6; font-size: 10px; text-align: center; }
.excel-fx { color: #666; font-style: italic; font-size: 10px; }
.excel-formula-input { flex: 1; padding: 2px 6px; background: white; border: 1px solid #d6d6d6; font-size: 10px; color: #333; min-height: 18px; }
.excel-sheet-area { background: white; overflow: hidden; }
.excel-grid { display: grid; grid-template-columns: 30px repeat(5, minmax(0, 1fr)); border: 1px solid #d6d6d6; }
.excel-corner { background: #f5f5f5; border-right: 1px solid #c0c0c0; border-bottom: 1px solid #c0c0c0; }
.excel-col-header { background: #f5f5f5; border-right: 1px solid #c0c0c0; border-bottom: 1px solid #c0c0c0; padding: 4px; text-align: center; font-weight: 500; color: #333; }
.excel-row-header { background: #f5f5f5; border-right: 1px solid #c0c0c0; border-bottom: 1px solid #c0c0c0; padding: 4px; text-align: center; font-weight: 500; color: #333; }
.excel-cell { border-right: 1px solid #e0e0e0; border-bottom: 1px solid #e0e0e0; padding: 4px 6px; min-height: 22px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; color: #333; }
.excel-cell.header-cell { background: #217346; color: white; font-weight: 600; }
.excel-cell.number-cell { text-align: right; font-variant-numeric: tabular-nums; }
.excel-cell.currency-cell { text-align: right; color: #1a5c38; font-weight: 500; }
.excel-cell.total-label { font-weight: 600; text-align: right; }
.excel-cell.total-cell { font-weight: 700; text-align: right; background: #f0f7f4; }
.excel-cell.total-cell.highlight { background: #d4edda; color: #155724; }
.excel-cell.positive { color: #28a745; }
.excel-cell.warning { color: #ffc107; }
.excel-cell.critical { color: #dc3545; font-weight: 600; }
.excel-sheet-tabs { display: flex; align-items: flex-end; background: #e0e0e0; padding: 4px 8px 0; gap: 2px; }
.excel-sheet-tab { background: #f5f5f5; padding: 4px 12px; border-radius: 4px 4px 0 0; font-size: 10px; color: #666; cursor: pointer; border: 1px solid #c0c0c0; border-bottom: none; }
.excel-sheet-tab.active { background: white; color: #333; font-weight: 500; }
.excel-sheet-tab-add { padding: 4px 8px; color: #888; cursor: pointer; font-size: 12px; }
.excel-status-bar { display: flex; justify-content: space-between; align-items: center; background: #217346; padding: 3px 12px; color: white; font-size: 10px; }
.excel-status-left { opacity: 0.9; }
.excel-zoom { opacity: 0.8; }
.excel-mockup-shadow { position: absolute; bottom: -15px; left: 10%; right: 10%; height: 20px; background: radial-gradient(ellipse at center, rgba(0,0,0,0.2) 0%, transparent 70%); filter: blur(8px); z-index: -1; }
.excel-mockup-reflection { position: absolute; top: 0; left: 0; right: 0; height: 40%; background: linear-gradient(180deg, rgba(255,255,255,0.1) 0%, transparent 100%); pointer-events: none; border-radius: 8px 8px 0 0; }
.excel-preview-notice { display: flex; align-items: flex-start; gap: 10px; margin-top: 16px; padding: 12px 16px; background: rgba(255, 255, 255, 0.1); border-radius: 8px; backdrop-filter: blur(4px); }
.excel-preview-notice .notice-icon { width: 20px; height: 20px; flex-shrink: 0; color: rgba(255, 255, 255, 0.8); margin-top: 2px; }
.excel-preview-notice p { margin: 0; font-size: 13px; color: rgba(255, 255, 255, 0.85); line-height: 1.5; }
.excel-preview-notice strong { color: white; }

/* =====================================================
   TAILWIND BLUE OVERRIDE SAFETY NET
   (covers any blue-* utility still emitted, e.g. legal pages
   before full migration). Nothing Tailwind-blue should show.
   ===================================================== */
.bg-blue-600, .bg-blue-700, .bg-blue-800, .bg-blue-900 { background-color: var(--ei-primary) !important; }
.from-blue-600, .from-blue-700, .from-blue-800, .from-blue-900,
.via-blue-700, .via-blue-800, .to-blue-600, .to-blue-700, .to-blue-800 { --tw-gradient-from: var(--ei-primary) !important; --tw-gradient-to: var(--ei-primary-darker) !important; --tw-gradient-stops: var(--ei-primary), var(--ei-primary-darker) !important; }
.bg-gradient-to-br, .bg-gradient-to-r { background-image: linear-gradient(120deg, var(--ei-primary), var(--ei-primary-darker)) !important; }
.text-blue-600, .text-blue-700, .text-blue-800, .text-blue-900 { color: var(--ei-primary) !important; }
.text-blue-100, .text-blue-200 { color: rgba(255,255,255,.85) !important; }
.bg-blue-50, .bg-blue-100 { background-color: var(--ei-primary-soft) !important; }
.border-blue-200 { border-color: #cfe3de !important; }
.hover\:bg-blue-700:hover, .hover\:bg-blue-600:hover { background-color: var(--ei-primary-dark) !important; }
.hover\:bg-blue-50:hover { background-color: var(--ei-primary-soft) !important; }
.hover\:text-blue-700:hover, .hover\:text-blue-600:hover { color: var(--ei-primary-dark) !important; }
.focus\:ring-blue-500:focus, .focus\:border-blue-500:focus { --tw-ring-color: var(--ei-primary) !important; border-color: var(--ei-primary) !important; }

/* Fix overflow móvil: permitir que el contenido de las tarjetas y el banner encojan */
.ei-cat-card__body{min-width:0}
.ei-consent__inner{min-width:0}
.ei-consent__text{overflow-wrap:anywhere}

/* AVATAR FIX móvil: evitar que flex + img{max-width:100%} aplaste los avatares */
.ei-author__avatar, .ei-byline__avatar, .ei-byline__item img, .ei-author__card img { flex-shrink: 0; }
.ei-author__avatar img, .ei-byline__avatar img, .avatar { max-width: none; }
.ei-author__info { min-width: 0; }

/* MOBILE-AVATAR-FIX: img.avatar max-width:100% + flex aplastaba los avatares */
img.avatar{max-width:none;flex-shrink:0;align-self:center}
[class*="__avatar"]{flex-shrink:0}
