﻿/* WebSOL — estilos parte pública (portada, cabecera sitio público, formulario presupuesto).
   Capas: orden = precedencia creciente entre reglas del mismo peso en capas distintas. */

/* Fuentes Roboto: declaradas en app.css (@layer app-fundaciones) para toda la app. */

@layer publico-base, publico-marco, publico-portada, publico-inicio-sesion, publico-presupuesto, publico-legal, publico-contacto;

@layer publico-base {
    :root {
        --publico-navy: #0d325e;
        --publico-acento: #ffcc4d;
        --publico-crema: #fff9e6;
        --publico-beige: #ffe7a1;
        --publico-blanco: #ffffff;
        --publico-texto-navy: #0d325e;
        --publico-texto-suave: rgba(13, 50, 94, 0.82);
        --publico-hero-overlay: linear-gradient(160deg, rgba(13, 50, 94, 0.72) 0%, rgba(13, 50, 94, 0.45) 42%, rgba(13, 50, 94, 0.78) 100%);
        --publico-ancho: min(72rem, calc(100% - 2.5rem));
    }

    .publico-layout-root {
        display: flex;
        flex-direction: column;
        font-family: Roboto, "Helvetica Neue", Helvetica, sans-serif;
        -webkit-font-smoothing: antialiased;
        min-height: 100vh;
        background: var(--publico-blanco);
        color: var(--publico-texto-navy);
        user-select: none;
        cursor: auto;
    }

    .publico-layout-root .selecc,
    .publico-layout-root input,
    .publico-layout-root textarea,
    .publico-layout-root select,
    .publico-layout-root button,
    .publico-layout-root .publico-legal,
    .publico-layout-root .publico-legal-pagina__contenido {
        user-select: text;
        cursor: auto;
    }

    .publico-layout-root h1:focus {
        outline: none;
    }

    .correo-publico {
        display: inline-flex;
        align-items: baseline;
        white-space: nowrap;
    }

    .correo-publico__arroba {
        width: 0.95em;
        height: 0.95em;
        margin: 0 0.03em;
        transform: translateY(0.18em);
        fill: currentColor;
    }

    .publico-saltar {
        position: absolute;
        left: -9999px;
        top: auto;
        width: 1px;
        height: 1px;
        overflow: hidden;
    }
    .publico-saltar:focus {
        position: fixed;
        left: 1rem;
        top: 1rem;
        z-index: 2000;
        width: auto;
        height: auto;
        padding: 0.5rem 1rem;
        background: var(--publico-blanco);
        color: #000;
        overflow: visible;
        clip: auto;
    }
}

@layer publico-contacto {
    .contacto-rapido {
        min-height: 100dvh;
        display: grid;
        place-items: center;
        padding: 1.25rem;
        background:
            radial-gradient(circle at top left, rgba(255, 204, 77, 0.35), transparent 42%),
            linear-gradient(160deg, var(--publico-navy), #174977);
        color: var(--publico-blanco);
    }

    .contacto-rapido__tarjeta {
        width: min(100%, 28rem);
        padding: clamp(1.25rem, 6vw, 2rem);
        border-radius: 1.35rem;
        background: rgba(255, 255, 255, 0.96);
        color: var(--publico-navy);
        box-shadow: 0 1.25rem 3rem rgba(0, 0, 0, 0.25);
        text-align: center;
    }

    .contacto-rapido__logo {
        display: block;
        width: min(18rem, 82%);
        height: auto;
        margin: 0 auto 1.1rem;
    }

    .contacto-rapido__etiqueta {
        margin: 0 0 0.45rem;
        text-transform: uppercase;
        letter-spacing: 0.08em;
        font-size: 0.75rem;
        font-weight: 700;
        color: rgba(13, 50, 94, 0.72);
    }

    .contacto-rapido h1 {
        margin: 0;
        font-size: clamp(1.45rem, 8vw, 2.1rem);
        line-height: 1.08;
    }

    .contacto-rapido__texto {
        margin: 0.85rem 0 1.35rem;
        color: var(--publico-texto-suave);
        font-size: 1rem;
        line-height: 1.45;
    }

    .contacto-rapido__acciones {
        display: grid;
        gap: 0.75rem;
    }

    .contacto-rapido__boton {
        display: flex;
        align-items: center;
        justify-content: center;
        min-height: 3.45rem;
        width: 100%;
        border: 0;
        border-radius: 0.9rem;
        background: var(--publico-navy);
        color: var(--publico-blanco);
        font: inherit;
        font-size: 1.06rem;
        font-weight: 700;
        text-decoration: none;
        cursor: pointer;
        box-shadow: 0 0.45rem 1rem rgba(13, 50, 94, 0.22);
    }

    .contacto-rapido__boton--whatsapp {
        background: #1f8f4d;
    }

    .contacto-rapido__boton--secundario {
        background: var(--publico-acento);
        color: var(--publico-navy);
    }

    .contacto-rapido__boton--vcard {
        background: #ffffff;
        color: var(--publico-navy);
        border: 1px solid rgba(13, 50, 94, 0.18);
    }

    .contacto-rapido__boton:focus-visible {
        outline: 3px solid rgba(255, 204, 77, 0.72);
        outline-offset: 3px;
    }

    .contacto-rapido__aviso {
        margin: 1rem 0;
        color: #a32020;
        font-weight: 600;
    }

    .contacto-rapido__privacidad {
        margin: 1rem 0 0;
        font-size: 0.78rem;
        color: rgba(13, 50, 94, 0.64);
    }
}

@layer publico-marco {
    .marco-publico {
        display: flex;
        flex-direction: column;
        min-height: 100vh;
        background: hsl(var(--fondo-neutro));
        color: hsl(var(--frente-neutro));
    }

    #CabeceraSitioPublico {
        display: flex;
        align-items: center;
        justify-content: flex-start;
        min-height: 3rem;
        flex-wrap: wrap;
        gap: 0.75rem;
        padding: 0.5rem 1rem;
        background-color: hsl(var(--fondo-primario));
        color: hsl(var(--frente-primario));
    }

    #CabeceraSitioPublico .cabecera-marca {
        display: inline-flex;
        align-items: center;
        text-decoration: none;
    }

    #CabeceraSitioPublico .cabecera-logo {
        height: 2.25rem;
        width: auto;
        display: block;
    }

    #CabeceraSitioPublico .cabecera-publica__nav {
        display: flex;
        flex-wrap: wrap;
        gap: 0.75rem;
        align-items: center;
    }

    #CabeceraSitioPublico .cabecera-publica__nav--usuario {
        flex: 1 1 0;
        justify-content: flex-end;
    }

    #CabeceraSitioPublico .enlace-cabecera-publica {
        color: inherit;
        text-decoration: none;
        padding: 0.25rem 0.35rem;
        border-radius: 0.25rem;
    }

    #CabeceraSitioPublico .enlace-cabecera-publica:hover {
        background-color: rgba(255, 255, 255, 0.12);
    }

    .contenedor-publico {
        flex: 1 1 0;
        overflow: auto;
        padding: 1rem;
    }
}

