:root {
    --color-fondo: #f5f1e8;
    --color-superficie: #ffffff;
    --color-tinta: #14202a;
    --color-texto: #3f4850;
    --color-muted: #737b82;
    --color-linea: rgba(20, 32, 42, 0.12);
    --color-azul: #101820;
    --color-azul-2: #162536;
    --color-dorado: #b8955a;
    --color-dorado-2: #d7bd82;
    --sombra: 0 24px 70px rgba(16, 24, 32, 0.12);
    --sombra-suave: 0 16px 40px rgba(16, 24, 32, 0.08);
    --radio: 26px;
    --contenedor: 1180px;
}

* {
    box-sizing: border-box;
}

html {
    scroll-behavior: smooth;
}

body {
    margin: 0;
    font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    color: var(--color-tinta);
    background: var(--color-fondo);
    line-height: 1.6;
}

body::before {
    content: "";
    position: fixed;
    inset: 0;
    z-index: -2;
    background:
        radial-gradient(circle at 12% 10%, rgba(184, 149, 90, 0.22), transparent 32%),
        radial-gradient(circle at 80% 0%, rgba(16, 37, 54, 0.16), transparent 28%),
        linear-gradient(135deg, #f7f3eb 0%, #eee7da 48%, #f9f7f1 100%);
}

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

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

.header {
    position: sticky;
    top: 0;
    z-index: 50;
    background: rgba(245, 241, 232, 0.86);
    backdrop-filter: blur(20px);
    border-bottom: 1px solid transparent;
    transition: border-color 0.25s ease, box-shadow 0.25s ease, background 0.25s ease;
}

.header.is-scrolled {
    background: rgba(245, 241, 232, 0.96);
    border-bottom-color: var(--color-linea);
    box-shadow: 0 16px 36px rgba(16, 24, 32, 0.08);
}

.header__contenido {
    display: flex;
    align-items: center;
    justify-content: space-between;
    min-height: 88px;
    gap: 24px;
}

.marca {
    display: inline-flex;
    align-items: center;
    gap: 14px;
    min-width: max-content;
}

.marca__simbolo {
    width: 54px;
    height: 54px;
    border-radius: 18px;
    display: grid;
    place-items: center;
    color: #fff;
    font-weight: 900;
    letter-spacing: -0.06em;
    background: linear-gradient(145deg, var(--color-azul), var(--color-azul-2));
    box-shadow: 0 16px 32px rgba(16, 24, 32, 0.22), inset 0 0 0 1px rgba(215, 189, 130, 0.24);
}

.marca__texto {
    display: grid;
    line-height: 1.15;
}

.marca__texto strong {
    font-size: 1.05rem;
    letter-spacing: -0.02em;
}

.marca__texto small {
    color: var(--color-muted);
    font-size: 0.78rem;
}

.nav {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 6px;
    font-size: 0.92rem;
    color: var(--color-texto);
}

.nav a {
    position: relative;
    padding: 10px 12px;
    border-radius: 999px;
    transition: color 0.2s ease, background 0.2s ease;
}

.nav a::after {
    content: "";
    position: absolute;
    left: 14px;
    right: 14px;
    bottom: 6px;
    height: 2px;
    transform: scaleX(0);
    transform-origin: center;
    background: var(--color-dorado);
    transition: transform 0.2s ease;
}

.nav a:hover,
.nav a.is-active {
    color: var(--color-azul);
    background: rgba(184, 149, 90, 0.1);
}

.nav a:hover::after,
.nav a.is-active::after {
    transform: scaleX(1);
}

.nav .nav__privado {
    margin-left: 8px;
    color: #fff;
    background: var(--color-azul);
    box-shadow: 0 12px 28px rgba(16, 24, 32, 0.16);
}

.nav .nav__privado:hover {
    color: #fff;
    background: #1b2f43;
}

.nav-toggle {
    display: none;
    width: 46px;
    height: 46px;
    border: 0;
    border-radius: 14px;
    background: var(--color-azul);
    cursor: pointer;
    padding: 13px;
}

.nav-toggle span {
    display: block;
    height: 2px;
    margin: 5px 0;
    background: #fff;
    border-radius: 999px;
}

.hero,
.page-hero {
    position: relative;
    overflow: hidden;
    padding: 96px 0 82px;
}

.hero::after,
.page-hero::after {
    content: "";
    position: absolute;
    inset: 54px 0 auto auto;
    width: min(44vw, 560px);
    height: 420px;
    border-radius: 80px 0 0 80px;
    background: linear-gradient(145deg, rgba(16, 24, 32, 0.11), rgba(184, 149, 90, 0.12));
    z-index: -1;
}

.hero__grid,
.page-hero__grid {
    display: grid;
    grid-template-columns: minmax(0, 1.15fr) minmax(320px, 0.85fr);
    align-items: center;
    gap: 56px;
}

.hero__contenido h1,
.page-hero h1 {
    margin: 18px 0 22px;
    max-width: 820px;
    font-size: clamp(2.55rem, 6vw, 5.2rem);
    line-height: 0.95;
    letter-spacing: -0.07em;
}

.hero__contenido p,
.page-hero p {
    max-width: 670px;
    margin: 0;
    color: var(--color-texto);
    font-size: clamp(1rem, 1.6vw, 1.18rem);
}

.etiqueta {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    color: var(--color-dorado);
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    font-size: 0.74rem;
}

.etiqueta::before {
    content: "";
    width: 34px;
    height: 1px;
    background: currentColor;
}

.hero__acciones,
.cta__acciones {
    display: flex;
    flex-wrap: wrap;
    gap: 14px;
    margin-top: 34px;
}

.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 48px;
    padding: 13px 22px;
    border-radius: 999px;
    font-weight: 800;
    border: 1px solid transparent;
    transition: transform 0.2s ease, box-shadow 0.2s ease, background 0.2s ease, color 0.2s ease, border-color 0.2s ease;
}

.btn:hover {
    transform: translateY(-2px);
}

.btn--principal {
    color: #fff;
    background: linear-gradient(135deg, var(--color-azul), #20364c);
    box-shadow: 0 18px 36px rgba(16, 24, 32, 0.24);
}

.btn--secundario {
    color: var(--color-azul);
    background: rgba(255, 255, 255, 0.58);
    border-color: rgba(184, 149, 90, 0.34);
}

.btn--claro {
    color: var(--color-azul);
    background: var(--color-dorado-2);
}

.hero__panel {
    display: grid;
    gap: 18px;
    padding: 22px;
    border-radius: 34px;
    background: rgba(255, 255, 255, 0.56);
    border: 1px solid rgba(255, 255, 255, 0.72);
    box-shadow: var(--sombra);
    backdrop-filter: blur(18px);
}

.panel-card,
.page-hero__panel {
    padding: 24px;
    border-radius: 24px;
    background: rgba(255, 255, 255, 0.78);
    border: 1px solid rgba(20, 32, 42, 0.09);
}

.panel-card--principal {
    min-height: 210px;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    color: #fff;
    background:
        linear-gradient(145deg, rgba(16, 24, 32, 0.92), rgba(26, 47, 66, 0.94)),
        radial-gradient(circle at top right, rgba(215, 189, 130, 0.45), transparent 42%);
}

.panel-card span,
.page-hero__panel span {
    display: block;
    margin-bottom: 8px;
    color: var(--color-muted);
    font-size: 0.86rem;
}

.panel-card--principal span {
    color: rgba(255, 255, 255, 0.7);
}

.panel-card strong,
.page-hero__panel strong {
    display: block;
    font-size: clamp(1.25rem, 2vw, 1.75rem);
    line-height: 1.12;
    letter-spacing: -0.04em;
}

.seccion {
    padding: 88px 0;
}

.seccion--confianza {
    padding-top: 40px;
}

.bloque-titulo,
.seccion__cabecera {
    max-width: 820px;
    margin-bottom: 34px;
}

.bloque-titulo h2,
.seccion__cabecera h2,
.portafolio__contenido h2,
.cta h2,
.area-card h2,
.proceso-grid h2 {
    margin: 12px 0 0;
    font-size: clamp(2rem, 4vw, 3.45rem);
    line-height: 1;
    letter-spacing: -0.06em;
}

.seccion__cabecera {
    max-width: none;
    display: flex;
    justify-content: space-between;
    align-items: end;
    gap: 24px;
}

.link-elegante {
    color: var(--color-azul);
    font-weight: 900;
    border-bottom: 2px solid var(--color-dorado);
    padding-bottom: 4px;
}

.confianza-grid,
.cards-grid,
.noticias-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 18px;
}

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

.confianza-card,
.servicio-card,
.noticia-card {
    min-height: 210px;
    padding: 28px;
    border-radius: var(--radio);
    background: rgba(255, 255, 255, 0.68);
    border: 1px solid rgba(255, 255, 255, 0.78);
    box-shadow: var(--sombra-suave);
    transition: transform 0.22s ease, box-shadow 0.22s ease, border-color 0.22s ease;
}

.confianza-card:hover,
.servicio-card:hover,
.noticia-card:hover,
.area-card:hover {
    transform: translateY(-5px);
    box-shadow: var(--sombra);
    border-color: rgba(184, 149, 90, 0.36);
}

.confianza-card__icono {
    display: block;
    width: 42px;
    height: 42px;
    margin-bottom: 24px;
    border-radius: 16px;
    background: linear-gradient(135deg, var(--color-azul), var(--color-dorado));
}

.servicio-card span,
.noticia-card span {
    color: var(--color-dorado);
    font-weight: 900;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    font-size: 0.78rem;
}

.servicio-card h3,
.noticia-card h3 {
    margin: 16px 0 12px;
    font-size: 1.38rem;
    line-height: 1.08;
    letter-spacing: -0.04em;
}

.servicio-card p,
.noticia-card p,
.portafolio__contenido p,
.cta p,
.area-card p {
    color: var(--color-texto);
    margin: 0;
}

.servicio-card a {
    display: inline-block;
    margin-top: 22px;
    color: var(--color-azul);
    font-weight: 900;
}