@layer publico-portada {
    .portada-hero {
        position: relative;
        min-height: min(100vh, 52rem);
        display: flex;
        flex-direction: column;
        color: var(--publico-blanco);
        overflow: hidden;
    }

    @media (max-width: 52rem) {
        .portada-hero {
            min-height: clamp(30rem, 68dvh, 38rem);
        }
    }

    @media (max-width: 36rem) {
        .portada-hero {
            min-height: clamp(24rem, 60dvh, 31rem);
        }
    }

    .portada-hero__fondo {
        position: absolute;
        inset: 0;
        background-image: var(--publico-hero-overlay), url('/imagenes/portada.jpg');
        background-size: cover;
        background-position: center;
    }

    .portada-hero__barra {
        position: relative;
        z-index: 2;
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 1rem;
        flex-wrap: wrap;
        padding: 1.15rem 1.25rem;
        max-width: var(--publico-ancho);
        margin: 0 auto;
        width: 100%;
    }

    @media (max-width: 36rem) {
        .portada-hero__barra {
            padding: 0.9rem 1rem;
        }
    }

    .portada-hero__marca {
        display: flex;
        align-items: center;
        gap: 0.8rem;
        text-decoration: none;
        color: inherit;
    }

    .portada-hero__logo {
        height: clamp(2.15rem, 4vw, 3rem);
        width: auto;
        display: block;
    }

    .portada-hero__razon {
        font-size: clamp(0.78rem, 1.45vw, 1rem);
        font-weight: 700;
        letter-spacing: 0.04em;
        text-transform: uppercase;
        line-height: 1.25;
        max-width: 22rem;
    }

    .portada-hero__area-privada {
        margin-left: auto;
        font-size: 0.875rem;
        font-weight: 500;
        text-decoration: none;
        color: var(--publico-blanco);
        padding: 0.35rem 0.65rem;
        border-radius: 999px;
        border: 1px solid rgba(255, 255, 255, 0.35);
    }

    .portada-hero__area-privada:hover,
    .portada-hero__area-privada:focus-visible {
        background: rgba(255, 255, 255, 0.12);
        outline: none;
    }

    .portada-hero__principal {
        position: relative;
        z-index: 2;
        flex: 1;
        display: flex;
        flex-direction: column;
        justify-content: center;
        padding: 2rem 1.25rem 6rem;
        max-width: var(--publico-ancho);
        margin: 0 auto;
        width: 100%;
    }

    @media (max-width: 52rem) {
        .portada-hero__principal {
            padding: 1.5rem 1rem 4.25rem;
        }
    }

    @media (max-width: 36rem) {
        .portada-hero__principal {
            padding: 1rem 1rem 3.4rem;
        }
    }

    .portada-hero__titular {
        font-size: clamp(1.15rem, 2.8vw, 1.65rem);
        font-weight: 500;
        line-height: 1.45;
        max-width: 36rem;
        margin: 0 0 1.75rem;
    }

    .portada-hero__titular:focus {
        outline: none;
    }

    .portada-cta-pildora {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        text-align: center;
        text-decoration: none;
        text-transform: uppercase;
        letter-spacing: 0.06em;
        font-weight: 600;
        font-size: clamp(0.72rem, 1.6vw, 0.82rem);
        line-height: 1.25;
        padding: 0.85rem 1.75rem;
        border-radius: 999px;
        border: 1px solid var(--publico-crema);
        color: var(--publico-crema);
        background: transparent;
        max-width: 14rem;
        transition: background-color 0.2s ease, color 0.2s ease, border-color 0.2s ease;
    }

    .portada-cta-pildora:hover,
    .portada-cta-pildora:focus-visible {
        background: var(--publico-crema);
        color: var(--publico-navy);
        border-color: var(--publico-crema);
        outline: none;
    }

    .portada-marquesina {
        position: absolute;
        left: 0;
        right: 0;
        bottom: 0;
        z-index: 1;
        padding: 0.35rem 0 0.75rem;
        overflow: hidden;
        pointer-events: none;
        mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent);
    }

    .portada-marquesina__pista {
        display: flex;
        width: max-content;
        gap: 4rem;
        animation: portada-marquesina-scroll 38s linear infinite;
    }

    .portada-marquesina__texto {
        font-size: clamp(2.5rem, 12vw, 6.5rem);
        font-weight: 700;
        letter-spacing: -0.02em;
        color: rgba(255, 255, 255, 0.22);
        white-space: nowrap;
        line-height: 1;
    }

    @media (max-width: 36rem) {
        .portada-marquesina__texto {
            font-size: clamp(2rem, 11vw, 3.4rem);
        }
    }

    @keyframes portada-marquesina-scroll {
        0% { transform: translateX(0); }
        100% { transform: translateX(-50%); }
    }

    @media (prefers-reduced-motion: reduce) {
        .portada-marquesina__pista {
            animation: none;
            justify-content: center;
            width: 100%;
        }
    }

    .portada-seccion {
        padding: clamp(2.5rem, 5vw, 4rem) 1.25rem;
    }

    @media (max-width: 52rem) {
        .portada-seccion {
            padding: 1rem;
        }

        #servicios.portada-seccion {
            padding-top: 2rem;
        }

        #presupuesto.portada-seccion {
            padding-top: 2rem;
        }
    }

    .portada-seccion--crema {
        background: var(--publico-crema);
    }

    .portada-seccion--beige {
        background: var(--publico-beige);
    }

    .portada-contenedor {
        max-width: var(--publico-ancho);
        margin: 0 auto;
    }

    .portada-h2 {
        font-size: clamp(1.65rem, 3.5vw, 2.25rem);
        font-weight: 700;
        color: var(--publico-navy);
        margin: 0 0 1.25rem;
    }

    .portada-servicio {
        display: flex;
        flex-wrap: wrap;
        align-items: center;
        gap: clamp(1.25rem, 3vw, 2.5rem);
        margin-bottom: clamp(2.5rem, 4vw, 3.5rem);
    }

    .portada-servicio:last-child {
        margin-bottom: 0;
    }

    .portada-servicio--invertida {
        flex-direction: row-reverse;
    }

    .portada-servicio__texto {
        flex: 1 1 18rem;
        min-width: min(100%, 18rem);
    }

    .portada-servicio__media {
        flex: 1 1 18rem;
        min-width: min(100%, 18rem);
        margin: 0;
    }

    .portada-servicio__media img {
        width: 100%;
        height: auto;
        display: block;
        border-radius: 2rem;
        object-fit: cover;
        aspect-ratio: 16 / 10;
    }

    .portada-servicio h3 {
        font-size: clamp(1.25rem, 2.4vw, 1.65rem);
        font-weight: 800;
        letter-spacing: -0.01em;
        color: var(--publico-navy);
        margin: 0 0 0.7rem;
        line-height: 1.15;
    }

    .portada-servicio p {
        margin: 0 0 0.65rem;
        color: var(--publico-texto-suave);
        line-height: 1.55;
        font-size: 1rem;
    }

    .portada-servicio p:last-child {
        margin-bottom: 0;
    }

    @media (max-width: 52rem) {
        .portada-servicio,
        .portada-servicio--invertida {
            flex-direction: column;
            align-items: stretch;
            gap: 0.55rem;
            margin-bottom: 1.15rem;
        }

        .portada-servicio__texto,
        .portada-servicio__media {
            flex: none;
            width: 100%;
            min-width: 0;
        }

        .portada-servicio__texto {
            margin-bottom: 3rem;
        }

        .portada-servicio__media {
            order: -1;
        }

        .portada-servicio h3 {
            margin: 1rem 0 0.7rem;
            text-align: center;
        }
    }

    @media (max-width: 36rem) {
        .portada-servicio,
        .portada-servicio--invertida {
            gap: 0.5rem;
            margin-bottom: 1rem;
        }

        .portada-servicio h3 {
            margin: 1rem 0 0.45rem;
            text-align: center;
        }

        .portada-servicio p {
            margin-bottom: 0.45rem;
        }
    }

    .portada-compromiso {
        display: grid;
        grid-template-columns: minmax(0, 0.95fr) minmax(0, 1.35fr);
        gap: clamp(1.5rem, 4vw, 3.5rem);
        align-items: center;
    }

    @media (max-width: 48rem) {
        .portada-compromiso {
            grid-template-columns: 1fr;
        }
    }

    .portada-compromiso h2 {
        font-size: clamp(1.75rem, 3.8vw, 2.6rem);
        font-weight: 800;
        color: var(--publico-navy);
        margin: 0 0 1rem;
        line-height: 1.08;
    }

    .portada-compromiso p {
        color: var(--publico-texto-suave);
        line-height: 1.55;
        margin: 0;
    }

    .portada-compromiso__intro {
        max-width: 31rem;
    }

    .portada-compromiso__intro p {
        margin-bottom: 1.2rem;
    }

    .portada-etiqueta {
        display: inline-flex;
        align-items: center;
        margin-bottom: 0.75rem;
        padding: 0.25rem 0.65rem;
        border-radius: 999px;
        background: rgba(255, 255, 255, 0.55);
        color: var(--publico-navy);
        font-size: 0.72rem;
        font-weight: 800;
        letter-spacing: 0.08em;
        text-transform: uppercase;
    }

    .portada-compromiso .portada-enlace {
        display: inline-flex;
        align-items: center;
        color: var(--publico-navy);
        font-weight: 800;
    }

    .portada-compromiso__tarjetas {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 1rem;
    }

    .portada-compromiso__tarjeta {
        min-height: 100%;
        padding: clamp(1rem, 2.5vw, 1.35rem);
        border: 1px solid rgba(13, 50, 94, 0.12);
        border-radius: 1.25rem;
        background: rgba(255, 255, 255, 0.58);
        box-shadow: 0 14px 35px rgba(13, 50, 94, 0.08);
    }

    .portada-compromiso__tarjeta h3 {
        margin: 0 0 0.75rem;
        color: var(--publico-navy);
        font-size: 1.1rem;
        font-weight: 800;
    }

    .portada-compromiso__tarjeta ul {
        margin: 0;
        padding-left: 1.1rem;
        color: var(--publico-texto-suave);
        line-height: 1.45;
    }

    .portada-compromiso__tarjeta li + li {
        margin-top: 0.45rem;
    }

    @media (max-width: 40rem) {
        .portada-compromiso__tarjetas {
            grid-template-columns: 1fr;
        }
    }

    .portada-compromiso a {
        color: var(--publico-navy);
        font-weight: 600;
    }

    .portada-pie {
        padding: clamp(2rem, 4vw, 3rem) 1.25rem;
    }

    .portada-pie__rejilla {
        display: grid;
        grid-template-columns: minmax(14rem, 1.25fr) minmax(14rem, 1fr) minmax(10rem, 0.8fr) minmax(12rem, 0.8fr);
        gap: 2rem;
        align-items: start;
    }

    @media (max-width: 62rem) {
        .portada-pie__rejilla {
            grid-template-columns: repeat(2, minmax(0, 1fr));
        }
    }

    @media (max-width: 38rem) {
        .portada-pie__rejilla {
            grid-template-columns: 1fr;
        }
    }

    .portada-pie__logo {
        max-width: 14rem;
        height: auto;
    }

    .portada-pie h2 {
        font-size: 1rem;
        margin: 0 0 0.5rem;
        color: var(--publico-navy);
    }

    .portada-pie p,
    .portada-pie a {
        font-size: 0.9rem;
        color: var(--publico-texto-suave);
        line-height: 1.5;
    }

    .portada-pie a {
        color: var(--publico-navy);
    }

    .portada-pie__contacto {
        list-style: none;
        padding: 0;
        margin: 0;
        display: grid;
        gap: 0.55rem;
    }

    .portada-pie__contacto li {
        display: grid;
        grid-template-columns: 1.2rem minmax(0, 1fr);
        gap: 0.55rem;
        align-items: center;
        color: var(--publico-texto-suave);
        font-size: 0.9rem;
        line-height: 1.45;
    }

    .portada-pie__contacto svg {
        display: block;
        width: 1.05rem;
        height: 1.05rem;
        margin: 0;
        justify-self: center;
        fill: var(--publico-navy);
    }

    .portada-pie__contacto a {
        text-decoration-color: rgba(13, 50, 94, 0.28);
        text-decoration-thickness: 0.0625rem;
        text-underline-offset: 0.18em;
    }

    .portada-pie__contacto a:hover,
    .portada-pie__contacto a:focus-visible {
        text-decoration-color: rgba(13, 50, 94, 0.58);
    }

    .portada-pie__redes {
        display: flex;
        flex-wrap: wrap;
        gap: 0.65rem;
        margin-top: 0.5rem;
    }

    .portada-pie__redes a {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        width: 2.15rem;
        height: 2.15rem;
        border-radius: 999px;
        background: rgba(255, 255, 255, 0.58);
        color: var(--publico-navy);
        font-weight: 600;
        transition: transform 0.2s ease, background-color 0.2s ease;
    }

    .portada-pie__redes a:hover,
    .portada-pie__redes a:focus-visible {
        transform: translateY(-1px);
        outline: none;
    }

    .portada-pie__redes a:nth-child(1) {
        background: radial-gradient(circle at 30% 110%, #feda75 0 22%, #fa7e1e 38%, #d62976 58%, #962fbf 78%, #4f5bd5 100%);
        color: var(--publico-blanco);
    }

    .portada-pie__redes a:nth-child(2) {
        background: #1877f2;
        color: var(--publico-blanco);
    }

    .portada-pie__redes a:nth-child(3) {
        background: #25d366;
        color: var(--publico-blanco);
    }

    .portada-pie__redes a:hover,
    .portada-pie__redes a:focus-visible {
        filter: brightness(1.06);
    }

    .portada-pie__redes svg {
        width: 1.2rem;
        height: 1.2rem;
        fill: currentColor;
    }
}

@layer publico-inicio-sesion {
    .inicio-sesion-publico {
        position: relative;
        min-height: 100dvh;
        display: grid;
        place-items: center;
        padding: clamp(1.25rem, 4vw, 2.5rem);
        overflow: hidden;
        color: var(--publico-navy);
    }

    .inicio-sesion-publico__fondo {
        position: absolute;
        inset: 0;
        background-image:
            var(--publico-hero-overlay),
            url('/imagenes/portada.jpg');
        background-size: cover;
        background-position: center;
    }

    .inicio-sesion-publico__fondo::after {
        content: "";
        position: absolute;
        inset: 0;
        background:
            radial-gradient(circle at 18% 18%, rgba(255, 204, 77, 0.26), transparent 30%),
            linear-gradient(180deg, rgba(13, 50, 94, 0.06), rgba(13, 50, 94, 0.35));
    }

    .inicio-sesion-publico__tarjeta {
        position: relative;
        z-index: 1;
        width: min(100%, 30rem);
        padding: clamp(1.35rem, 4vw, 2rem);
        border: 1px solid rgba(255, 255, 255, 0.62);
        border-radius: 1.5rem;
        background: rgba(255, 249, 230, 0.95);
        box-shadow: 0 1.5rem 4rem rgba(0, 0, 0, 0.28);
        backdrop-filter: blur(10px);
    }

    .inicio-sesion-publico__cabecera {
        display: flex;
        align-items: flex-start;
        justify-content: space-between;
        gap: 1rem;
    }

    .inicio-sesion-publico__marca {
        display: inline-flex;
        align-items: center;
        gap: 2rem;
        color: inherit;
        text-decoration: none;
    }

    .inicio-sesion-publico__marca img {
        width: 4.85rem;
        height: auto;
        display: block;
    }

    .inicio-sesion-publico__marca-texto {
        display: grid;
        font-size: 1rem;
        font-weight: 700;
        letter-spacing: 0.05em;
        line-height: 1.575;
        text-transform: uppercase;
    }

    .inicio-sesion-publico__marca-linea {
        display: grid;
        grid-template-columns: 0.95em auto;
        align-items: center;
        column-gap: 0.18rem;
    }

    .inicio-sesion-publico__marca-acronimo {
        font-size: 1.8em;
        font-weight: 900;
        line-height: 0.8;
        justify-self: center;
        text-align: center;
    }

    .inicio-sesion-publico__accesos {
        display: flex;
        flex-direction: row;
        gap: 0.45rem;
        flex: 0 0 auto;
    }

    .inicio-sesion-publico__accesos form {
        margin: 0;
    }

    .inicio-sesion-publico__acceso-rapido {
        width: 2.1rem;
        min-height: 2.1rem;
        border: 1px solid rgba(13, 50, 94, 0.2);
        border-radius: 0.5rem;
        background: rgba(255, 255, 255, 0.82);
        color: var(--publico-navy);
        cursor: pointer;
        font-size: 0.95rem;
        font-weight: 800;
        line-height: 1;
    }

    .inicio-sesion-publico__acceso-rapido:hover,
    .inicio-sesion-publico__acceso-rapido:focus-visible {
        border-color: var(--publico-navy);
        outline: 2px solid rgba(255, 204, 77, 0.45);
        outline-offset: 1px;
    }

    @media (max-width: 36rem) {
        .inicio-sesion-publico__cabecera {
            gap: 0.75rem;
        }

        .inicio-sesion-publico__marca {
            gap: 1rem;
        }

        .inicio-sesion-publico__marca-texto {
            font-size: 0.92rem;
        }
    }

    .inicio-sesion-publico__intro {
        margin-top: 1.8rem;
    }

    .inicio-sesion-publico__intro h1 {
        margin: 0;
        font-size: clamp(2rem, 8vw, 3rem);
        line-height: 0.98;
        letter-spacing: -0.04em;
    }

    .inicio-sesion-publico__intro p {
        margin: 0.85rem 0 0;
        color: var(--publico-texto-suave);
        line-height: 1.5;
    }

    .inicio-sesion-publico__form {
        display: grid;
        gap: 0.85rem;
        margin-top: 2.45rem;
    }

    .inicio-sesion-publico__campos {
        display: flex;
        flex-wrap: wrap;
        gap: 1rem;
    }

    .inicio-sesion-publico__form .publico-campo {
        flex: 1 1 10rem;
        margin-bottom: 0;
    }

    .inicio-sesion-publico__form input {
        width: 100%;
        min-height: 2.9rem;
        background: rgba(255, 255, 255, 0.82);
        box-sizing: border-box;
    }

    .inicio-sesion-publico__form input:focus-visible {
        border-color: var(--publico-navy);
        outline: 3px solid rgba(255, 204, 77, 0.55);
        outline-offset: 2px;
    }

    .inicio-sesion-publico__boton {
        min-height: 3rem;
        margin: 2rem;
    }

    .inicio-sesion-publico__error {
        margin: 1.1rem 0 0;
        padding: 0.7rem 0.85rem;
        border: 1px solid rgba(180, 40, 40, 0.35);
        border-radius: 0.75rem;
        background: rgba(180, 40, 40, 0.1);
        color: #6b1c1c;
        font-size: 0.9rem;
        font-weight: 600;
    }

    .inicio-sesion-publico__volver {
        display: inline-flex;
        align-items: center;
        gap: 0.35rem;
        margin-top: 1rem;
        color: var(--publico-navy);
        font-size: 0.9rem;
        font-weight: 700;
        text-decoration-color: rgba(13, 50, 94, 0.28);
        text-underline-offset: 0.18em;
    }

    .inicio-sesion-publico__volver svg {
        width: 1rem;
        height: 1rem;
        flex: 0 0 auto;
        fill: currentColor;
    }

    .inicio-sesion-publico__volver:hover,
    .inicio-sesion-publico__volver:focus-visible {
        text-decoration-color: rgba(13, 50, 94, 0.7);
    }
}