.seccion--oscura {
    color: #fff;
    background:
        radial-gradient(circle at 15% 0%, rgba(184, 149, 90, 0.22), transparent 34%),
        linear-gradient(135deg, #101820, #182a3c 60%, #0c131b);
}

.bloque-titulo--claro .etiqueta,
.seccion--oscura .etiqueta {
    color: var(--color-dorado-2);
}

.nosotros-grid,
.proceso-grid {
    display: grid;
    grid-template-columns: 0.95fr 1.05fr;
    gap: 56px;
    align-items: center;
}

.texto-destacado {
    padding: 34px;
    border-radius: 30px;
    background: rgba(255, 255, 255, 0.08);
    border: 1px solid rgba(255, 255, 255, 0.12);
}

.texto-destacado p {
    margin: 0;
    color: rgba(255, 255, 255, 0.82);
    font-size: 1.08rem;
}

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

.portafolio__lista,
.proceso-lista {
    display: grid;
    gap: 14px;
}

.portafolio__lista div,
.proceso-lista div {
    display: grid;
    grid-template-columns: 72px 1fr;
    align-items: center;
    gap: 18px;
    padding: 22px;
    border-radius: 22px;
    background: rgba(255, 255, 255, 0.68);
    border: 1px solid rgba(255, 255, 255, 0.78);
    box-shadow: var(--sombra-suave);
}

.proceso-lista div {
    color: #fff;
    background: rgba(255, 255, 255, 0.08);
    border-color: rgba(255, 255, 255, 0.12);
    box-shadow: none;
}

.portafolio__lista strong,
.proceso-lista strong {
    color: var(--color-dorado);
    font-size: 1.4rem;
    letter-spacing: -0.04em;
}

.proceso-lista strong {
    color: var(--color-dorado-2);
}

.cta {
    padding: 80px 0;
}

.cta__contenido {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 36px;
    padding: 42px;
    border-radius: 36px;
    background: rgba(255, 255, 255, 0.72);
    border: 1px solid rgba(255, 255, 255, 0.82);
    box-shadow: var(--sombra);
}

.cta__contenido > div:first-child {
    max-width: 690px;
}

.footer {
    color: rgba(255, 255, 255, 0.78);
    background: #0e1720;
    padding: 54px 0 24px;
}

.footer__grid {
    display: grid;
    grid-template-columns: 1.3fr 0.8fr 0.8fr 0.8fr;
    gap: 28px;
}

.footer strong {
    color: #fff;
    font-size: 1.12rem;
}

.footer span {
    display: block;
    margin-bottom: 8px;
    color: var(--color-dorado-2);
    font-weight: 900;
    font-size: 0.78rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.footer a:hover {
    color: #fff;
}

.footer__copy {
    margin-top: 34px;
    padding-top: 22px;
    border-top: 1px solid rgba(255, 255, 255, 0.1);
    font-size: 0.88rem;
}

.whatsapp-flotante {
    position: fixed;
    right: 22px;
    bottom: 22px;
    z-index: 60;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 122px;
    min-height: 48px;
    padding: 12px 18px;
    border-radius: 999px;
    color: #fff;
    background: #178c52;
    font-weight: 900;
    box-shadow: 0 18px 42px rgba(23, 140, 82, 0.34);
}

.page-hero {
    padding-bottom: 64px;
}

.page-hero__panel {
    min-height: 220px;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    color: #fff;
    background:
        linear-gradient(145deg, rgba(16, 24, 32, 0.94), rgba(26, 47, 66, 0.96)),
        radial-gradient(circle at top right, rgba(215, 189, 130, 0.36), transparent 44%);
    box-shadow: var(--sombra);
}

.page-hero__panel span {
    color: rgba(255, 255, 255, 0.72);
}

.servicios-detalle {
    display: grid;
    gap: 20px;
}

.area-card {
    display: grid;
    grid-template-columns: 110px 1fr;
    gap: 28px;
    padding: 34px;
    border-radius: 32px;
    background: rgba(255, 255, 255, 0.72);
    border: 1px solid rgba(255, 255, 255, 0.82);
    box-shadow: var(--sombra-suave);
    transition: transform 0.22s ease, box-shadow 0.22s ease, border-color 0.22s ease;
}

.area-card__numero {
    width: 82px;
    height: 82px;
    border-radius: 26px;
    display: grid;
    place-items: center;
    color: #fff;
    font-weight: 900;
    font-size: 1.35rem;
    background: linear-gradient(145deg, var(--color-azul), #20364c);
    box-shadow: 0 16px 32px rgba(16, 24, 32, 0.2);
}

.area-card h2 {
    margin-top: 0;
    font-size: clamp(1.8rem, 3vw, 2.75rem);
}

.area-card ul {
    display: grid;
    gap: 10px;
    margin: 24px 0 0;
    padding: 0;
    list-style: none;
}

.area-card li {
    position: relative;
    padding-left: 28px;
    color: var(--color-texto);
}

.area-card li::before {
    content: "";
    position: absolute;
    left: 0;
    top: 0.72em;
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: var(--color-dorado);
}

.reveal {
    opacity: 0;
    transform: translateY(18px);
    transition: opacity 0.55s ease, transform 0.55s ease;
}

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

@media (max-width: 1080px) {
    .nav-toggle {
        display: block;
    }

    .nav {
        position: fixed;
        left: 20px;
        right: 20px;
        top: 88px;
        display: none;
        flex-direction: column;
        align-items: stretch;
        gap: 8px;
        padding: 18px;
        border-radius: 24px;
        background: rgba(255, 255, 255, 0.96);
        box-shadow: var(--sombra);
    }

    .nav.is-open {
        display: flex;
    }

    .nav .nav__privado {
        margin-left: 0;
        text-align: center;
    }

    .hero__grid,
    .page-hero__grid,
    .nosotros-grid,
    .portafolio,
    .proceso-grid {
        grid-template-columns: 1fr;
    }

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

    .footer__grid {
        grid-template-columns: 1fr 1fr;
    }
}

@media (max-width: 720px) {
    .contenedor {
        width: min(100% - 28px, var(--contenedor));
    }

    .header__contenido {
        min-height: 76px;
    }

    .marca__texto small {
        display: none;
    }

    .hero,
    .page-hero {
        padding: 60px 0 52px;
    }

    .seccion {
        padding: 62px 0;
    }

    .confianza-grid,
    .cards-grid,
    .noticias-grid {
        grid-template-columns: 1fr;
    }

    .seccion__cabecera,
    .cta__contenido {
        display: grid;
        align-items: start;
    }

    .area-card {
        grid-template-columns: 1fr;
        padding: 26px;
    }

    .footer__grid {
        grid-template-columns: 1fr;
    }

    .whatsapp-flotante {
        right: 14px;
        bottom: 14px;
    }
}

.seccion--compacta {
    padding-top: 0;
}

.equipo-presentacion {
    display: grid;
    grid-template-columns: 0.95fr 1.05fr;
    gap: 54px;
    align-items: center;
    padding: 38px;
    border-radius: 34px;
    background: rgba(255, 255, 255, 0.7);
    border: 1px solid rgba(255, 255, 255, 0.82);
    box-shadow: var(--sombra-suave);
}

.equipo-presentacion h2,
.metodo-grid h2 {
    margin: 12px 0 0;
    font-size: clamp(2rem, 4vw, 3.45rem);
    line-height: 1;
    letter-spacing: -0.06em;
}

.equipo-presentacion p,
.principio-card p,
.rol-card p {
    margin: 0;
    color: var(--color-texto);
}

.principios-grid,
.roles-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 18px;
}

.principio-card,
.rol-card {
    min-height: 250px;
    padding: 30px;
    border-radius: var(--radio);
    background: rgba(255, 255, 255, 0.7);
    border: 1px solid rgba(255, 255, 255, 0.82);
    box-shadow: var(--sombra-suave);
    transition: transform 0.22s ease, box-shadow 0.22s ease, border-color 0.22s ease;
}

.principio-card:hover,
.rol-card:hover {
    transform: translateY(-5px);
    box-shadow: var(--sombra);
    border-color: rgba(184, 149, 90, 0.36);
}

.principio-card span {
    display: grid;
    place-items: center;
    width: 56px;
    height: 56px;
    margin-bottom: 24px;
    border-radius: 18px;
    color: #fff;
    font-weight: 900;
    background: linear-gradient(145deg, var(--color-azul), #20364c);
}

.principio-card h3,
.rol-card h3 {
    margin: 0 0 14px;
    font-size: 1.45rem;
    line-height: 1.08;
    letter-spacing: -0.04em;
}

.rol-card {
    color: #fff;
    background: rgba(255, 255, 255, 0.08);
    border-color: rgba(255, 255, 255, 0.12);
    box-shadow: none;
}

.rol-card p {
    color: rgba(255, 255, 255, 0.78);
}

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

.metodo-lista {
    display: grid;
    gap: 14px;
}

.metodo-lista div {
    display: grid;
    grid-template-columns: 72px 1fr;
    gap: 18px;
    align-items: center;
    padding: 22px;
    border-radius: 22px;
    background: rgba(255, 255, 255, 0.7);
    border: 1px solid rgba(255, 255, 255, 0.82);
    box-shadow: var(--sombra-suave);
}

.metodo-lista strong {
    color: var(--color-dorado);
    font-size: 1.4rem;
    letter-spacing: -0.04em;
}

@media (max-width: 1080px) {
    .equipo-presentacion,
    .metodo-grid {
        grid-template-columns: 1fr;
    }

    .principios-grid,
    .roles-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 720px) {
    .equipo-presentacion {
        padding: 26px;
    }

    .metodo-lista div {
        grid-template-columns: 1fr;
    }
}

.portafolio-indicadores {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 18px;
}

.portafolio-indicadores article {
    min-height: 150px;
    padding: 28px;
    border-radius: var(--radio);
    background: rgba(255, 255, 255, 0.72);
    border: 1px solid rgba(255, 255, 255, 0.82);
    box-shadow: var(--sombra-suave);
}

.portafolio-indicadores strong {
    display: block;
    margin-bottom: 10px;
    color: var(--color-azul);
    font-size: clamp(2rem, 4vw, 3rem);
    line-height: 1;
    letter-spacing: -0.06em;
}

.portafolio-indicadores span {
    color: var(--color-texto);
    font-weight: 800;
}

.portafolio-detalle {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 20px;
}

.portafolio-card {
    display: grid;
    grid-template-columns: 78px 1fr;
    gap: 22px;
    min-height: 330px;
    padding: 30px;
    border-radius: 32px;
    background: rgba(255, 255, 255, 0.72);
    border: 1px solid rgba(255, 255, 255, 0.82);
    box-shadow: var(--sombra-suave);
    transition: transform 0.22s ease, box-shadow 0.22s ease, border-color 0.22s ease;
}

.portafolio-card:hover {
    transform: translateY(-5px);
    box-shadow: var(--sombra);
    border-color: rgba(184, 149, 90, 0.36);
}

.portafolio-card__numero {
    width: 64px;
    height: 64px;
    display: grid;
    place-items: center;
    border-radius: 20px;
    color: #fff;
    font-weight: 900;
    background: linear-gradient(145deg, var(--color-azul), #20364c);
    box-shadow: 0 16px 32px rgba(16, 24, 32, 0.2);
}

.portafolio-card h3 {
    margin: 0 0 14px;
    font-size: clamp(1.55rem, 2.6vw, 2.25rem);
    line-height: 1;
    letter-spacing: -0.05em;
}

.portafolio-card p,
.portafolio-nota p {
    margin: 0;
    color: var(--color-texto);
}

.portafolio-card ul {
    display: grid;
    gap: 10px;
    margin: 24px 0 0;
    padding: 0;
    list-style: none;
}

.portafolio-card li {
    position: relative;
    padding-left: 28px;
    color: var(--color-texto);
}

.portafolio-card li::before {
    content: "";
    position: absolute;
    left: 0;
    top: 0.72em;
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: var(--color-dorado);
}

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

.criterio-lista {
    display: grid;
    gap: 14px;
}

.criterio-lista div {
    display: grid;
    grid-template-columns: 72px 1fr;
    gap: 18px;
    align-items: center;
    padding: 22px;
    border-radius: 22px;
    color: #fff;
    background: rgba(255, 255, 255, 0.08);
    border: 1px solid rgba(255, 255, 255, 0.12);
}

.criterio-lista strong {
    color: var(--color-dorado-2);
    font-size: 1.4rem;
    letter-spacing: -0.04em;
}

.criterio-lista span {
    color: rgba(255, 255, 255, 0.8);
}

.portafolio-nota {
    display: grid;
    grid-template-columns: 0.95fr 1.05fr;
    gap: 54px;
    align-items: center;
    padding: 38px;
    border-radius: 34px;
    background: rgba(255, 255, 255, 0.7);
    border: 1px solid rgba(255, 255, 255, 0.82);
    box-shadow: var(--sombra-suave);
}

.portafolio-nota h2 {
    margin: 12px 0 0;
    font-size: clamp(2rem, 4vw, 3.45rem);
    line-height: 1;
    letter-spacing: -0.06em;
}

@media (max-width: 1080px) {
    .portafolio-detalle,
    .criterio-grid,
    .portafolio-nota {
        grid-template-columns: 1fr;
    }

    .portafolio-indicadores {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 720px) {
    .portafolio-card,
    .criterio-lista div {
        grid-template-columns: 1fr;
    }

    .portafolio-card,
    .portafolio-nota {
        padding: 26px;
    }
}

.publicaciones-destacadas {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 20px;
}

.publicacion-destacada {
    min-height: 300px;
    padding: 34px;
    border-radius: 32px;
    background: rgba(255, 255, 255, 0.72);
    border: 1px solid rgba(255, 255, 255, 0.82);
    box-shadow: var(--sombra-suave);
    transition: transform 0.22s ease, box-shadow 0.22s ease, border-color 0.22s ease;
}

.publicacion-destacada:hover,
.categoria-juridica-card:hover,
.publicacion-card:hover {
    transform: translateY(-5px);
    box-shadow: var(--sombra);
    border-color: rgba(184, 149, 90, 0.36);
}

.publicacion-destacada > div {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 16px;
    margin-bottom: 26px;
}

.publicacion-destacada span,
.categoria-juridica-card span,
.publicacion-card span {
    color: var(--color-dorado);
    font-weight: 900;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    font-size: 0.78rem;
}

.publicacion-destacada small {
    color: var(--color-muted);
    font-weight: 800;
}

.publicacion-destacada h2 {
    margin: 0 0 16px;
    font-size: clamp(1.7rem, 3vw, 2.65rem);
    line-height: 1;
    letter-spacing: -0.06em;
}

.publicacion-destacada p,
.categoria-juridica-card p,
.publicacion-card p,
.criterio-editorial span {
    margin: 0;
    color: var(--color-texto);
}

.categorias-juridicas {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 18px;
}

.categoria-juridica-card {
    min-height: 260px;
    padding: 30px;
    border-radius: var(--radio);
    background: rgba(255, 255, 255, 0.72);
    border: 1px solid rgba(255, 255, 255, 0.82);
    box-shadow: var(--sombra-suave);
    transition: transform 0.22s ease, box-shadow 0.22s ease, border-color 0.22s ease;
}

.categoria-juridica-card h3,
.publicacion-card h3 {
    margin: 16px 0 14px;
    font-size: clamp(1.45rem, 2.4vw, 2.05rem);
    line-height: 1;
    letter-spacing: -0.05em;
}

.publicaciones-grid-wrap {
    display: grid;
    grid-template-columns: 0.85fr 1.15fr;
    gap: 54px;
    align-items: start;
}

.publicaciones-grid {
    display: grid;
    gap: 18px;
}

.publicacion-card {
    padding: 28px;
    border-radius: var(--radio);
    color: #fff;
    background: rgba(255, 255, 255, 0.08);
    border: 1px solid rgba(255, 255, 255, 0.12);
    transition: transform 0.22s ease, box-shadow 0.22s ease, border-color 0.22s ease;
}

.publicacion-card p {
    color: rgba(255, 255, 255, 0.78);
}

.publicacion-card small {
    display: inline-flex;
    margin-top: 22px;
    padding: 8px 12px;
    border-radius: 999px;
    color: var(--color-azul);
    background: var(--color-dorado-2);
    font-weight: 900;
    font-size: 0.75rem;
}

.criterio-editorial {
    display: grid;
    grid-template-columns: 0.9fr 1.1fr;
    gap: 54px;
    align-items: center;
    padding: 38px;
    border-radius: 34px;
    background: rgba(255, 255, 255, 0.7);
    border: 1px solid rgba(255, 255, 255, 0.82);
    box-shadow: var(--sombra-suave);
}

.criterio-editorial h2 {
    margin: 12px 0 0;
    font-size: clamp(2rem, 4vw, 3.45rem);
    line-height: 1;
    letter-spacing: -0.06em;
}

.criterio-editorial__lista {
    display: grid;
    gap: 14px;
}

.criterio-editorial__lista div {
    display: grid;
    grid-template-columns: 72px 1fr;
    gap: 18px;
    align-items: center;
    padding: 22px;
    border-radius: 22px;
    background: rgba(255, 255, 255, 0.72);
    border: 1px solid rgba(255, 255, 255, 0.84);
    box-shadow: var(--sombra-suave);
}

.criterio-editorial__lista strong {
    color: var(--color-dorado);
    font-size: 1.4rem;
    letter-spacing: -0.04em;
}

@media (max-width: 1080px) {
    .publicaciones-destacadas,
    .categorias-juridicas,
    .publicaciones-grid-wrap,
    .criterio-editorial {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 720px) {
    .publicacion-destacada,
    .categoria-juridica-card,
    .publicacion-card,
    .criterio-editorial {
        padding: 26px;
    }

    .publicacion-destacada > div,
    .criterio-editorial__lista div {
        grid-template-columns: 1fr;
        display: grid;
    }
}

.contacto-hero .page-hero__panel {
    background:
        linear-gradient(145deg, rgba(16, 24, 32, 0.94), rgba(22, 37, 54, 0.94)),
        radial-gradient(circle at 20% 0%, rgba(215, 189, 130, 0.24), transparent 34%);
}

.contacto-grid {
    display: grid;
    grid-template-columns: minmax(0, 0.92fr) minmax(380px, 1.08fr);
    gap: 50px;
    align-items: start;
}

.contacto-info h2 {
    margin: 14px 0 18px;
    font-size: clamp(2.1rem, 4.3vw, 3.7rem);
    line-height: 0.98;
    letter-spacing: -0.065em;
}

.contacto-info > p {
    margin: 0 0 28px;
    color: var(--color-texto);
    font-size: 1.06rem;
}

.canales-contacto {
    display: grid;
    gap: 16px;
}

.canal-card {
    padding: 24px;
    border-radius: 24px;
    background: rgba(255, 255, 255, 0.72);
    border: 1px solid rgba(255, 255, 255, 0.82);
    box-shadow: var(--sombra-suave);
}

.canal-card h3 {
    margin: 0 0 10px;
    font-size: 1.25rem;
    letter-spacing: -0.035em;
}

.canal-card p {
    margin: 0 0 16px;
    color: var(--color-texto);
}

.canal-card a {
    display: inline-flex;
    color: var(--color-dorado);
    font-weight: 900;
}

.formulario-wrap {
    position: relative;
}

.form-contacto {
    padding: 34px;
    border-radius: 34px;
    background: rgba(255, 255, 255, 0.78);
    border: 1px solid rgba(255, 255, 255, 0.9);
    box-shadow: var(--sombra);
}

.form-contacto__cabecera {
    margin-bottom: 24px;
}

.form-contacto__cabecera span {
    display: inline-flex;
    color: var(--color-dorado);
    font-weight: 900;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    font-size: 0.72rem;
}

.form-contacto__cabecera h2 {
    margin: 8px 0 0;
    font-size: clamp(1.7rem, 3vw, 2.45rem);
    line-height: 1;
    letter-spacing: -0.055em;
}

.campo {
    display: grid;
    gap: 8px;
    margin-bottom: 16px;
}

.campo label {
    color: var(--color-azul);
    font-weight: 850;
    font-size: 0.9rem;
}

.campo input,
.campo select,
.campo textarea {
    width: 100%;
    border: 1px solid rgba(20, 32, 42, 0.13);
    border-radius: 18px;
    padding: 14px 16px;
    color: var(--color-tinta);
    background: rgba(255, 255, 255, 0.82);
    outline: none;
    font: inherit;
    transition: border-color 0.2s ease, box-shadow 0.2s ease, background 0.2s ease;
}

.campo textarea {
    resize: vertical;
    min-height: 150px;
}

.campo input:focus,
.campo select:focus,
.campo textarea:focus {
    border-color: rgba(184, 149, 90, 0.7);
    box-shadow: 0 0 0 4px rgba(184, 149, 90, 0.13);
    background: #fff;
}

.form-doble {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 14px;
}

.oculto {
    position: absolute;
    left: -9999px;
    width: 1px;
    height: 1px;
    overflow: hidden;
}

.alerta {
    padding: 14px 16px;
    margin-bottom: 18px;
    border-radius: 18px;
    font-weight: 750;
}

.alerta p {
    margin: 0;
}

.alerta p + p {
    margin-top: 6px;
}

.alerta--ok {
    color: #153f2f;
    background: rgba(55, 142, 96, 0.14);
    border: 1px solid rgba(55, 142, 96, 0.24);
}

.alerta--error {
    color: #5b2020;
    background: rgba(159, 55, 55, 0.12);
    border: 1px solid rgba(159, 55, 55, 0.22);
}

.contacto-proceso {
    display: grid;
    grid-template-columns: 0.88fr 1.12fr;
    gap: 54px;
    align-items: start;
}

.contacto-pasos {
    display: grid;
    gap: 16px;
}

.contacto-pasos article {
    display: grid;
    grid-template-columns: 70px 1fr;
    gap: 18px;
    align-items: center;
    padding: 24px;
    border-radius: 24px;
    color: #fff;
    background: rgba(255, 255, 255, 0.08);
    border: 1px solid rgba(255, 255, 255, 0.12);
}

.contacto-pasos strong {
    color: var(--color-dorado-2);
    font-size: 1.4rem;
    letter-spacing: -0.05em;
}

.contacto-pasos p {
    margin: 0;
    color: rgba(255, 255, 255, 0.78);
}

@media (max-width: 1080px) {
    .contacto-grid,
    .contacto-proceso {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 720px) {
    .form-contacto {
        padding: 26px;
    }

    .form-doble,
    .contacto-pasos article {
        grid-template-columns: 1fr;
    }
}

.agenda-body {
    min-height: 100vh;
    background: var(--color-fondo);
}

.agenda-header {
    position: sticky;
    top: 0;
    z-index: 40;
    background: rgba(245, 241, 232, 0.92);
    backdrop-filter: blur(20px);
    border-bottom: 1px solid var(--color-linea);
}

.agenda-header__contenido {
    min-height: 84px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 24px;
}

.agenda-nav {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    flex-wrap: wrap;
    gap: 8px;
}

.agenda-nav a {
    padding: 10px 14px;
    border-radius: 999px;
    color: var(--color-texto);
    font-weight: 800;
    font-size: 0.9rem;
    transition: background 0.2s ease, color 0.2s ease;
}

.agenda-nav a:hover,
.agenda-nav a.is-active {
    color: var(--color-azul);
    background: rgba(184, 149, 90, 0.13);
}

.agenda-nav__salir {
    color: #fff !important;
    background: var(--color-azul);
}

.agenda-login {
    padding: 90px 0;
}

.agenda-login__grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(360px, 440px);
    gap: 54px;
    align-items: center;
}

.agenda-login__intro h1,
.agenda-panel-hero h1,
.agenda-page-head h1 {
    margin: 16px 0 18px;
    font-size: clamp(2.35rem, 5vw, 4.65rem);
    line-height: 0.96;
    letter-spacing: -0.07em;
}

.agenda-login__intro p,
.agenda-panel-hero p,
.agenda-page-head p {
    max-width: 720px;
    margin: 0;
    color: var(--color-texto);
    font-size: 1.06rem;
}

.agenda-card {
    padding: 34px;
    border-radius: 34px;
    background: rgba(255, 255, 255, 0.76);
    border: 1px solid rgba(255, 255, 255, 0.88);
    box-shadow: var(--sombra);
}

.agenda-card__cabecera {
    margin-bottom: 24px;
}

.agenda-card__cabecera span,
.agenda-table-head span,
.agenda-message-card span {
    color: var(--color-dorado);
    font-weight: 900;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    font-size: 0.72rem;
}

.agenda-card__cabecera h2,
.agenda-section-title h2,
.agenda-table-head h2 {
    margin: 8px 0 0;
    font-size: clamp(1.75rem, 3vw, 2.5rem);
    line-height: 1;
    letter-spacing: -0.055em;
}

.agenda-form .btn {
    width: 100%;
    margin-top: 4px;
}

.agenda-nota {
    margin: 18px 0 0;
    padding: 14px 16px;
    border-radius: 18px;
    color: var(--color-texto);
    background: rgba(184, 149, 90, 0.12);
    border: 1px solid rgba(184, 149, 90, 0.22);
    font-size: 0.92rem;
}

.agenda-main {
    padding: 70px 0 90px;
}

.agenda-panel-hero {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(300px, 380px);
    gap: 38px;
    align-items: stretch;
}

.agenda-panel-estado {
    min-height: 240px;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    padding: 30px;
    border-radius: 32px;
    color: #fff;
    background:
        linear-gradient(145deg, rgba(16, 24, 32, 0.94), rgba(26, 47, 66, 0.96)),
        radial-gradient(circle at 20% 0%, rgba(215, 189, 130, 0.34), transparent 42%);
    box-shadow: var(--sombra);
}

.agenda-panel-estado span,
.agenda-panel-estado small {
    color: rgba(255, 255, 255, 0.68);
}

.agenda-panel-estado strong {
    display: block;
    margin: 8px 0;
    font-size: 2rem;
    line-height: 1;
    letter-spacing: -0.055em;
}

.agenda-metricas {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 18px;
    margin-top: 42px;
}

.agenda-metrica-card,
.agenda-action-card,
.agenda-table-wrap,
.agenda-message-card,
.agenda-empty {
    padding: 28px;
    border-radius: 28px;
    background: rgba(255, 255, 255, 0.72);
    border: 1px solid rgba(255, 255, 255, 0.86);
    box-shadow: var(--sombra-suave);
}

.agenda-metrica-card span {
    display: block;
    color: var(--color-dorado);
    font-weight: 900;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    font-size: 0.72rem;
}

.agenda-metrica-card strong {
    display: block;
    margin: 14px 0 8px;
    font-size: 3rem;
    line-height: 0.9;
    letter-spacing: -0.07em;
}

.agenda-metrica-card p,
.agenda-action-card p,
.agenda-empty p,
.agenda-message-card p,
.agenda-message-card small {
    margin: 0;
    color: var(--color-texto);
}

.agenda-acciones,
.agenda-table-wrap {
    margin-top: 48px;
}

.agenda-section-title {
    margin-bottom: 24px;
}

.agenda-acciones-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 18px;
}

.agenda-action-card {
    display: block;
    min-height: 170px;
    transition: transform 0.22s ease, box-shadow 0.22s ease, border-color 0.22s ease;
}

.agenda-action-card:hover {
    transform: translateY(-5px);
    box-shadow: var(--sombra);
    border-color: rgba(184, 149, 90, 0.36);
}

.agenda-action-card h3,
.agenda-empty h3,
.agenda-message-card h3 {
    margin: 0 0 12px;
    font-size: 1.35rem;
    line-height: 1.08;
    letter-spacing: -0.04em;
}

.agenda-page-head {
    max-width: 900px;
}

.agenda-table-head {
    display: flex;
    align-items: end;
    justify-content: space-between;
    gap: 20px;
    margin-bottom: 22px;
}

.agenda-table {
    width: 100%;
    border-collapse: collapse;
    overflow: hidden;
}

.agenda-table th,
.agenda-table td {
    padding: 16px 14px;
    text-align: left;
    border-bottom: 1px solid rgba(20, 32, 42, 0.1);
}

.agenda-table th {
    color: var(--color-azul);
    font-size: 0.82rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
}

.agenda-table td {
    color: var(--color-texto);
}

.agenda-empty {
    box-shadow: none;
    background: rgba(184, 149, 90, 0.1);
    border-color: rgba(184, 149, 90, 0.18);
}

.agenda-message-list {
    display: grid;
    gap: 16px;
}

.agenda-message-card {
    box-shadow: none;
}

.agenda-message-card small {
    display: block;
    margin-top: 14px;
    font-weight: 750;
}

.agenda-footer {
    padding: 28px 0;
    color: rgba(255, 255, 255, 0.72);
    background: var(--color-azul);
}

.agenda-footer__contenido p {
    margin: 0;
}

@media (max-width: 1040px) {
    .agenda-login__grid,
    .agenda-panel-hero {
        grid-template-columns: 1fr;
    }

    .agenda-metricas,
    .agenda-acciones-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 760px) {
    .agenda-header__contenido {
        align-items: flex-start;
        flex-direction: column;
        padding: 18px 0;
    }

    .agenda-nav {
        width: 100%;
        justify-content: flex-start;
    }

    .agenda-login,
    .agenda-main {
        padding: 48px 0 70px;
    }

    .agenda-metricas,
    .agenda-acciones-grid {
        grid-template-columns: 1fr;
    }

    .agenda-card,
    .agenda-metrica-card,
    .agenda-action-card,
    .agenda-table-wrap,
    .agenda-empty {
        padding: 24px;
    }

    .agenda-table-wrap {
        overflow-x: auto;
    }

    .agenda-table {
        min-width: 720px;
    }
}

.agenda-page-head--acciones {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 26px;
    max-width: none;
}

.agenda-page-actions,
.agenda-form-actions,
.agenda-table-actions {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
}

.agenda-table--acciones {
    min-width: 980px;
}

.agenda-table td strong {
    color: var(--color-azul);
}

.agenda-table-actions a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 8px 12px;
    border-radius: 999px;
    color: var(--color-azul);
    background: rgba(184, 149, 90, 0.12);
    font-size: 0.82rem;
    font-weight: 900;
    transition: background 0.2s ease, transform 0.2s ease;
}

.agenda-table-actions a:hover {
    transform: translateY(-2px);
    background: rgba(184, 149, 90, 0.22);
}

.estado-pill {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 118px;
    padding: 8px 12px;
    border-radius: 999px;
    color: var(--color-azul);
    background: rgba(20, 32, 42, 0.08);
    font-size: 0.8rem;
    font-weight: 900;
    white-space: nowrap;
}

.estado-pill--en_revision {
    color: #725114;
    background: rgba(184, 149, 90, 0.18);
}

.estado-pill--en_tramitacion {
    color: #12354c;
    background: rgba(26, 83, 115, 0.14);
}

.estado-pill--audiencia {
    color: #5f2c17;
    background: rgba(184, 92, 45, 0.14);
}

.estado-pill--cerrada {
    color: #21533d;
    background: rgba(57, 125, 91, 0.14);
}

.agenda-empty--accion {
    display: grid;
    gap: 18px;
    justify-items: start;
}

.agenda-form-shell {
    margin-top: 44px;
    max-width: 980px;
}

.agenda-form-panel {
    padding: 34px;
    border-radius: 32px;
    background: rgba(255, 255, 255, 0.74);
    border: 1px solid rgba(255, 255, 255, 0.86);
    box-shadow: var(--sombra-suave);
}

.agenda-form-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 18px;
}

.agenda-form-panel .campo {
    margin-bottom: 18px;
}

.agenda-form-panel .campo span {
    display: block;
    margin-bottom: 8px;
    color: var(--color-azul);
    font-size: 0.84rem;
    font-weight: 900;
    letter-spacing: 0.05em;
    text-transform: uppercase;
}

.agenda-form-panel input,
.agenda-form-panel select,
.agenda-form-panel textarea {
    width: 100%;
    min-height: 52px;
    padding: 14px 16px;
    border: 1px solid rgba(20, 32, 42, 0.14);
    border-radius: 16px;
    color: var(--color-azul);
    background: rgba(255, 255, 255, 0.9);
    font: inherit;
    font-weight: 700;
    outline: none;
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.agenda-form-panel textarea {
    min-height: 180px;
    resize: vertical;
    line-height: 1.55;
}

.agenda-form-panel input:focus,
.agenda-form-panel select:focus,
.agenda-form-panel textarea:focus {
    border-color: rgba(184, 149, 90, 0.7);
    box-shadow: 0 0 0 4px rgba(184, 149, 90, 0.14);
}

.agenda-form-actions {
    justify-content: flex-end;
    margin-top: 10px;
}

.agenda-form-actions .btn {
    width: auto;
    margin: 0;
}

.agenda-alert {
    margin-bottom: 22px;
    padding: 18px 20px;
    border-radius: 20px;
    color: var(--color-azul);
    font-weight: 800;
}

.agenda-alert strong {
    display: block;
    margin-bottom: 8px;
}

.agenda-alert ul {
    margin: 0;
    padding-left: 20px;
}

.agenda-alert--error {
    background: rgba(148, 48, 48, 0.1);
    border: 1px solid rgba(148, 48, 48, 0.18);
}

.agenda-alert--ok {
    background: rgba(57, 125, 91, 0.12);
    border: 1px solid rgba(57, 125, 91, 0.2);
}

.agenda-detail-wrap {
    display: grid;
    gap: 22px;
    margin-top: 44px;
}

.agenda-detail-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 18px;
}

.agenda-detail-card {
    padding: 26px;
    border-radius: 28px;
    background: rgba(255, 255, 255, 0.74);
    border: 1px solid rgba(255, 255, 255, 0.86);
    box-shadow: var(--sombra-suave);
}

.agenda-detail-card span {
    display: block;
    margin-bottom: 12px;
    color: var(--color-dorado);
    font-size: 0.72rem;
    font-weight: 900;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.agenda-detail-card strong {
    display: block;
    color: var(--color-azul);
    font-size: clamp(1.25rem, 2.4vw, 1.9rem);
    line-height: 1;
    letter-spacing: -0.055em;
}

.agenda-detail-card p {
    margin: 0;
    color: var(--color-texto);
    line-height: 1.65;
}

.agenda-detail-card--principal {
    color: #fff;
    background:
        linear-gradient(145deg, rgba(16, 24, 32, 0.94), rgba(26, 47, 66, 0.96)),
        radial-gradient(circle at 20% 0%, rgba(215, 189, 130, 0.34), transparent 42%);
}

.agenda-detail-card--principal span,
.agenda-detail-card--principal p {
    color: rgba(255, 255, 255, 0.72);
}

.agenda-detail-card--principal strong {
    color: #fff;
    font-size: clamp(2rem, 4vw, 3.2rem);
}

.agenda-detail-card--texto {
    min-height: 190px;
}

@media (max-width: 1040px) {
    .agenda-detail-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 760px) {
    .agenda-page-head--acciones {
        align-items: flex-start;
        flex-direction: column;
    }

    .agenda-form-grid,
    .agenda-detail-grid {
        grid-template-columns: 1fr;
    }

    .agenda-form-panel,
    .agenda-detail-card {
        padding: 24px;
    }

    .agenda-form-actions,
    .agenda-page-actions {
        width: 100%;
        align-items: stretch;
        flex-direction: column;
    }

    .agenda-form-actions .btn,
    .agenda-page-actions .btn,
    .agenda-page-head--acciones .btn {
        width: 100%;
    }
}

.estado-pill--activo {
    color: #21533d;
    background: rgba(57, 125, 91, 0.14);
}

.estado-pill--inactivo {
    color: #5c2730;
    background: rgba(148, 48, 48, 0.12);
}

@media (min-width: 1180px) {
    .agenda-metricas,
    .agenda-acciones-grid {
        grid-template-columns: repeat(5, 1fr);
    }
}


.agenda-metricas--compactas {
    margin-top: 20px;
    margin-bottom: 30px;
}

.estado-pill--pendiente,
.estado-pill--nuevo {
    color: #725114;
    background: rgba(184, 149, 90, 0.18);
}

.estado-pill--pagado,
.estado-pill--revisado {
    color: #21533d;
    background: rgba(57, 125, 91, 0.14);
}

.estado-pill--anulado,
.estado-pill--cerrado {
    color: #5f2c17;
    background: rgba(148, 48, 48, 0.12);
}

.agenda-message-card--gestion {
    display: grid;
    gap: 12px;
}

.agenda-message-card__top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    flex-wrap: wrap;
}

.agenda-inline-form {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 6px;
    border-radius: 999px;
    background: rgba(20, 32, 42, 0.05);
}

.agenda-inline-form select,
.agenda-inline-form button {
    min-height: 36px;
    border: 0;
    border-radius: 999px;
    font: inherit;
    font-size: 0.78rem;
    font-weight: 900;
}

.agenda-inline-form select {
    padding: 0 10px;
    color: var(--color-azul);
    background: rgba(255, 255, 255, 0.9);
}

.agenda-inline-form button {
    padding: 0 12px;
    color: #fff;
    background: var(--color-azul);
    cursor: pointer;
}

@media (max-width: 760px) {
    .agenda-inline-form,
    .agenda-inline-form select,
    .agenda-inline-form button {
        width: 100%;
    }

    .agenda-inline-form {
        border-radius: 18px;
        align-items: stretch;
        flex-direction: column;
    }
}

.agenda-table--calendario {
    min-width: 1060px;
}

.agenda-table-note {
    display: block;
    margin-top: 6px;
    color: rgba(20, 32, 42, 0.62);
    font-size: 0.78rem;
    font-weight: 800;
}

.estado-pill--realizado {
    color: #21533d;
    background: rgba(57, 125, 91, 0.14);
}

.estado-pill--cancelado {
    color: #5c2730;
    background: rgba(148, 48, 48, 0.12);
}

/* Ajuste visual final v12 */
:root {
    --color-crema: #f8f4ec;
    --color-crema-2: #ece2d1;
    --color-marfil: #fffaf0;
    --color-focus: rgba(184, 149, 90, 0.34);
    --transicion: 0.22s ease;
}

body {
    min-width: 320px;
    text-rendering: optimizeLegibility;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

body.nav-open {
    overflow: hidden;
}

::selection {
    color: #fff;
    background: var(--color-azul);
}

main {
    display: block;
}

.skip-link {
    position: fixed;
    left: 18px;
    top: 18px;
    z-index: 999;
    transform: translateY(-150%);
    padding: 10px 14px;
    border-radius: 999px;
    color: #fff;
    background: var(--color-azul);
    box-shadow: var(--sombra-suave);
    font-weight: 900;
    transition: transform var(--transicion);
}

.skip-link:focus {
    transform: translateY(0);
}

a:focus-visible,
button:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible {
    outline: 3px solid var(--color-focus);
    outline-offset: 3px;
}

.header::before,
.agenda-header::before {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    height: 3px;
    background: linear-gradient(90deg, transparent, var(--color-dorado), transparent);
    opacity: 0.84;
}

.header__contenido,
.agenda-header__contenido {
    position: relative;
}

.marca {
    border-radius: 22px;
    transition: transform var(--transicion), opacity var(--transicion);
}

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

.marca__simbolo {
    position: relative;
    overflow: hidden;
}

.marca__simbolo::after {
    content: "";
    position: absolute;
    inset: 1px;
    border-radius: 17px;
    border: 1px solid rgba(255, 255, 255, 0.14);
    pointer-events: none;
}

.nav a,
.agenda-nav a {
    white-space: nowrap;
}

.nav-toggle {
    transition: transform var(--transicion), background var(--transicion);
}

.nav-toggle:hover,
.nav-toggle.is-active {
    background: #1d3145;
}

.nav-toggle.is-active span:nth-child(1) {
    transform: translateY(7px) rotate(45deg);
}

.nav-toggle.is-active span:nth-child(2) {
    opacity: 0;
}

.nav-toggle.is-active span:nth-child(3) {
    transform: translateY(-7px) rotate(-45deg);
}

.nav-toggle span {
    transition: transform var(--transicion), opacity var(--transicion);
}

.hero::before,
.page-hero::before {
    content: "";
    position: absolute;
    left: max(20px, calc((100vw - var(--contenedor)) / 2));
    bottom: 24px;
    width: min(46vw, 520px);
    height: 1px;
    background: linear-gradient(90deg, rgba(184, 149, 90, 0.55), transparent);
    z-index: -1;
}

.hero__panel,
.page-hero__panel,
.cta__contenido,
.form-contacto,
.agenda-card,
.agenda-panel-estado {
    isolation: isolate;
}

.panel-card--principal,
.page-hero__panel,
.agenda-panel-estado,
.agenda-detail-card--principal {
    position: relative;
    overflow: hidden;
}

.panel-card--principal::before,
.page-hero__panel::before,
.agenda-panel-estado::before,
.agenda-detail-card--principal::before {
    content: "";
    position: absolute;
    inset: auto -18% -32% auto;
    width: 210px;
    height: 210px;
    border-radius: 999px;
    background: rgba(215, 189, 130, 0.16);
    filter: blur(2px);
    z-index: -1;
}

.confianza-card,
.servicio-card,
.noticia-card,
.area-card,
.principio-card,
.portafolio-card,
.publicacion-destacada,
.categoria-juridica-card,
.canal-card,
.agenda-metrica-card,
.agenda-action-card,
.agenda-table-wrap,
.agenda-form-panel,
.agenda-detail-card {
    backdrop-filter: blur(14px);
}

.servicio-card,
.noticia-card,
.area-card,
.principio-card,
.portafolio-card,
.publicacion-destacada,
.categoria-juridica-card,
.agenda-action-card {
    position: relative;
    overflow: hidden;
}

.servicio-card::after,
.noticia-card::after,
.area-card::after,
.principio-card::after,
.portafolio-card::after,
.publicacion-destacada::after,
.categoria-juridica-card::after,
.agenda-action-card::after {
    content: "";
    position: absolute;
    left: 24px;
    right: 24px;
    top: 0;
    height: 3px;
    border-radius: 0 0 999px 999px;
    background: linear-gradient(90deg, transparent, rgba(184, 149, 90, 0.62), transparent);
    opacity: 0;
    transition: opacity var(--transicion);
}

.servicio-card:hover::after,
.noticia-card:hover::after,
.area-card:hover::after,
.principio-card:hover::after,
.portafolio-card:hover::after,
.publicacion-destacada:hover::after,
.categoria-juridica-card:hover::after,
.agenda-action-card:hover::after {
    opacity: 1;
}

.btn {
    cursor: pointer;
    line-height: 1.1;
}

.btn--principal:hover,
.agenda-inline-form button:hover {
    background: linear-gradient(135deg, #172638, #29455f);
}

.btn--secundario:hover {
    border-color: rgba(184, 149, 90, 0.62);
    background: rgba(255, 255, 255, 0.82);
    box-shadow: 0 14px 30px rgba(16, 24, 32, 0.09);
}

.link-elegante {
    transition: color var(--transicion), border-color var(--transicion);
}

.link-elegante:hover {
    color: var(--color-dorado);
    border-color: var(--color-azul);
}

.footer {
    position: relative;
    overflow: hidden;
}

.footer::before {
    content: "";
    position: absolute;
    inset: 0 0 auto 0;
    height: 1px;
    background: linear-gradient(90deg, transparent, rgba(215, 189, 130, 0.5), transparent);
}

.whatsapp-flotante {
    transition: transform var(--transicion), box-shadow var(--transicion), background var(--transicion);
}

.whatsapp-flotante:hover {
    transform: translateY(-3px);
    background: #137848;
    box-shadow: 0 22px 52px rgba(23, 140, 82, 0.4);
}

.campo input::placeholder,
.campo textarea::placeholder,
.agenda-form-panel input::placeholder,
.agenda-form-panel textarea::placeholder {
    color: rgba(63, 72, 80, 0.58);
}

.agenda-table-wrap {
    overflow-x: auto;
}

.agenda-table tr:hover td {
    background: rgba(184, 149, 90, 0.055);
}

.agenda-table td,
.agenda-table th {
    vertical-align: top;
}

.estado-pill {
    line-height: 1.05;
}

@media (max-width: 1080px) {
    .nav {
        max-height: calc(100vh - 112px);
        overflow-y: auto;
        border: 1px solid rgba(20, 32, 42, 0.09);
    }

    .nav a {
        padding: 13px 14px;
    }

    .nav a::after {
        left: 14px;
        right: auto;
        width: 42px;
    }

    .hero__panel,
    .page-hero__panel {
        max-width: 680px;
    }
}

@media (max-width: 720px) {
    .hero__contenido h1,
    .page-hero h1,
    .agenda-login__intro h1,
    .agenda-panel-hero h1,
    .agenda-page-head h1 {
        letter-spacing: -0.055em;
    }

    .hero__acciones,
    .cta__acciones,
    .agenda-page-actions {
        width: 100%;
    }

    .hero__acciones .btn,
    .cta__acciones .btn,
    .contacto-info .btn,
    .canal-card a {
        width: 100%;
    }

    .hero__panel {
        padding: 16px;
        border-radius: 26px;
    }

    .panel-card,
    .page-hero__panel,
    .servicio-card,
    .noticia-card,
    .confianza-card,
    .principio-card,
    .rol-card,
    .publicacion-destacada,
    .categoria-juridica-card,
    .canal-card,
    .agenda-card {
        border-radius: 24px;
    }

    .cta__contenido {
        padding: 28px;
        border-radius: 28px;
    }

    .footer {
        padding-bottom: 92px;
    }

    .whatsapp-flotante {
        left: 14px;
        right: 14px;
        width: auto;
    }
}

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

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

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

/* =========================================================
   Ajuste visual profesional v17 - Justicia Tarapacá
   Paleta jurídica sobria + imagen institucional de fondo
   ========================================================= */
:root{
    --color-fondo: #f2eee6;
    --color-fondo-2: #e7dfd1;
    --color-superficie: rgba(255, 252, 247, .86);
    --color-superficie-solida: #fffaf2;
    --color-texto: #111b24;
    --color-texto-suave: #4d5660;
    --color-borde: rgba(17, 27, 36, .11);
    --color-primario: #101c28;
    --color-primario-2: #182b3a;
    --color-acento: #b38b46;
    --color-acento-2: #d9bd79;
    --sombra-suave: 0 18px 55px rgba(17, 27, 36, .10);
    --sombra-media: 0 28px 80px rgba(17, 27, 36, .16);
    --radio-xl: 32px;
}

html{
    background: var(--color-fondo);
}

body{
    background:
        radial-gradient(circle at 8% 9%, rgba(217, 189, 121, .18), transparent 34%),
        radial-gradient(circle at 94% 4%, rgba(16, 28, 40, .10), transparent 33%),
        linear-gradient(180deg, #f6f1e8 0%, #ebe3d5 46%, #f7f2ea 100%);
    color: var(--color-texto);
}

body::before{
    content: "";
    position: fixed;
    inset: 0;
    pointer-events: none;
    background:
        linear-gradient(90deg, rgba(16, 28, 40, .06) 1px, transparent 1px),
        linear-gradient(180deg, rgba(16, 28, 40, .04) 1px, transparent 1px);
    background-size: 72px 72px;
    opacity: .20;
    mask-image: linear-gradient(180deg, transparent 0%, black 18%, black 72%, transparent 100%);
    z-index: -1;
}

.header{
    background: rgba(255, 251, 243, .88);
    border-bottom: 1px solid rgba(17, 27, 36, .08);
    box-shadow: 0 18px 52px rgba(17, 27, 36, .08);
    backdrop-filter: blur(18px);
}

.marca__simbolo{
    background:
        linear-gradient(145deg, #182938 0%, #0e1720 100%);
    color: #fffaf2;
    border: 1px solid rgba(217, 189, 121, .34);
    box-shadow: 0 18px 38px rgba(17, 27, 36, .20), inset 0 1px 0 rgba(255,255,255,.14);
}

.marca__texto strong{
    letter-spacing: -.02em;
}

.nav a{
    color: rgba(17, 27, 36, .78);
}

.nav a:hover,
.nav a.is-active{
    color: var(--color-primario);
}

.nav a.is-active{
    background: rgba(179, 139, 70, .12);
}

.nav a.is-active::after{
    background: linear-gradient(90deg, transparent, var(--color-acento), transparent);
}

.nav__privado,
.boton--oscuro,
.boton--principal{
    background: linear-gradient(135deg, var(--color-primario) 0%, var(--color-primario-2) 100%);
    color: #fffaf2 !important;
    box-shadow: 0 20px 48px rgba(17, 27, 36, .22);
    border: 1px solid rgba(255,255,255,.08);
}

.nav__privado:hover,
.boton--oscuro:hover,
.boton--principal:hover{
    transform: translateY(-2px);
    box-shadow: 0 26px 62px rgba(17, 27, 36, .30);
}

.boton--claro,
.boton--secundario{
    background: rgba(255, 250, 242, .72);
    border: 1px solid rgba(179, 139, 70, .28);
    color: var(--color-primario) !important;
    box-shadow: 0 16px 38px rgba(17, 27, 36, .08);
}

main{
    overflow: hidden;
}

.hero{
    position: relative;
    min-height: calc(100vh - 86px);
    isolation: isolate;
    background:
        linear-gradient(90deg, rgba(246,241,232,.97) 0%, rgba(246,241,232,.90) 38%, rgba(246,241,232,.55) 63%, rgba(246,241,232,.26) 100%),
        url('../img/tribunal-institucional.svg') right center / min(920px, 58vw) auto no-repeat;
}

.hero::before{
    content: "";
    position: absolute;
    inset: 0;
    z-index: -2;
    background:
        radial-gradient(circle at 72% 30%, rgba(179, 139, 70, .18), transparent 32%),
        linear-gradient(180deg, rgba(255,255,255,.36), rgba(231,223,209,.58));
}

.hero::after{
    content: "";
    position: absolute;
    right: -9%;
    top: 12%;
    width: 54%;
    height: 78%;
    border-radius: 44px 0 0 44px;
    background: linear-gradient(135deg, rgba(16,28,40,.10), rgba(179,139,70,.10));
    border: 1px solid rgba(255,255,255,.34);
    box-shadow: inset 0 1px 0 rgba(255,255,255,.32);
    z-index: -1;
}

.hero__contenido{
    grid-template-columns: minmax(0, 1.02fr) minmax(360px, .78fr);
    gap: clamp(36px, 5vw, 82px);
}

.hero h1{
    max-width: 780px;
    font-size: clamp(3.3rem, 6.4vw, 6.3rem);
    line-height: .88;
    letter-spacing: -.075em;
}

.hero p{
    max-width: 650px;
    color: rgba(17, 27, 36, .78);
    font-size: clamp(1.05rem, 1.45vw, 1.22rem);
}

.etiqueta,
.seccion__etiqueta,
.hero__eyebrow{
    color: var(--color-acento);
    letter-spacing: .09em;
}

.etiqueta::before,
.seccion__etiqueta::before,
.hero__eyebrow::before{
    background: var(--color-acento);
}

.hero__tarjeta,
.tarjeta,
.servicio-card,
.card,
.contacto-card,
.form-card,
.login-card,
.panel,
.agenda-card{
    background: rgba(255, 252, 247, .82);
    border: 1px solid rgba(255,255,255,.72);
    box-shadow: var(--sombra-suave);
    backdrop-filter: blur(14px);
}

.hero__tarjeta{
    position: relative;
    overflow: hidden;
    border-radius: 32px;
}

.hero__tarjeta::before{
    content: "";
    position: absolute;
    inset: 22px 22px auto auto;
    width: 142px;
    height: 142px;
    border-radius: 999px;
    background: radial-gradient(circle, rgba(217, 189, 121, .34), transparent 68%);
    pointer-events: none;
}

.hero__tarjeta--principal{
    background:
        linear-gradient(135deg, rgba(16, 28, 40, .96), rgba(27, 48, 64, .96)),
        url('../img/tribunal-institucional.svg') center / cover no-repeat;
    color: #fffaf2;
    border-color: rgba(217, 189, 121, .22);
    box-shadow: 0 30px 80px rgba(17, 27, 36, .26);
}

.hero__tarjeta--principal small,
.hero__tarjeta--principal p{
    color: rgba(255, 250, 242, .74);
}

.hero__tarjeta--principal strong{
    color: #fffaf2;
}

.hero__tarjeta:not(.hero__tarjeta--principal) strong,
.hero__tarjeta:not(.hero__tarjeta--principal) h3{
    color: var(--color-primario);
}

.confianza__item,
.servicio,
.portafolio__item,
.noticia,
.jurisprudencia-card,
.equipo-card{
    background: rgba(255, 252, 247, .72);
    border: 1px solid rgba(255,255,255,.76);
    box-shadow: var(--sombra-suave);
    backdrop-filter: blur(10px);
}

.confianza__icono,
.servicio__numero,
.portafolio__numero{
    color: var(--color-acento);
}

.confianza__icono{
    background: linear-gradient(135deg, #1b2d3b 0%, #b38b46 100%);
    box-shadow: inset 0 1px 0 rgba(255,255,255,.26);
}

.servicios-resumen,
.confianza,
.portafolio-resumen,
.jurisprudencia-resumen,
.contacto-cta{
    position: relative;
}

.servicios-resumen::before,
.confianza::before,
.portafolio-resumen::before,
.jurisprudencia-resumen::before,
.contacto-cta::before{
    content: "";
    position: absolute;
    inset: 0;
    z-index: -1;
    background: radial-gradient(circle at 82% 10%, rgba(179, 139, 70, .12), transparent 36%);
    pointer-events: none;
}

.equipo-resumen{
    background:
        linear-gradient(135deg, rgba(16, 28, 40, .98) 0%, rgba(18, 38, 54, .98) 100%),
        url('../img/tribunal-institucional.svg') right center / 690px auto no-repeat;
    color: #fffaf2;
}

.equipo-resumen p,
.equipo-resumen .texto-suave{
    color: rgba(255, 250, 242, .74);
}

.equipo-resumen .panel-destacado{
    background: rgba(255,255,255,.08);
    border: 1px solid rgba(255,255,255,.13);
    box-shadow: none;
}

.contacto-cta__caja{
    background:
        linear-gradient(135deg, rgba(255,252,247,.90), rgba(255,252,247,.70)),
        url('../img/tribunal-institucional.svg') right center / 540px auto no-repeat;
    border: 1px solid rgba(255,255,255,.72);
    box-shadow: var(--sombra-media);
}

.whatsapp-float{
    background: linear-gradient(135deg, #14985c, #0d7042);
    box-shadow: 0 22px 54px rgba(13, 112, 66, .30);
    border: 1px solid rgba(255,255,255,.18);
}

.footer{
    background:
        linear-gradient(135deg, #0d171f 0%, #142330 100%);
    border-top: 1px solid rgba(217, 189, 121, .18);
}

.footer h2,
.footer strong,
.footer .footer__titulo{
    color: #fffaf2;
}

.footer p,
.footer a,
.footer li{
    color: rgba(255, 250, 242, .72);
}

.footer__etiqueta{
    color: var(--color-acento-2);
}

@media (max-width: 1080px){
    .hero{
        background:
            linear-gradient(180deg, rgba(246,241,232,.96), rgba(246,241,232,.82)),
            url('../img/tribunal-institucional.svg') center top 38px / 980px auto no-repeat;
    }

    .hero::after{
        display: none;
    }

    .hero__contenido{
        grid-template-columns: 1fr;
    }
}

@media (max-width: 760px){
    .hero{
        min-height: auto;
        padding-top: 64px;
        background:
            linear-gradient(180deg, rgba(246,241,232,.98), rgba(246,241,232,.90)),
            url('../img/tribunal-institucional.svg') center top / 760px auto no-repeat;
    }

    .hero h1{
        font-size: clamp(3rem, 16vw, 4.8rem);
        letter-spacing: -.07em;
    }

    .contacto-cta__caja,
    .equipo-resumen{
        background-image: linear-gradient(135deg, rgba(16, 28, 40, .98), rgba(18, 38, 54, .98));
    }

    .contacto-cta__caja{
        background: rgba(255, 252, 247, .88);
    }
}


:root {
    --jt-azul-profundo: #07182f;
    --jt-azul-noche: #0b1f3a;
    --jt-dorado: #c9a65f;
    --jt-dorado-claro: #ead7a2;
    --jt-marfil: #f3eee4;
    --jt-tinta: #18243a;
    --jt-panel: rgba(255, 255, 255, 0.92);
    --jt-borde-dorado: rgba(201, 166, 95, 0.35);
    --jt-sombra-pro: 0 22px 65px rgba(3, 12, 29, 0.22);
}

body {
    background: linear-gradient(135deg, #07182f 0%, #10284b 42%, #e9e1d1 100%);
    color: var(--jt-tinta);
}

body::before {
    content: "";
    position: fixed;
    inset: 0;
    z-index: -2;
    background: linear-gradient(90deg, rgba(7, 24, 47, 0.94), rgba(7, 24, 47, 0.78) 48%, rgba(243, 238, 228, 0.72)), url('../img/tribunal-institucional.svg') center right / min(980px, 88vw) auto no-repeat;
    opacity: 0.98;
    pointer-events: none;
}

body::after {
    content: "";
    position: fixed;
    inset: 0;
    z-index: -1;
    background-image: radial-gradient(circle at 18% 12%, rgba(201, 166, 95, 0.16), transparent 26%), radial-gradient(circle at 82% 20%, rgba(255, 255, 255, 0.10), transparent 28%), linear-gradient(180deg, rgba(255, 255, 255, 0.02), rgba(7, 24, 47, 0.08));
    pointer-events: none;
}

.header {
    background: rgba(7, 24, 47, 0.94);
    border-bottom: 1px solid rgba(234, 215, 162, 0.26);
    box-shadow: 0 18px 45px rgba(3, 12, 29, 0.28);
    backdrop-filter: blur(16px);
}

.header.is-scrolled {
    background: rgba(7, 24, 47, 0.98);
    box-shadow: 0 18px 55px rgba(3, 12, 29, 0.34);
}

.marca {
    gap: 14px;
}

.marca__simbolo {
    background: linear-gradient(135deg, var(--jt-dorado-claro), var(--jt-dorado) 52%, #8e6a22);
    color: #07182f;
    border: 1px solid rgba(255, 255, 255, 0.28);
    box-shadow: 0 12px 34px rgba(201, 166, 95, 0.25), inset 0 1px 0 rgba(255, 255, 255, 0.48);
}

.marca__texto strong {
    color: #ffffff;
    letter-spacing: 0.02em;
}

.marca__texto small {
    color: rgba(243, 238, 228, 0.76);
}

.nav a {
    border: 1px solid transparent;
    border-radius: 999px;
    color: rgba(243, 238, 228, 0.86);
    transition: color 0.22s ease, background 0.22s ease, border-color 0.22s ease, transform 0.22s ease, box-shadow 0.22s ease;
}

.nav a:hover,
.nav a.is-active {
    color: #ffffff;
    background: rgba(201, 166, 95, 0.14);
    border-color: rgba(201, 166, 95, 0.42);
    box-shadow: 0 10px 26px rgba(0, 0, 0, 0.16);
    transform: translateY(-1px);
}

.nav .nav__privado {
    color: #07182f;
    background: linear-gradient(135deg, var(--jt-dorado-claro), var(--jt-dorado));
    border-color: rgba(255, 255, 255, 0.32);
    box-shadow: 0 12px 32px rgba(201, 166, 95, 0.25);
}

.nav .nav__privado:hover {
    color: #07182f;
    background: linear-gradient(135deg, #fff0bf, #d8b76d);
    box-shadow: 0 16px 38px rgba(201, 166, 95, 0.34);
}

.hero,
.page-hero,
.contacto-hero {
    position: relative;
    overflow: hidden;
    background: linear-gradient(135deg, rgba(7, 24, 47, 0.96), rgba(12, 33, 63, 0.9));
}

.hero::before,
.page-hero::before,
.contacto-hero::before {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(90deg, rgba(7, 24, 47, 0.93), rgba(7, 24, 47, 0.62), rgba(7, 24, 47, 0.88)), url('../img/tribunal-institucional.svg') center right / min(900px, 86vw) auto no-repeat;
    opacity: 0.92;
    pointer-events: none;
}

.hero::after,
.page-hero::after,
.contacto-hero::after {
    content: "";
    position: absolute;
    inset: auto 0 0 0;
    height: 1px;
    background: linear-gradient(90deg, transparent, rgba(234, 215, 162, 0.7), transparent);
    pointer-events: none;
}

.hero > *,
.page-hero > *,
.contacto-hero > * {
    position: relative;
    z-index: 1;
}

.hero__contenido,
.page-hero__panel,
.hero__panel,
.contacto-v20,
.contacto-contenedor,
.panel-card,
.servicio-card,
.area-card,
.portafolio-card,
.publicacion-card,
.noticia-card,
.rol-card,
.principio-card,
.confianza-card,
.categoria-juridica-card {
    border: 1px solid rgba(201, 166, 95, 0.24);
    box-shadow: var(--jt-sombra-pro);
}

.hero__panel,
.page-hero__panel,
.panel-card,
.contacto-v20,
.contacto-contenedor {
    background: rgba(255, 255, 255, 0.9);
    backdrop-filter: blur(18px);
}

.eyebrow,
.etiqueta,
.area-card__numero,
.portafolio-card__numero {
    color: var(--jt-dorado);
    letter-spacing: 0.13em;
}

h1,
.bloque-titulo h2,
.seccion__cabecera h2,
.page-hero h1,
.hero h1 {
    letter-spacing: -0.035em;
}

.hero h1,
.page-hero h1,
.contacto-hero h1,
.seccion--oscura h2,
.bloque-titulo--claro h2 {
    color: #ffffff;
    text-shadow: 0 16px 42px rgba(0, 0, 0, 0.26);
}

.hero p,
.page-hero p,
.contacto-hero p,
.seccion--oscura p,
.bloque-titulo--claro p {
    color: rgba(243, 238, 228, 0.88);
}

.btn,
.btn-principal,
.btn-secundario,
.btn-v20,
button,
input[type="submit"] {
    border-radius: 999px;
    font-weight: 800;
    letter-spacing: 0.01em;
    transition: transform 0.22s ease, box-shadow 0.22s ease, background 0.22s ease, border-color 0.22s ease, color 0.22s ease;
}

.btn:hover,
.btn-principal:hover,
.btn-secundario:hover,
.btn-v20:hover,
button:hover,
input[type="submit"]:hover {
    transform: translateY(-2px);
}

.btn--principal,
.btn-principal,
.btn-v20,
input[type="submit"] {
    color: #07182f;
    background: linear-gradient(135deg, #f4dea3 0%, #c9a65f 52%, #9f792f 100%);
    border: 1px solid rgba(255, 255, 255, 0.34);
    box-shadow: 0 16px 38px rgba(201, 166, 95, 0.32), inset 0 1px 0 rgba(255, 255, 255, 0.42);
}

.btn--principal:hover,
.btn-principal:hover,
.btn-v20:hover,
input[type="submit"]:hover {
    color: #07182f;
    background: linear-gradient(135deg, #fff0bf 0%, #d7b76d 54%, #a88234 100%);
    box-shadow: 0 22px 52px rgba(201, 166, 95, 0.42), inset 0 1px 0 rgba(255, 255, 255, 0.52);
}

.btn--secundario,
.btn-secundario {
    color: #ffffff;
    background: rgba(255, 255, 255, 0.08);
    border: 1px solid rgba(234, 215, 162, 0.42);
    box-shadow: 0 14px 34px rgba(3, 12, 29, 0.18);
}

.btn--secundario:hover,
.btn-secundario:hover {
    color: #ffffff;
    background: rgba(201, 166, 95, 0.16);
    border-color: rgba(234, 215, 162, 0.7);
    box-shadow: 0 18px 42px rgba(3, 12, 29, 0.24);
}

.btn--claro {
    color: #07182f;
    background: rgba(255, 255, 255, 0.92);
    border: 1px solid rgba(201, 166, 95, 0.28);
    box-shadow: 0 14px 34px rgba(3, 12, 29, 0.14);
}

.seccion {
    position: relative;
}

.seccion:not(.seccion--oscura):not(.contacto-fondo) {
    background: rgba(248, 245, 238, 0.94);
}

.seccion--oscura,
.cta {
    background: linear-gradient(135deg, #07182f, #0c2549 58%, #102d57);
    border-top: 1px solid rgba(234, 215, 162, 0.18);
    border-bottom: 1px solid rgba(234, 215, 162, 0.18);
}

.servicio-card,
.area-card,
.portafolio-card,
.publicacion-card,
.noticia-card,
.rol-card,
.principio-card,
.confianza-card,
.categoria-juridica-card,
.panel,
.panel-card {
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.94), rgba(248, 245, 238, 0.9));
    border-radius: 26px;
    transition: transform 0.24s ease, box-shadow 0.24s ease, border-color 0.24s ease;
}

.servicio-card:hover,
.area-card:hover,
.portafolio-card:hover,
.publicacion-card:hover,
.noticia-card:hover,
.rol-card:hover,
.principio-card:hover,
.confianza-card:hover,
.categoria-juridica-card:hover,
.panel-card:hover {
    transform: translateY(-4px);
    border-color: rgba(201, 166, 95, 0.52);
    box-shadow: 0 28px 72px rgba(3, 12, 29, 0.24);
}

input,
select,
textarea {
    border-radius: 18px;
    border: 1px solid rgba(7, 24, 47, 0.14);
    background: rgba(255, 255, 255, 0.94);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.65);
}

input:focus,
select:focus,
textarea:focus {
    outline: none;
    border-color: rgba(201, 166, 95, 0.72);
    box-shadow: 0 0 0 4px rgba(201, 166, 95, 0.16);
}

.link-elegante {
    color: var(--jt-dorado);
    font-weight: 800;
}

.aviso,
.aviso-ok,
.aviso-error {
    border-radius: 20px;
    border: 1px solid rgba(201, 166, 95, 0.28);
    box-shadow: 0 18px 42px rgba(3, 12, 29, 0.12);
}

.footer {
    background: #061326;
    border-top: 1px solid rgba(234, 215, 162, 0.22);
}

.footer a:hover {
    color: var(--jt-dorado-claro);
}

@media (max-width: 980px) {
    .nav {
        background: rgba(7, 24, 47, 0.98);
        border: 1px solid rgba(234, 215, 162, 0.18);
        box-shadow: 0 24px 70px rgba(0, 0, 0, 0.34);
        backdrop-filter: blur(16px);
    }

    .nav a {
        border-radius: 16px;
    }

    body::before,
    .hero::before,
    .page-hero::before,
    .contacto-hero::before {
        background-position: center bottom;
        background-size: 780px auto;
        opacity: 0.72;
    }
}

@media (max-width: 640px) {
    .marca__texto small {
        display: none;
    }

    .hero__acciones,
    .cta__acciones,
    .acciones {
        align-items: stretch;
    }

    .btn,
    .btn-principal,
    .btn-secundario,
    .btn-v20 {
        justify-content: center;
        width: 100%;
    }
}

/* =========================================================
   Ajuste v23 - Menú principal en pestañas 3D con volumen
   ========================================================= */
.header .nav {
    gap: 9px;
    align-items: center;
    perspective: 1000px;
}

.header .nav a {
    position: relative;
    isolation: isolate;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 42px;
    padding: 10px 14px 11px;
    border-radius: 15px;
    color: rgba(7, 24, 47, 0.86);
    font-size: 0.86rem;
    font-weight: 900;
    letter-spacing: -0.015em;
    line-height: 1;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.98) 0%, rgba(246, 239, 225, 0.96) 48%, rgba(226, 213, 187, 0.95) 100%);
    border: 1px solid rgba(7, 24, 47, 0.10);
    box-shadow:
        0 11px 0 rgba(111, 86, 42, 0.28),
        0 18px 30px rgba(7, 24, 47, 0.16),
        inset 0 1px 0 rgba(255, 255, 255, 0.96),
        inset 0 -1px 0 rgba(120, 86, 35, 0.18);
    text-shadow: 0 1px 0 rgba(255, 255, 255, 0.72);
    transform: translateY(0) rotateX(0deg);
    transition:
        transform 0.20s ease,
        box-shadow 0.20s ease,
        color 0.20s ease,
        border-color 0.20s ease,
        background 0.20s ease;
}

.header .nav a::before {
    content: "";
    position: absolute;
    inset: 1px 1px auto 1px;
    height: 46%;
    z-index: -1;
    border-radius: 13px 13px 9px 9px;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.92), rgba(255, 255, 255, 0));
    pointer-events: none;
}

.header .nav a::after {
    content: "";
    position: absolute;
    left: 12px;
    right: 12px;
    bottom: 6px;
    width: auto;
    height: 3px;
    border-radius: 999px;
    background: linear-gradient(90deg, transparent, rgba(201, 166, 95, 0.98), transparent);
    opacity: 0;
    transform: scaleX(0.55);
    transform-origin: center;
    transition: opacity 0.20s ease, transform 0.20s ease;
}

.header .nav a:hover,
.header .nav a.is-active {
    color: #07182f;
    border-color: rgba(201, 166, 95, 0.58);
    background:
        linear-gradient(180deg, #fffdf8 0%, #f3e7cf 46%, #dcc28a 100%);
    box-shadow:
        0 7px 0 rgba(111, 86, 42, 0.34),
        0 20px 34px rgba(7, 24, 47, 0.20),
        inset 0 1px 0 rgba(255, 255, 255, 0.98),
        inset 0 -1px 0 rgba(120, 86, 35, 0.22);
    transform: translateY(4px) rotateX(3deg);
}

.header .nav a:hover::after,
.header .nav a.is-active::after {
    opacity: 1;
    transform: scaleX(1);
}

.header .nav .nav__privado {
    margin-left: 6px;
    color: #fffaf2 !important;
    background:
        linear-gradient(180deg, #213a55 0%, #0d2035 46%, #061326 100%);
    border-color: rgba(234, 215, 162, 0.32);
    box-shadow:
        0 11px 0 rgba(4, 12, 24, 0.58),
        0 20px 38px rgba(7, 24, 47, 0.30),
        inset 0 1px 0 rgba(255, 255, 255, 0.14),
        inset 0 -1px 0 rgba(0, 0, 0, 0.34);
    text-shadow: 0 1px 0 rgba(0, 0, 0, 0.38);
}

.header .nav .nav__privado::before {
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.16), rgba(255, 255, 255, 0));
}

.header .nav .nav__privado::after {
    background: linear-gradient(90deg, transparent, rgba(234, 215, 162, 0.96), transparent);
}

.header .nav .nav__privado:hover {
    color: #fffaf2 !important;
    background:
        linear-gradient(180deg, #2a4563 0%, #102842 48%, #07182f 100%);
    box-shadow:
        0 7px 0 rgba(4, 12, 24, 0.66),
        0 24px 44px rgba(7, 24, 47, 0.34),
        inset 0 1px 0 rgba(255, 255, 255, 0.16),
        inset 0 -1px 0 rgba(0, 0, 0, 0.36);
}

@media (max-width: 1180px) {
    .header .nav {
        gap: 7px;
    }

    .header .nav a {
        min-height: 39px;
        padding: 9px 11px 10px;
        font-size: 0.80rem;
        border-radius: 14px;
    }
}

@media (max-width: 980px) {
    .header .nav {
        align-items: stretch;
        gap: 11px;
        padding: 18px;
        perspective: none;
    }

    .header .nav a,
    .header .nav .nav__privado {
        width: 100%;
        min-height: 48px;
        padding: 14px 16px 15px;
        border-radius: 17px;
        font-size: 0.95rem;
        color: #fffaf2;
        background:
            linear-gradient(180deg, rgba(255, 255, 255, 0.10) 0%, rgba(255, 255, 255, 0.04) 48%, rgba(0, 0, 0, 0.20) 100%);
        border: 1px solid rgba(234, 215, 162, 0.18);
        box-shadow:
            0 8px 0 rgba(0, 0, 0, 0.30),
            0 16px 28px rgba(0, 0, 0, 0.22),
            inset 0 1px 0 rgba(255, 255, 255, 0.10);
        text-shadow: 0 1px 0 rgba(0, 0, 0, 0.35);
    }

    .header .nav a:hover,
    .header .nav a.is-active,
    .header .nav .nav__privado:hover {
        color: #fffaf2;
        background:
            linear-gradient(180deg, rgba(234, 215, 162, 0.26) 0%, rgba(201, 166, 95, 0.18) 48%, rgba(0, 0, 0, 0.22) 100%);
        transform: translateY(3px);
        box-shadow:
            0 5px 0 rgba(0, 0, 0, 0.36),
            0 18px 30px rgba(0, 0, 0, 0.26),
            inset 0 1px 0 rgba(255, 255, 255, 0.12);
    }

    .header .nav .nav__privado {
        margin-left: 0;
    }
}


/* =========================================================
   Ajuste v24 - Pestañas 3D profundas, visibles y sobresalientes
   ========================================================= */
.header,
.header__contenido,
.header .nav {
    overflow: visible !important;
}

.header {
    min-height: 96px !important;
    padding-top: 10px !important;
    padding-bottom: 18px !important;
    background:
        linear-gradient(180deg, rgba(5, 16, 32, 0.98), rgba(8, 24, 46, 0.94) 64%, rgba(8, 24, 46, 0.72)) !important;
    box-shadow:
        0 18px 40px rgba(0, 0, 0, 0.26),
        inset 0 -1px 0 rgba(234, 215, 162, 0.16) !important;
}

.header .nav {
    gap: 13px !important;
    align-items: center !important;
    perspective: 1200px !important;
    transform-style: preserve-3d !important;
    padding-bottom: 9px !important;
}

.header .nav a {
    position: relative !important;
    isolation: isolate !important;
    overflow: visible !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    min-height: 50px !important;
    padding: 14px 18px 15px !important;
    border-radius: 18px !important;
    color: #07182f !important;
    font-size: 0.88rem !important;
    font-weight: 950 !important;
    letter-spacing: -0.02em !important;
    line-height: 1 !important;
    text-decoration: none !important;
    background:
        linear-gradient(180deg, #fffefa 0%, #f7ecd4 42%, #d7bc7b 100%) !important;
    border: 1px solid rgba(255, 255, 255, 0.74) !important;
    outline: 1px solid rgba(83, 58, 20, 0.18) !important;
    outline-offset: -2px !important;
    text-shadow: 0 1px 0 rgba(255, 255, 255, 0.76) !important;
    transform: perspective(900px) translateY(-7px) translateZ(26px) rotateX(7deg) !important;
    transform-style: preserve-3d !important;
    box-shadow:
        0 2px 0 rgba(255, 255, 255, 0.96) inset,
        0 -4px 0 rgba(100, 70, 25, 0.22) inset,
        0 10px 0 #9a7737,
        0 14px 0 #5a421f,
        0 22px 26px rgba(0, 0, 0, 0.34),
        0 34px 48px rgba(0, 0, 0, 0.25) !important;
    transition:
        transform 0.18s ease,
        box-shadow 0.18s ease,
        background 0.18s ease,
        color 0.18s ease !important;
}

.header .nav a::before {
    content: "" !important;
    position: absolute !important;
    z-index: 1 !important;
    inset: 2px 3px auto 3px !important;
    height: 48% !important;
    border-radius: 16px 16px 10px 10px !important;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.92), rgba(255, 255, 255, 0.06)) !important;
    pointer-events: none !important;
}

.header .nav a::after {
    content: "" !important;
    position: absolute !important;
    z-index: -1 !important;
    left: 8px !important;
    right: 8px !important;
    bottom: -14px !important;
    width: auto !important;
    height: 16px !important;
    border-radius: 0 0 16px 16px !important;
    background:
        linear-gradient(180deg, #8e6d32 0%, #4c3719 100%) !important;
    opacity: 1 !important;
    transform: skewX(-14deg) scaleX(1) !important;
    transform-origin: top center !important;
    box-shadow:
        0 10px 18px rgba(0, 0, 0, 0.30),
        inset 0 1px 0 rgba(255, 255, 255, 0.18) !important;
    pointer-events: none !important;
}

.header .nav a:hover,
.header .nav a.is-active {
    color: #05101f !important;
    background:
        linear-gradient(180deg, #ffffff 0%, #fff2cc 40%, #c99b3e 100%) !important;
    transform: perspective(900px) translateY(-12px) translateZ(42px) rotateX(5deg) !important;
    box-shadow:
        0 2px 0 rgba(255, 255, 255, 0.98) inset,
        0 -4px 0 rgba(100, 70, 25, 0.24) inset,
        0 14px 0 #a9823e,
        0 19px 0 #4e3817,
        0 28px 34px rgba(0, 0, 0, 0.40),
        0 42px 62px rgba(0, 0, 0, 0.30) !important;
}

.header .nav a:hover::after,
.header .nav a.is-active::after {
    bottom: -18px !important;
    height: 19px !important;
    background: linear-gradient(180deg, #9f7938 0%, #483316 100%) !important;
}

.header .nav .nav__privado {
    margin-left: 7px !important;
    color: #fff9ed !important;
    background:
        linear-gradient(180deg, #2d4867 0%, #112b47 44%, #061426 100%) !important;
    border-color: rgba(234, 215, 162, 0.46) !important;
    outline-color: rgba(234, 215, 162, 0.22) !important;
    text-shadow: 0 1px 0 rgba(0, 0, 0, 0.48) !important;
    box-shadow:
        0 2px 0 rgba(255, 255, 255, 0.16) inset,
        0 -4px 0 rgba(0, 0, 0, 0.26) inset,
        0 10px 0 #04101f,
        0 14px 0 #020711,
        0 24px 32px rgba(0, 0, 0, 0.42),
        0 38px 58px rgba(0, 0, 0, 0.30) !important;
}

.header .nav .nav__privado::after {
    background: linear-gradient(180deg, #061426 0%, #01050b 100%) !important;
}

.header .nav .nav__privado:hover,
.header .nav .nav__privado.is-active {
    color: #fff9ed !important;
    background:
        linear-gradient(180deg, #395a7f 0%, #153555 46%, #07182f 100%) !important;
    box-shadow:
        0 2px 0 rgba(255, 255, 255, 0.18) inset,
        0 -4px 0 rgba(0, 0, 0, 0.28) inset,
        0 14px 0 #04101f,
        0 19px 0 #020711,
        0 30px 38px rgba(0, 0, 0, 0.46),
        0 46px 66px rgba(0, 0, 0, 0.34) !important;
}

@media (max-width: 1220px) {
    .header .nav {
        gap: 10px !important;
    }

    .header .nav a {
        min-height: 46px !important;
        padding: 12px 13px 13px !important;
        font-size: 0.80rem !important;
        border-radius: 16px !important;
    }
}

@media (max-width: 980px) {
    .header {
        min-height: 78px !important;
        padding-bottom: 10px !important;
    }

    .header .nav {
        gap: 16px !important;
        padding: 22px !important;
        perspective: 900px !important;
    }

    .header .nav a,
    .header .nav .nav__privado {
        width: 100% !important;
        min-height: 54px !important;
        padding: 16px 18px !important;
        border-radius: 18px !important;
        color: #fff9ed !important;
        background:
            linear-gradient(180deg, #2d4867 0%, #132d49 48%, #07182f 100%) !important;
        border-color: rgba(234, 215, 162, 0.36) !important;
        transform: perspective(800px) translateY(-5px) translateZ(20px) rotateX(5deg) !important;
        text-shadow: 0 1px 0 rgba(0, 0, 0, 0.42) !important;
        box-shadow:
            0 2px 0 rgba(255, 255, 255, 0.16) inset,
            0 -4px 0 rgba(0, 0, 0, 0.24) inset,
            0 10px 0 #020b16,
            0 16px 26px rgba(0, 0, 0, 0.38) !important;
    }

    .header .nav a::after,
    .header .nav .nav__privado::after {
        bottom: -13px !important;
        height: 15px !important;
        background: linear-gradient(180deg, #061426 0%, #01050b 100%) !important;
    }

    .header .nav a:hover,
    .header .nav a.is-active,
    .header .nav .nav__privado:hover {
        color: #fff9ed !important;
        transform: perspective(800px) translateY(-9px) translateZ(32px) rotateX(4deg) !important;
        background:
            linear-gradient(180deg, #3b5c80 0%, #183a5b 48%, #07182f 100%) !important;
        box-shadow:
            0 2px 0 rgba(255, 255, 255, 0.18) inset,
            0 -4px 0 rgba(0, 0, 0, 0.25) inset,
            0 13px 0 #020b16,
            0 22px 32px rgba(0, 0, 0, 0.42) !important;
    }
}

/* =========================================================
   V25 - Pestañas superiores 3D con volumen real visible
   ========================================================= */
.header {
    overflow: visible !important;
    background: linear-gradient(180deg, #fffaf1 0%, #f3eadc 100%) !important;
    box-shadow: 0 14px 32px rgba(7, 24, 47, 0.18), inset 0 -1px 0 rgba(184,149,90,0.22) !important;
}
.header__contenido,
.header .nav {
    overflow: visible !important;
}
.header .nav {
    gap: 12px !important;
    align-items: center !important;
    perspective: 1200px !important;
    transform-style: preserve-3d !important;
    padding: 10px 0 16px !important;
}
.header .nav a,
.header .nav .nav__privado {
    position: relative !important;
    isolation: isolate !important;
    overflow: visible !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    min-height: 48px !important;
    padding: 13px 17px 14px !important;
    border-radius: 18px !important;
    font-size: 0.86rem !important;
    font-weight: 900 !important;
    line-height: 1 !important;
    letter-spacing: -0.018em !important;
    text-decoration: none !important;
    color: #fff8ea !important;
    background: linear-gradient(180deg, #2f4a67 0%, #142f4b 48%, #07182f 100%) !important;
    border: 1px solid rgba(255, 255, 255, 0.24) !important;
    text-shadow: 0 1px 0 rgba(0,0,0,0.48) !important;
    transform: translateY(-8px) translateZ(34px) rotateX(8deg) !important;
    transform-style: preserve-3d !important;
    box-shadow:
        inset 0 2px 0 rgba(255,255,255,0.22),
        inset 0 -4px 0 rgba(0,0,0,0.26),
        0 9px 0 #041427,
        0 15px 0 #020815,
        0 24px 28px rgba(7,24,47,0.34),
        0 38px 54px rgba(7,24,47,0.22) !important;
    transition: transform .16s ease, box-shadow .16s ease, background .16s ease, color .16s ease !important;
}
.header .nav a::before,
.header .nav .nav__privado::before {
    content: "" !important;
    position: absolute !important;
    z-index: 1 !important;
    left: 4px !important;
    right: 4px !important;
    top: 3px !important;
    height: 48% !important;
    border-radius: 15px 15px 9px 9px !important;
    background: linear-gradient(180deg, rgba(255,255,255,0.30), rgba(255,255,255,0.02)) !important;
    pointer-events: none !important;
}
.header .nav a::after,
.header .nav .nav__privado::after {
    content: "" !important;
    position: absolute !important;
    z-index: -1 !important;
    left: 9px !important;
    right: 9px !important;
    bottom: -15px !important;
    height: 17px !important;
    border-radius: 0 0 16px 16px !important;
    background: linear-gradient(180deg, #041427 0%, #01050b 100%) !important;
    opacity: 1 !important;
    transform: skewX(-13deg) scaleX(1) !important;
    transform-origin: top center !important;
    box-shadow: 0 12px 22px rgba(0,0,0,0.32), inset 0 1px 0 rgba(255,255,255,0.10) !important;
    pointer-events: none !important;
}
.header .nav a:hover,
.header .nav a.is-active {
    color: #07182f !important;
    background: linear-gradient(180deg, #fffdfa 0%, #f5dfad 43%, #c49a45 100%) !important;
    border-color: rgba(255,255,255,0.86) !important;
    text-shadow: 0 1px 0 rgba(255,255,255,0.72) !important;
    transform: translateY(-15px) translateZ(54px) rotateX(5deg) !important;
    box-shadow:
        inset 0 2px 0 rgba(255,255,255,0.95),
        inset 0 -4px 0 rgba(92,62,18,0.24),
        0 13px 0 #8e692c,
        0 20px 0 #4a3214,
        0 30px 34px rgba(7,24,47,0.38),
        0 48px 70px rgba(7,24,47,0.28) !important;
}
.header .nav a:hover::before,
.header .nav a.is-active::before {
    background: linear-gradient(180deg, rgba(255,255,255,0.92), rgba(255,255,255,0.10)) !important;
}
.header .nav a:hover::after,
.header .nav a.is-active::after {
    bottom: -20px !important;
    height: 21px !important;
    background: linear-gradient(180deg, #8e692c 0%, #4a3214 100%) !important;
}
.header .nav .nav__privado {
    margin-left: 8px !important;
    color: #fff8ea !important;
    background: linear-gradient(180deg, #0d2035 0%, #07182f 48%, #020915 100%) !important;
    box-shadow:
        inset 0 2px 0 rgba(255,255,255,0.14),
        inset 0 -4px 0 rgba(0,0,0,0.36),
        0 10px 0 #020815,
        0 16px 0 #00030a,
        0 26px 32px rgba(7,24,47,0.44),
        0 42px 62px rgba(7,24,47,0.30) !important;
}
.header .nav .nav__privado:hover {
    color: #07182f !important;
    background: linear-gradient(180deg, #fffdfa 0%, #f5dfad 43%, #c49a45 100%) !important;
}
@media (max-width: 1220px) {
    .header .nav { gap: 8px !important; }
    .header .nav a, .header .nav .nav__privado {
        min-height: 44px !important;
        padding: 12px 12px 13px !important;
        font-size: .78rem !important;
        border-radius: 16px !important;
    }
}
@media (max-width: 980px) {
    .header .nav {
        gap: 15px !important;
        padding: 22px !important;
        perspective: 900px !important;
    }
    .header .nav a, .header .nav .nav__privado {
        width: 100% !important;
        min-height: 54px !important;
        padding: 16px 18px !important;
        border-radius: 18px !important;
        font-size: .95rem !important;
        transform: translateY(-6px) translateZ(22px) rotateX(5deg) !important;
    }
}

/* =========================================================
   JUSTICIA TARAPACÁ — PALETA CORPORATIVA ABOGADO V26
   Elegante, sobria, jurídica: azul tinta + marfil + burdeos + oro viejo
   ========================================================= */
:root {
    --jt-navy: #071522;
    --jt-navy-2: #102335;
    --jt-navy-3: #1d3348;
    --jt-ink: #0b1722;
    --jt-cream: #f4efe5;
    --jt-cream-2: #ebe2d4;
    --jt-card: #fffaf2;
    --jt-gold: #b48a45;
    --jt-gold-2: #d7b46a;
    --jt-burgundy: #6f1d2c;
    --jt-burgundy-2: #8b2737;
    --jt-muted: #5d6670;
}

html,
body {
    background:
        radial-gradient(circle at 78% 14%, rgba(180,138,69,.16), transparent 34%),
        radial-gradient(circle at 12% 88%, rgba(7,21,34,.10), transparent 38%),
        linear-gradient(135deg, #f8f4ec 0%, #eee5d7 46%, #e4dac9 100%) !important;
    color: var(--jt-ink) !important;
}

body::before {
    opacity: .075 !important;
    filter: sepia(.22) saturate(.9) contrast(1.05) !important;
}

body::after {
    background:
        linear-gradient(90deg, rgba(7,21,34,.065) 1px, transparent 1px),
        linear-gradient(180deg, rgba(7,21,34,.045) 1px, transparent 1px) !important;
    background-size: 42px 42px !important;
    opacity: .18 !important;
}

.header {
    background: linear-gradient(180deg, rgba(255,250,242,.98) 0%, rgba(239,230,216,.96) 100%) !important;
    border-bottom: 1px solid rgba(7,21,34,.14) !important;
    box-shadow: 0 18px 42px rgba(7,21,34,.16), inset 0 -1px 0 rgba(255,255,255,.65) !important;
}

.logo__marca {
    color: var(--jt-ink) !important;
}

.logo__subtitulo,
.hero__texto,
.section__texto,
.card p,
.footer p,
.footer a,
.contacto__texto,
.muted {
    color: var(--jt-muted) !important;
}

.logo__icono {
    background: linear-gradient(145deg, #16283a 0%, #071522 100%) !important;
    border: 1px solid rgba(215,180,106,.45) !important;
    box-shadow: 0 14px 28px rgba(7,21,34,.26), inset 0 1px 0 rgba(255,255,255,.13) !important;
}

/* Pestañas 3D con presencia jurídica */
.header .nav a,
.header .nav .nav__privado {
    color: #fff8ea !important;
    background: linear-gradient(180deg, #253d54 0%, #102335 48%, #071522 100%) !important;
    border: 1px solid rgba(215,180,106,.34) !important;
    box-shadow:
        inset 0 2px 0 rgba(255,255,255,.18),
        inset 0 -4px 0 rgba(0,0,0,.32),
        0 9px 0 #04101d,
        0 15px 0 #01050a,
        0 24px 28px rgba(7,21,34,.38),
        0 38px 54px rgba(7,21,34,.24) !important;
}

.header .nav a::after,
.header .nav .nav__privado::after {
    background: linear-gradient(180deg, #04101d 0%, #01050a 100%) !important;
}

.header .nav a:hover,
.header .nav a.is-active {
    color: #fffaf2 !important;
    background: linear-gradient(180deg, #9c3444 0%, #6f1d2c 48%, #45101a 100%) !important;
    border-color: rgba(215,180,106,.72) !important;
    text-shadow: 0 1px 0 rgba(0,0,0,.42) !important;
    box-shadow:
        inset 0 2px 0 rgba(255,255,255,.22),
        inset 0 -4px 0 rgba(0,0,0,.30),
        0 13px 0 #321018,
        0 20px 0 #16070b,
        0 30px 34px rgba(7,21,34,.42),
        0 48px 70px rgba(7,21,34,.30) !important;
}

.header .nav a:hover::after,
.header .nav a.is-active::after {
    background: linear-gradient(180deg, #321018 0%, #16070b 100%) !important;
}

.header .nav .nav__privado {
    background: linear-gradient(180deg, #bf9857 0%, #8d682d 50%, #4e3515 100%) !important;
    color: #fffaf2 !important;
    border-color: rgba(255,255,255,.32) !important;
    box-shadow:
        inset 0 2px 0 rgba(255,255,255,.25),
        inset 0 -4px 0 rgba(0,0,0,.26),
        0 10px 0 #4e3515,
        0 16px 0 #241606,
        0 26px 32px rgba(7,21,34,.34),
        0 42px 62px rgba(7,21,34,.24) !important;
}

/* Secciones principales */
.hero,
.section,
.page-hero,
.contacto-hero {
    background: transparent !important;
}

.hero__label,
.section__label,
.eyebrow,
.kicker,
.card__number {
    color: var(--jt-gold) !important;
}

.hero__label::before,
.section__label::before,
.eyebrow::before,
.kicker::before {
    background: linear-gradient(90deg, var(--jt-burgundy), var(--jt-gold)) !important;
}

h1,
h2,
h3,
.hero__titulo,
.section__titulo,
.card h3,
.contacto__titulo {
    color: var(--jt-ink) !important;
}

.hero__panel,
.panel,
.dark-panel,
.cta-dark,
.footer,
.footer-principal {
    background: linear-gradient(145deg, #132638 0%, #071522 100%) !important;
    color: #fffaf2 !important;
    border-color: rgba(215,180,106,.20) !important;
    box-shadow: 0 26px 58px rgba(7,21,34,.28), inset 0 1px 0 rgba(255,255,255,.08) !important;
}

.hero__panel h2,
.hero__panel h3,
.panel h2,
.panel h3,
.dark-panel h2,
.dark-panel h3,
.footer h2,
.footer h3,
.footer strong {
    color: #fffaf2 !important;
}

.hero__panel p,
.panel p,
.dark-panel p,
.footer p,
.footer a {
    color: rgba(255,250,242,.78) !important;
}

.card,
.service-card,
.info-card,
.contact-card,
.portfolio-card,
.news-card,
.feature-card,
.stat-card {
    background: linear-gradient(180deg, rgba(255,250,242,.96) 0%, rgba(247,240,229,.94) 100%) !important;
    border: 1px solid rgba(7,21,34,.10) !important;
    box-shadow: 0 20px 42px rgba(7,21,34,.13), inset 0 1px 0 rgba(255,255,255,.88) !important;
}

.card:hover,
.service-card:hover,
.info-card:hover,
.contact-card:hover,
.portfolio-card:hover,
.news-card:hover,
.feature-card:hover {
    border-color: rgba(180,138,69,.34) !important;
    box-shadow: 0 28px 58px rgba(7,21,34,.18), inset 0 1px 0 rgba(255,255,255,.92) !important;
}

.btn,
.button,
a.button,
.hero__button,
.cta__button,
.form button,
button[type="submit"] {
    background: linear-gradient(180deg, #9a3243 0%, #6f1d2c 52%, #47111b 100%) !important;
    color: #fffaf2 !important;
    border: 1px solid rgba(215,180,106,.45) !important;
    box-shadow: 0 12px 0 #321018, 0 22px 30px rgba(7,21,34,.26), inset 0 1px 0 rgba(255,255,255,.18) !important;
}

.btn:hover,
.button:hover,
a.button:hover,
.hero__button:hover,
.cta__button:hover,
.form button:hover,
button[type="submit"]:hover {
    background: linear-gradient(180deg, #bd9955 0%, #967038 54%, #553918 100%) !important;
    color: #fffaf2 !important;
    box-shadow: 0 15px 0 #4e3515, 0 28px 38px rgba(7,21,34,.30), inset 0 1px 0 rgba(255,255,255,.24) !important;
}

.whatsapp,
.whatsapp-float,
.whatsapp__boton,
a[href*="wa.me"].whatsapp {
    background: linear-gradient(180deg, #1fa463 0%, #137a49 100%) !important;
    box-shadow: 0 18px 34px rgba(19,122,73,.30), inset 0 1px 0 rgba(255,255,255,.20) !important;
}

input,
textarea,
select {
    background: rgba(255,250,242,.96) !important;
    border-color: rgba(7,21,34,.16) !important;
    color: var(--jt-ink) !important;
}

input:focus,
textarea:focus,
select:focus {
    border-color: rgba(111,29,44,.52) !important;
    box-shadow: 0 0 0 4px rgba(111,29,44,.10) !important;
}

::selection {
    background: rgba(111,29,44,.22) !important;
    color: var(--jt-ink) !important;
}

/* =========================================================
   V27 - Fondo premium medio para abogado
   Más sobrio que marfil claro, sin oscurecer el contenido.
   ========================================================= */
:root {
    --jt-bg-base: #d7cbb7;
    --jt-bg-mid: #c7b89f;
    --jt-bg-deep: #b9aa91;
    --jt-surface: #f3ecdf;
    --jt-surface-2: #eee4d4;
    --jt-border-soft: rgba(8, 22, 34, .16);
}

html,
body {
    background:
        radial-gradient(circle at 78% 10%, rgba(111, 29, 44, .105), transparent 31%),
        radial-gradient(circle at 18% 88%, rgba(7, 21, 34, .14), transparent 42%),
        linear-gradient(135deg, var(--jt-bg-base) 0%, var(--jt-bg-mid) 50%, var(--jt-bg-deep) 100%) !important;
    color: #081622 !important;
}

body::before {
    opacity: .095 !important;
    filter: sepia(.28) saturate(.82) contrast(1.08) !important;
}

body::after {
    background:
        linear-gradient(90deg, rgba(7,21,34,.075) 1px, transparent 1px),
        linear-gradient(180deg, rgba(7,21,34,.055) 1px, transparent 1px) !important;
    background-size: 46px 46px !important;
    opacity: .16 !important;
}

.header {
    background: linear-gradient(180deg, rgba(242, 234, 219, .985) 0%, rgba(219, 207, 185, .965) 100%) !important;
    border-bottom: 1px solid rgba(7,21,34,.20) !important;
    box-shadow:
        0 18px 46px rgba(7,21,34,.22),
        inset 0 1px 0 rgba(255,255,255,.58),
        inset 0 -1px 0 rgba(90,68,38,.16) !important;
}

.logo__marca,
.header .logo__marca,
.header__brand strong,
.header__brand span:first-child {
    color: #071522 !important;
    text-shadow: none !important;
}

.logo__subtitulo,
.header .logo__subtitulo,
.header__brand small {
    color: #4f5963 !important;
    text-shadow: none !important;
}

.hero,
.section,
.page-hero,
.contacto-hero,
main > section {
    background: transparent !important;
}

.hero::before,
.section::before,
.page-hero::before,
.contacto-hero::before {
    opacity: .08 !important;
}

.hero__titulo,
h1,
h2,
h3,
.section__titulo,
.contacto__titulo {
    color: #071522 !important;
    text-shadow: 0 1px 0 rgba(255,255,255,.24) !important;
}

.hero__texto,
.section__texto,
.card p,
.service-card p,
.info-card p,
.contact-card p,
.portfolio-card p,
.news-card p {
    color: #48515b !important;
}

.card,
.service-card,
.info-card,
.contact-card,
.portfolio-card,
.news-card,
.feature-card,
.stat-card,
.hero__card,
.contacto__card {
    background: linear-gradient(180deg, rgba(246,239,226,.96) 0%, rgba(232,221,203,.94) 100%) !important;
    border: 1px solid rgba(7,21,34,.13) !important;
    box-shadow:
        0 22px 48px rgba(7,21,34,.18),
        inset 0 1px 0 rgba(255,255,255,.78) !important;
}

.hero__panel,
.panel,
.dark-panel,
.cta-dark {
    background: linear-gradient(145deg, #183149 0%, #071522 100%) !important;
    border: 1px solid rgba(215,180,106,.23) !important;
    box-shadow:
        0 28px 62px rgba(7,21,34,.34),
        inset 0 1px 0 rgba(255,255,255,.09) !important;
}

.footer,
.footer-principal {
    background: linear-gradient(145deg, #12283d 0%, #06121f 100%) !important;
}

/* Área clara del hero: se mantiene legible, pero no queda blanco plano */
.hero__visual,
.hero__mockup,
.hero__box,
.contacto__panel {
    background: linear-gradient(145deg, rgba(231,222,205,.88), rgba(214,202,180,.72)) !important;
    border-color: rgba(7,21,34,.12) !important;
}

.header .nav a,
.header .nav .nav__privado {
    box-shadow:
        inset 0 2px 0 rgba(255,255,255,.18),
        inset 0 -4px 0 rgba(0,0,0,.32),
        0 9px 0 #04101d,
        0 15px 0 #01050a,
        0 24px 32px rgba(7,21,34,.44),
        0 40px 58px rgba(7,21,34,.28) !important;
}

.header .nav a.is-active,
.header .nav a:hover,
.header .nav .nav__privado:hover {
    box-shadow:
        inset 0 2px 0 rgba(255,255,255,.22),
        inset 0 -4px 0 rgba(0,0,0,.28),
        0 13px 0 #321018,
        0 20px 0 #16070b,
        0 30px 36px rgba(7,21,34,.46),
        0 50px 74px rgba(7,21,34,.31) !important;
}

/* =========================================================
   AJUSTE V28 - PORTADA PROFESIONAL ABOGADO
   Mejora lectura del hero, reduce exceso de tamaño y ordena el bloque inicial.
   ========================================================= */

:root{
    --jt-fondo-base: #d7cbb8;
    --jt-fondo-suave: #e5dccd;
    --jt-fondo-claro-controlado: #eee7dc;
    --jt-tinta: #111c27;
    --jt-tinta-suave: rgba(17, 28, 39, .74);
    --jt-oro: #b58b45;
    --jt-oro-profundo: #8a642c;
    --jt-azul: #0d1b2a;
    --jt-azul-2: #16283a;
}

body{
    background:
        radial-gradient(circle at 14% 8%, rgba(255,255,255,.34), transparent 34%),
        radial-gradient(circle at 84% 18%, rgba(13,27,42,.10), transparent 36%),
        linear-gradient(135deg, #d2c5b1 0%, #e7dfd1 42%, #cbbda7 100%) !important;
}

.header{
    background: rgba(229, 221, 208, .94) !important;
    border-bottom: 1px solid rgba(13, 27, 42, .18) !important;
    box-shadow: 0 18px 44px rgba(13, 27, 42, .16) !important;
    backdrop-filter: blur(18px);
}

.marca__texto strong{
    color: #101b27 !important;
    text-shadow: none !important;
}

.marca__texto span{
    color: rgba(16, 27, 39, .68) !important;
}

.hero{
    min-height: calc(100vh - 98px) !important;
    display: flex;
    align-items: center;
    padding-top: clamp(72px, 8vh, 110px) !important;
    padding-bottom: clamp(72px, 9vh, 120px) !important;
    background:
        linear-gradient(90deg, rgba(232,224,211,.97) 0%, rgba(232,224,211,.88) 38%, rgba(232,224,211,.55) 64%, rgba(232,224,211,.34) 100%),
        url('../img/tribunal-institucional.svg') right 56% / min(880px, 56vw) auto no-repeat !important;
}

.hero::before{
    background:
        radial-gradient(circle at 73% 28%, rgba(181,139,69,.22), transparent 34%),
        radial-gradient(circle at 22% 24%, rgba(255,255,255,.28), transparent 35%),
        linear-gradient(180deg, rgba(255,255,255,.18), rgba(202,190,170,.48)) !important;
}

.hero::after{
    right: -8% !important;
    top: 16% !important;
    width: 50% !important;
    height: 72% !important;
    background: linear-gradient(135deg, rgba(13,27,42,.13), rgba(181,139,69,.12)) !important;
    border: 1px solid rgba(255,255,255,.30) !important;
}

.hero__contenido{
    grid-template-columns: minmax(0, .94fr) minmax(390px, .82fr) !important;
    gap: clamp(42px, 5.5vw, 86px) !important;
    border: 0 !important;
    box-shadow: none !important;
}

.hero h1{
    max-width: 710px !important;
    font-size: clamp(3.15rem, 5.55vw, 5.45rem) !important;
    line-height: .91 !important;
    letter-spacing: -.068em !important;
    text-wrap: balance;
}

.hero p{
    max-width: 610px !important;
    color: rgba(17, 28, 39, .78) !important;
}

.hero__eyebrow{
    color: #9a7130 !important;
    font-weight: 900 !important;
    letter-spacing: .105em !important;
}

.hero__panel{
    border: 1px solid rgba(13,27,42,.20) !important;
    box-shadow: 0 34px 80px rgba(13,27,42,.28), 0 12px 26px rgba(181,139,69,.16) !important;
}

.panel-card:first-child{
    background: linear-gradient(145deg, #132435 0%, #0b1621 100%) !important;
    color: #ffffff !important;
    border: 1px solid rgba(255,255,255,.15) !important;
}

.panel-card:first-child span,
.panel-card:first-child strong{
    color: #ffffff !important;
}

.panel-card{
    background: rgba(245,242,236,.88) !important;
    border: 1px solid rgba(13,27,42,.12) !important;
    box-shadow: 0 22px 54px rgba(13,27,42,.16) !important;
}

@media (max-width: 980px){
    .hero{
        background:
            linear-gradient(180deg, rgba(232,224,211,.97), rgba(232,224,211,.84)),
            url('../img/tribunal-institucional.svg') center 20% / 115% auto no-repeat !important;
    }
    .hero__contenido{
        grid-template-columns: 1fr !important;
    }
    .hero h1{
        font-size: clamp(2.55rem, 12vw, 4.2rem) !important;
    }
}

/* =========================================================
   AJUSTE V29 - CORRECCIÓN DE LEGIBILIDAD EN INICIO
   Mejora contraste del panel derecho del hero, enlaces laterales y bloque Equipo.
   ========================================================= */

.hero__panel .panel-card:not(:first-child) {
    background: rgba(250, 247, 241, 0.96) !important;
    border: 1px solid rgba(13, 27, 42, 0.16) !important;
    box-shadow: 0 18px 40px rgba(13, 27, 42, 0.10) !important;
}

.hero__panel .panel-card:not(:first-child) span {
    color: rgba(17, 28, 39, 0.72) !important;
    font-weight: 700 !important;
}

.hero__panel .panel-card:not(:first-child) strong {
    color: #111c27 !important;
    text-shadow: none !important;
}

.link-elegante {
    color: #102338 !important;
    border-bottom-color: #b58b45 !important;
    text-shadow: none !important;
    font-weight: 900 !important;
}

.seccion__cabecera .link-elegante:hover {
    color: #0b1a29 !important;
    border-bottom-color: #8a642c !important;
}

.texto-destacado {
    background: linear-gradient(180deg, rgba(247, 242, 234, 0.92), rgba(236, 227, 213, 0.88)) !important;
    border: 1px solid rgba(13, 27, 42, 0.12) !important;
    box-shadow: 0 20px 48px rgba(13, 27, 42, 0.12) !important;
}

.texto-destacado p {
    color: #22303d !important;
    text-shadow: none !important;
}

.texto-destacado .btn--claro {
    color: #ffffff !important;
    background: linear-gradient(135deg, #8f1f35 0%, #6e1226 58%, #4f0c1b 100%) !important;
    border: 1px solid rgba(255,255,255,0.16) !important;
    box-shadow: 0 16px 34px rgba(79, 12, 27, 0.26) !important;
}

.texto-destacado .btn--claro:hover {
    color: #ffffff !important;
    background: linear-gradient(135deg, #a0263f 0%, #7a162b 58%, #5a0e1f 100%) !important;
}

@media (max-width: 980px) {
    .seccion__cabecera .link-elegante {
        display: inline-flex !important;
        width: fit-content !important;
    }
}


/* =========================================================
   V30 - Integración logo 3D Justicia Tarapacá
   ========================================================= */
.marca {
    align-items: center !important;
    gap: 14px !important;
}
.marca__simbolo--logo {
    width: 70px !important;
    height: 70px !important;
    min-width: 70px !important;
    padding: 0 !important;
    background: transparent !important;
    border: 0 !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    overflow: visible !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}
.marca__logo {
    width: 88px !important;
    height: 88px !important;
    object-fit: contain !important;
    display: block !important;
    filter: drop-shadow(0 16px 18px rgba(5, 12, 22, .34)) drop-shadow(0 2px 0 rgba(255,255,255,.35));
    transform: translateY(1px);
}
.header .marca__texto strong,
.agenda-header .marca__texto strong {
    letter-spacing: -.02em !important;
}
@media (max-width: 720px) {
    .marca__simbolo--logo {
        width: 58px !important;
        height: 58px !important;
        min-width: 58px !important;
    }
    .marca__logo {
        width: 72px !important;
        height: 72px !important;
    }
}


/* ===== Icono flotante jurídico 3D ===== */
.whatsapp-flotante.whatsapp-flotante--legal {
    right: 22px;
    bottom: 22px;
    width: 88px;
    height: 88px;
    min-width: 88px;
    min-height: 88px;
    padding: 7px;
    border-radius: 50%;
    background:
        radial-gradient(circle at 30% 25%, rgba(255,255,255,0.96), rgba(255,255,255,0.25) 32%, transparent 33%),
        linear-gradient(145deg, #f4ead5 0%, #dbc59a 52%, #b8934f 100%);
    border: 1px solid rgba(177, 140, 71, 0.72);
    box-shadow:
        0 16px 36px rgba(7, 19, 33, 0.24),
        0 6px 14px rgba(7, 19, 33, 0.16),
        inset 0 2px 0 rgba(255, 255, 255, 0.72),
        inset 0 -10px 18px rgba(113, 82, 28, 0.2);
}

.whatsapp-flotante.whatsapp-flotante--legal img {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: cover;
    border-radius: 50%;
    box-shadow:
        0 10px 18px rgba(9, 24, 41, 0.16),
        inset 0 0 0 1px rgba(255, 255, 255, 0.25);
}

.whatsapp-flotante.whatsapp-flotante--legal:hover {
    transform: translateY(-6px) scale(1.04);
    background:
        radial-gradient(circle at 30% 24%, rgba(255,255,255,1), rgba(255,255,255,0.28) 32%, transparent 33%),
        linear-gradient(145deg, #f8efdd 0%, #e4d0a8 54%, #c19b58 100%);
    box-shadow:
        0 22px 42px rgba(7, 19, 33, 0.3),
        0 8px 18px rgba(7, 19, 33, 0.2),
        inset 0 2px 0 rgba(255, 255, 255, 0.8),
        inset 0 -12px 20px rgba(113, 82, 28, 0.24);
}

.whatsapp-flotante.whatsapp-flotante--legal::after {
    content: "Consulta directa";
    position: absolute;
    right: calc(100% + 12px);
    top: 50%;
    transform: translateY(-50%);
    padding: 8px 12px;
    border-radius: 999px;
    background: rgba(9, 24, 41, 0.92);
    color: #f7f1e6;
    font-size: 0.82rem;
    font-weight: 800;
    letter-spacing: 0.01em;
    white-space: nowrap;
    box-shadow: 0 12px 24px rgba(9, 24, 41, 0.22);
    opacity: 0;
    pointer-events: none;
    transition: opacity var(--transicion), transform var(--transicion);
}

.whatsapp-flotante.whatsapp-flotante--legal:hover::after {
    opacity: 1;
    transform: translateY(-50%) translateX(-4px);
}

@media (max-width: 820px) {
    .whatsapp-flotante.whatsapp-flotante--legal {
        width: 78px;
        height: 78px;
        min-width: 78px;
        min-height: 78px;
        right: 16px;
        bottom: 16px;
    }

    .whatsapp-flotante.whatsapp-flotante--legal::after {
        display: none;
    }
}