@layer publico-presupuesto {
    .publico-presupuesto {
        display: grid;
        grid-template-columns: 1fr 1.2fr;
        gap: clamp(1.5rem, 3vw, 2.75rem);
        align-items: start;
    }

    .publico-presupuesto--compact {
        grid-template-columns: 1fr;
        max-width: 60rem;
    }

    .publico-presupuesto--compact .publico-presupuesto__intro {
        display: none;
    }

    @media (max-width: 52rem) {
        .publico-presupuesto:not(.publico-presupuesto--compact) {
            grid-template-columns: 1fr;
        }
    }

    .publico-presupuesto__intro p {
        color: var(--publico-texto-suave);
        line-height: 1.55;
        margin: 0;
        max-width: 28rem;
    }

    .publico-presupuesto__texto {
        max-width: 36rem;
        color: var(--publico-texto-suave);
        line-height: 1.5;
        margin: 0 0 1.1rem;
    }

    .publico-pasos {
        position: relative;
        display: flex;
        flex-direction: column;
        overflow: hidden;
        border-radius: 1rem;
        border: 1px solid rgba(13, 50, 94, 0.12);
        background: var(--publico-blanco);
        box-shadow: 0 4px 24px rgba(13, 50, 94, 0.06);
    }

    .publico-pasos__cinta {
        display: flex;
        width: 300%;
        transition: transform 0.35s ease;
    }

    .publico-pasos__cinta[data-paso="1"] { transform: translateX(0); }
    .publico-pasos__cinta[data-paso="2"] { transform: translateX(-33.333%); }
    .publico-pasos__cinta[data-paso="3"] { transform: translateX(-66.666%); }

    .publico-pasos__fieldset {
        border: none;
        margin: 0;
        padding: 0;
        min-width: 0;
    }

    .publico-pasos__fieldset:disabled {
        opacity: 1;
    }

    .publico-pasos__panel {
        width: 33.333%;
        flex: 0 0 33.333%;
        padding: 1.25rem 1.35rem 1.5rem;
        box-sizing: border-box;
    }

    .publico-pasos__mensaje {
        flex: 1 1 22rem;
        box-sizing: border-box;
        margin: 0;
        padding: 0.55rem 0.75rem;
        border-radius: 0.5rem;
        font-size: 0.84rem;
        line-height: 1.45;
        color: #6b1c1c;
        background: rgba(180, 40, 40, 0.1);
        border: 1px solid rgba(180, 40, 40, 0.35);
    }

    .publico-pasos__nav {
        display: flex;
        flex-wrap: wrap;
        gap: 0.75rem;
        margin-top: 0.85rem;
        margin-bottom: 1rem;
        align-items: center;
    }

    .publico-pasos__nav--envio {
        align-items: flex-start;
    }

    .publico-pasos__indicador {
        font-size: 0.8rem;
        color: var(--publico-texto-suave);
        margin-right: auto;
    }

    .publico-btn {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        padding: 0.55rem 1.25rem;
        border-radius: 999px;
        font-family: inherit;
        font-size: 0.875rem;
        font-weight: 600;
        cursor: pointer;
        border: 1px solid var(--publico-navy);
        background: var(--publico-navy);
        color: var(--publico-blanco);
        text-transform: uppercase;
        letter-spacing: 0.04em;
    }

    .publico-btn--secundario {
        background: transparent;
        color: var(--publico-navy);
    }

    .publico-btn:disabled {
        opacity: 0.45;
        cursor: not-allowed;
    }

    .publico-campo {
        display: flex;
        flex-direction: column;
        gap: 0.15rem;
        margin-bottom: 0.28rem;
    }

    .publico-campo span {
        font-size: 0.82rem;
        font-weight: 600;
        color: var(--publico-navy);
    }

    .publico-campo span em {
        font-style: normal;
        font-weight: 300;
    }

    .publico-campo small {
        color: rgba(13, 50, 94, 0.66);
        font-size: 0.76rem;
        line-height: 1.35;
    }

    .publico-campo input,
    .publico-campo textarea,
    .publico-campo select {
        width: 100%;
        font: inherit;
        padding: 0.4rem 0.6rem;
        border-radius: 0.65rem;
        border: 0.0625rem solid rgba(13, 50, 94, 0.25);
        max-width: 100%;
    }

    .publico-control {
        width: 100%;
    }

    .publico-campo textarea {
        min-height: 4.25rem;
        resize: vertical;
    }

    .publico-campo--mitad {
        flex: 1 1 18rem;
        min-width: min(100%, 16rem);
    }

    .publico-campo--empresa {
        flex: 1 1 28rem;
        min-width: min(100%, 18rem);
    }

    .publico-campo--localidad {
        flex: 0 1 18rem;
        min-width: min(100%, 14rem);
    }

    .publico-campo--telefono {
        flex: 0 1 15rem;
        min-width: min(100%, 12rem);
    }

    .publico-campo--fecha {
        flex: 0 1 10.4rem;
        min-width: min(100%, 10.4rem);
        max-width: 100%;
    }

    .publico-fila {
        display: flex;
        flex-wrap: wrap;
        gap: 0.15rem 0.7rem;
    }

    .publico-fila--contacto .publico-campo--mitad {
        flex: 1 1 18rem;
    }

    .publico-seccion-form {
        border: 1px solid rgba(13, 50, 94, 0.12);
        border-radius: 0.75rem;
        padding: 1rem;
        margin-top: 0.85rem;
        background: rgba(255, 249, 230, 0.35);
    }

    .publico-seccion-form h3 {
        margin: 0 0 0.65rem;
        font-size: 0.95rem;
        color: var(--publico-navy);
    }

    .publico-cuadricula-comprobaciones {
        display: grid;
        grid-template-columns: repeat(auto-fill, minmax(13rem, 1fr));
        gap: 0.35rem 0.75rem;
        margin-top: 0.5rem;
    }

    .publico-cuadricula-comprobaciones label {
        display: flex;
        align-items: flex-start;
        gap: 0.4rem;
        font-size: 0.82rem;
        cursor: pointer;
        color: var(--publico-texto-suave);
    }

    .publico-legal {
        font-size: 0.66rem;
        line-height: 1.25;
        color: rgba(13, 50, 94, 0.58);
        padding: 0.45rem 0.55rem;
        border-radius: 0.5rem;
        background: rgba(255, 255, 255, 0.34);
        border: 0.0625rem solid rgba(13, 50, 94, 0.06);
        margin: 0.25rem 0 0.55rem;
    }

    .publico-privacidad-form {
        display: grid;
        grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
        gap: 2rem;
        align-items: start;
        margin-top: 0.15rem;
    }

    @media (max-width: 48rem) {
        .publico-privacidad-form {
            grid-template-columns: 1fr;
            gap: 2rem;
        }
    }

    .publico-legal .publico-legal__titulo {
        margin: 0 0 0.2rem;
        color: rgba(13, 50, 94, 0.62);
        font-size: 0.62rem;
        font-weight: 700;
        letter-spacing: 0.04em;
        text-transform: uppercase;
    }

    .publico-legal p {
        margin: 0.08rem 0;
    }

    .publico-legal strong {
        font-weight: 600;
        color: rgba(13, 50, 94, 0.7);
    }

    .publico-legal a {
        color: inherit;
        font-weight: inherit;
    }

    .publico-consent {
        display: grid;
        justify-items: start;
        padding-top: 0.2rem;
    }

    .publico-consent label {
        display: inline-flex;
        align-items: center;
        gap: 0.55rem;
        font-size: 0.86rem;
        margin-bottom: 0.45rem;
        cursor: pointer;
        color: var(--publico-texto-suave);
        width: fit-content;
        max-width: 100%;
    }

    .publico-consent a {
        color: inherit;
        font-weight: 600;
        text-decoration-color: rgba(13, 50, 94, 0.24);
        text-decoration-thickness: 0.0625rem;
        text-underline-offset: 0.14em;
    }

    .publico-consent a:visited {
        color: inherit;
    }

    .publico-consent input[type="checkbox"] {
        width: 1.18rem;
        height: 1.18rem;
        flex: 0 0 1.18rem;
        margin: 0;
        accent-color: var(--publico-navy);
        cursor: pointer;
    }

    .publico-mensaje-exito {
        color: #1a6b2e;
        font-weight: 600;
    }

    .publico-validation-summary {
        color: #a32020;
        font-size: 0.85rem;
        margin-bottom: 0.75rem;
    }
}

@layer publico-legal {
    .publico-legal-hero {
        background:
            radial-gradient(circle at 12% 12%, rgba(255, 204, 77, 0.28), transparent 30%),
            linear-gradient(145deg, var(--publico-navy), #174977);
        color: var(--publico-blanco);
    }

    .publico-legal-hero__barra {
        padding-bottom: 0;
        color: var(--publico-blanco);
    }

    .publico-legal-hero__barra .portada-hero__marca,
    .publico-legal-hero__barra .portada-hero__area-privada {
        color: var(--publico-blanco);
    }

    .publico-legal-hero__contenido {
        padding: clamp(2.5rem, 6vw, 5rem) 1.25rem clamp(2.75rem, 6vw, 4.5rem);
    }

    .publico-legal-hero h1 {
        max-width: 48rem;
        margin: 0 0 1rem;
        font-size: clamp(2rem, 5vw, 3.65rem);
        line-height: 1;
        letter-spacing: -0.03em;
    }

    .publico-legal-hero p {
        max-width: 48rem;
        margin: 0;
        color: rgba(255, 255, 255, 0.86);
        line-height: 1.55;
    }

    .publico-legal-pagina__fecha {
        margin-top: 1rem !important;
        font-size: 0.92rem;
    }

    .publico-legal-pagina__contenido {
        display: grid;
        gap: 0.8rem;
        max-width: min(58rem, calc(100% - 2.5rem));
    }

    .publico-legal-pagina__intro {
        margin: 0 0 0.4rem;
        color: var(--publico-texto-suave);
        line-height: 1.6;
    }

    .publico-legal-pagina details {
        border: 1px solid rgba(13, 50, 94, 0.12);
        border-radius: 1rem;
        background: rgba(255, 255, 255, 0.72);
        box-shadow: 0 12px 30px rgba(13, 50, 94, 0.06);
        overflow: hidden;
    }

    .publico-legal-pagina summary {
        padding: 1rem 1.15rem;
        color: var(--publico-navy);
        font-weight: 800;
        cursor: pointer;
        list-style-position: inside;
    }

    .publico-legal-pagina summary:focus-visible {
        outline: 3px solid rgba(255, 204, 77, 0.72);
        outline-offset: -3px;
    }

    .publico-legal-pagina__panel {
        padding: 0 1.15rem 1.15rem;
        color: var(--publico-texto-suave);
        line-height: 1.58;
    }

    .publico-legal-pagina__panel p {
        margin: 0 0 0.85rem;
    }

    .publico-legal-pagina__panel p:last-child {
        margin-bottom: 0;
    }

    .publico-legal-pagina__panel ul {
        margin: 0.3rem 0 0.85rem;
        padding-left: 1.2rem;
    }

    .publico-legal-pagina__panel li + li {
        margin-top: 0.45rem;
    }

    .publico-legal-pagina a {
        color: var(--publico-navy);
        font-weight: 700;
    }

    .publico-legal-pagina__ficha {
        display: grid;
        gap: 0.45rem;
        margin: 0;
    }

    .publico-legal-pagina__ficha div {
        display: grid;
        grid-template-columns: minmax(8rem, 0.45fr) 1fr;
        gap: 0.75rem;
        padding-bottom: 0.45rem;
        border-bottom: 1px solid rgba(13, 50, 94, 0.08);
    }

    .publico-legal-pagina__ficha dt {
        color: var(--publico-navy);
        font-weight: 800;
    }

    .publico-legal-pagina__ficha dd {
        margin: 0;
    }

    .publico-legal-pagina__tabla-wrap {
        max-width: 100%;
        overflow-x: auto;
        margin: 0.8rem 0 1rem;
        border-radius: 0.8rem;
        border: 1px solid rgba(13, 50, 94, 0.12);
        background: var(--publico-blanco);
    }

    .publico-legal-pagina__tabla {
        width: 100%;
        min-width: 48rem;
        border-collapse: collapse;
        font-size: 0.9rem;
    }

    .publico-legal-pagina__tabla th,
    .publico-legal-pagina__tabla td {
        padding: 0.75rem;
        text-align: left;
        vertical-align: top;
        border-bottom: 1px solid rgba(13, 50, 94, 0.1);
    }

    .publico-legal-pagina__tabla th {
        color: var(--publico-navy);
        background: rgba(255, 231, 161, 0.42);
        font-weight: 800;
    }

    .publico-legal-pagina__tabla tr:last-child td {
        border-bottom: 0;
    }

    .publico-aviso-cookies {
        position: fixed;
        right: clamp(0.8rem, 3vw, 1.5rem);
        bottom: clamp(0.8rem, 3vw, 1.5rem);
        z-index: 1500;
        display: flex;
        align-items: center;
        gap: 1rem;
        max-width: min(38rem, calc(100% - 1.6rem));
        padding: 0.9rem 1rem;
        border: 1px solid rgba(13, 50, 94, 0.16);
        border-radius: 1rem;
        background: rgba(255, 255, 255, 0.96);
        color: var(--publico-navy);
        box-shadow: 0 18px 45px rgba(13, 50, 94, 0.18);
    }

    .publico-aviso-cookies__texto {
        display: grid;
        gap: 0.2rem;
        font-size: 0.9rem;
        line-height: 1.4;
    }

    .publico-aviso-cookies__texto span {
        color: var(--publico-texto-suave);
    }

    .publico-aviso-cookies__acciones {
        display: flex;
        flex-wrap: wrap;
        gap: 0.65rem;
        align-items: center;
        justify-content: flex-end;
        margin-left: auto;
    }

    .publico-aviso-cookies__acciones a {
        color: var(--publico-navy);
        font-size: 0.86rem;
        font-weight: 800;
        white-space: nowrap;
    }

    .portada-pie__legal {
        display: grid;
        gap: 0.35rem;
        margin-top: 0.6rem;
    }

    .portada-pie__legal a {
        font-size: 0.78rem;
        text-decoration-color: rgba(13, 50, 94, 0.28);
        text-decoration-thickness: 0.0625rem;
        text-underline-offset: 0.18em;
    }

    .portada-pie__legal a:hover,
    .portada-pie__legal a:focus-visible {
        text-decoration-color: rgba(13, 50, 94, 0.58);
    }

    @media (max-width: 42rem) {
        .publico-legal-pagina__ficha div {
            grid-template-columns: 1fr;
            gap: 0.15rem;
        }

        .publico-aviso-cookies {
            left: 0.8rem;
            flex-direction: column;
            align-items: stretch;
        }

        .publico-aviso-cookies__acciones {
            justify-content: space-between;
            margin-left: 0;
        }
    }
}
