/* =============================================================================
   IPSOO · PUBLIC · Edición 2026
   Sistema de diseño de las páginas públicas (landing, info, auth, footer).
   Todo está scopeado a body.is-public-page — no contamina paneles ni builder.
   ============================================================================= */

/* ─── TOKENS ────────────────────────────────────────────────────────────── */
body.is-public-page {
    /* paleta */
    --c-canvas:         #FBFAF8; /* casi blanco, leve calidez */
    --c-canvas-alt:     #F2F1EC; /* gris c&aacute;lido para secciones alternas */
    --c-ink:            #0E1511;
    --c-stone:          #6E6A62;
    --c-stone-soft:     #A8A39A;
    --c-green:          #106D60; /* WCAG AA-safe on canvas (5.4:1); brand-800 — small text */
    --c-green-bright:   #15AB92; /* brand-600 — logo IPSOO, fondos, texto grande */
    --c-green-dark:     #0E5B50; /* brand-900 — bot&oacute;n primario */
    --c-green-soft:     #D4EFEA;
    --c-accent:         #106D60; /* reemplaza terracota; sin naranja */
    --c-accent-soft:    #D4EFEA;
    --c-terracota:      #106D60; /* legacy alias — ya no es naranja */
    --c-terracota-soft: #D4EFEA;
    --c-border:         rgba(14, 21, 17, 0.10);
    --c-border-strong:  rgba(14, 21, 17, 0.22);

    /* tipos — Plus Jakarta Sans (body) + Fraunces (detalles/labels editoriales) */
    --f-serif:   "Fraunces", "Times New Roman", Georgia, serif; /* alias legacy */
    --f-display: "Plus Jakarta Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
    --f-sans:    "Plus Jakarta Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
    --f-mono:    "Fraunces", "Times New Roman", Georgia, serif;

    /* escala tipográfica agresiva, no lineal */
    --fs-display: clamp(3rem, 10vw, 7.5rem);
    --fs-h1:      clamp(2.25rem, 5.5vw, 4.25rem);
    --fs-h2:      clamp(1.875rem, 4.2vw, 3rem);
    --fs-h3:      1.375rem;
    --fs-lead:    1.125rem;
    --fs-body:    1rem;
    --fs-meta:    0.8125rem;
    --fs-micro:   0.6875rem;

    /* layout */
    --sec-y:      clamp(4rem, 9vw, 8rem);
    --wrap:       1240px;
}

/* ─── BASE ──────────────────────────────────────────────────────────────── */
body.is-public-page {
    background: var(--c-canvas);
    color: var(--c-ink);
    font-family: var(--f-sans);
    font-size: 16px;
    line-height: 1.55;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    text-rendering: optimizeLegibility;
    overflow-x: clip;
}

body.is-public-page main {
    padding-top: 64px;
    min-height: 60vh;
}

body.is-public-page h1,
body.is-public-page h2 {
    font-family: var(--f-display);
    font-weight: 700;
    color: var(--c-ink);
    letter-spacing: -0.035em;
    line-height: 1.04;
    margin: 0;
}
body.is-public-page h1 { font-size: var(--fs-h1); }
body.is-public-page h2 { font-size: var(--fs-h2); }
body.is-public-page h3 {
    font-family: var(--f-sans);
    font-weight: 600;
    font-size: var(--fs-h3);
    letter-spacing: -0.01em;
    color: var(--c-ink);
    margin: 0;
}

/* Overrides: títulos de componentes usan display Geist (sin serif editorial) */
body.is-public-page .ipsoo-minisite__title,
body.is-public-page .ipsoo-frame__title,
body.is-public-page .ipsoo-index__title,
body.is-public-page .ipsoo-pricing__name,
body.is-public-page .ipsoo-colofon__brand {
    font-family: var(--f-display);
    font-weight: 700;
    letter-spacing: -0.02em;
}
body.is-public-page .ipsoo-minisite__title { font-size: 1.25rem; line-height: 1.05; color: inherit; font-weight: 600; letter-spacing: -0.025em; }
body.is-public-page .ipsoo-frame__title    { font-size: 1.625rem; line-height: 1.05; color: var(--c-ink); }
body.is-public-page .ipsoo-index__title    { font-size: clamp(1.375rem, 2.5vw, 1.875rem); line-height: 1.05; color: var(--c-ink); }
body.is-public-page .ipsoo-pricing__name   { font-size: 1.625rem; line-height: 1; color: var(--c-ink); }
body.is-public-page .ipsoo-colofon__brand  { font-size: 2.25rem; line-height: 1; color: var(--c-canvas); margin-bottom: 0.625rem; }

/* h3 sans en contextos específicos */
body.is-public-page .ipsoo-colofon__heading {
    font-family: var(--f-mono);
    font-weight: 400;
    font-size: var(--fs-micro);
    color: var(--c-stone-soft);
    text-transform: uppercase;
    letter-spacing: 0.12em;
}
body.is-public-page .ipsoo-showcase__title {
    font-family: var(--f-display);
    font-weight: 600;
    font-size: 1.1875rem;
    color: var(--c-ink);
    line-height: 1.1;
    letter-spacing: -0.02em;
}
body.is-public-page p {
    color: var(--c-stone);
    font-size: var(--fs-body);
    line-height: 1.62;
    margin: 0;
}
body.is-public-page a { color: inherit; text-decoration: none; }

body.is-public-page .ipsoo-display {
    font-family: var(--f-serif);
    font-weight: 400;
    font-size: var(--fs-display);
    line-height: 0.92;
    letter-spacing: -0.035em;
    color: var(--c-ink);
}
body.is-public-page .ipsoo-lead {
    font-size: var(--fs-lead);
    color: var(--c-ink);
    line-height: 1.5;
}

/* ─── LAYOUT UTILITIES ──────────────────────────────────────────────────── */
.ipsoo-wrap {
    max-width: var(--wrap);
    margin: 0 auto;
    padding-inline: 1.25rem;
}
@media (min-width: 640px)  { .ipsoo-wrap { padding-inline: 1.5rem; } }
@media (min-width: 1024px) { .ipsoo-wrap { padding-inline: 2rem; } }

.ipsoo-section {
    padding-block: var(--sec-y);
    position: relative;
}
.ipsoo-section--alt  { background: var(--c-canvas-alt); }
.ipsoo-section--dark { background: var(--c-ink); color: var(--c-canvas); }
.ipsoo-section--dark h1,
.ipsoo-section--dark h2 { color: var(--c-canvas); }
.ipsoo-section--dark p  { color: var(--c-stone-soft); }

/* ─── MARCADOR DE SECCIÓN (firma del rediseño) ─────────────────────────── */
.ipsoo-marker {
    display: inline-flex;
    align-items: center;
    gap: 0.625rem;
    font-family: var(--f-mono);
    font-size: var(--fs-meta);
    color: var(--c-green);
    text-transform: uppercase;
    letter-spacing: 0.06em;
    margin-bottom: 1.75rem;
}
.ipsoo-marker::before {
    content: "";
    width: 7px; height: 7px;
    border-radius: 50%;
    background: currentColor;
    flex-shrink: 0;
}

/* ─── BOTONES ───────────────────────────────────────────────────────────── */
body.is-public-page .ipsoo-btn {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.9375rem 1.5rem;
    font-family: var(--f-sans);
    font-size: 0.9375rem;
    font-weight: 500;
    letter-spacing: -0.005em;
    line-height: 1;
    border-radius: 2px;
    cursor: pointer;
    transition: transform 0.18s cubic-bezier(.2,.8,.2,1), box-shadow 0.18s ease, background 0.2s, color 0.2s;
    border: 1.5px solid var(--c-ink);
    white-space: nowrap;
    min-height: 48px;
    text-decoration: none;
}
body.is-public-page .ipsoo-btn:focus-visible {
    outline: 2px solid var(--c-terracota);
    outline-offset: 3px;
}
body.is-public-page .ipsoo-btn--primary {
    background: var(--c-green-dark);
    color: #FFFFFF;
    box-shadow: 4px 4px 0 var(--c-ink);
}
body.is-public-page .ipsoo-btn--primary:hover  { transform: translate(-2px, -2px); box-shadow: 6px 6px 0 var(--c-ink); color: #FFFFFF; background: var(--c-ink); }
body.is-public-page .ipsoo-btn--primary:active { transform: translate(0,0);        box-shadow: 1px 1px 0 var(--c-ink); }

body.is-public-page .ipsoo-btn--secondary {
    background: transparent;
    color: var(--c-ink);
}
body.is-public-page .ipsoo-btn--secondary:hover {
    background: var(--c-ink);
    color: var(--c-canvas);
}

body.is-public-page .ipsoo-btn--dark {
    background: var(--c-ink);
    color: var(--c-canvas);
}
body.is-public-page .ipsoo-btn--dark:hover { background: var(--c-terracota); border-color: var(--c-terracota); color: #FFFFFF; }

.ipsoo-link {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    font-family: var(--f-sans);
    font-size: 0.9375rem;
    font-weight: 500;
    color: var(--c-ink);
    text-decoration: none;
    padding: 0.75rem 0;
    border-bottom: 1.5px solid var(--c-ink);
    transition: color 0.2s, border-color 0.2s;
}
.ipsoo-link::after { content: "→"; transition: transform 0.25s ease; }
.ipsoo-link:hover { color: var(--c-terracota); border-color: var(--c-terracota); }
.ipsoo-link:hover::after { transform: translateX(4px); }

/* ─── NAVBAR PÚBLICA (compacto, limpio) ─────────────────────────────────── */
body.is-public-page nav.fixed {
    background: rgba(251, 250, 248, 0.82);
    -webkit-backdrop-filter: blur(14px) saturate(140%);
    backdrop-filter: blur(14px) saturate(140%);
    border-bottom: 1px solid rgba(14, 21, 17, 0.06);
    box-shadow: none !important;
}
body.is-public-page nav.fixed > div {
    max-width: var(--wrap);
}

/* Logo — altura modesta pero escalado visualmente para que se vea grande
   sin afectar la altura del navbar (transform no ocupa espacio de layout) */
body.is-public-page .public-logo {
    height: 32px !important;
    width: auto !important;
    object-fit: contain !important;
    transform: scale(2) !important;
    transform-origin: left center !important;
    margin-right: 32px !important;
    flex-shrink: 0;
}
@media (min-width: 1024px) {
    body.is-public-page .public-logo {
        height: 36px !important;
        transform: scale(2.2) !important;
        margin-right: 40px !important;
    }
}

/* Navbar compacto */
body.is-public-page nav.fixed > div > div {
    min-height: 64px !important;
    height: 64px !important;
}
body.is-public-page main {
    padding-top: 72px;
}

/* Nav links tipogr&aacute;ficos, hover sutil */
body.is-public-page .nav-link {
    font-family: var(--f-sans);
    color: var(--c-stone);
    font-size: 0.875rem;
    font-weight: 500;
    letter-spacing: -0.005em;
    background: transparent !important;
    border-radius: 0 !important;
    padding: 0.5rem 0.75rem !important;
    transition: color 0.2s;
}
body.is-public-page .nav-link:hover,
body.is-public-page .nav-link.nav-active {
    color: var(--c-ink) !important;
    background: transparent !important;
}
body.is-public-page .nav-link.nav-active {
    position: relative;
}
body.is-public-page .nav-link.nav-active::after {
    content: "";
    position: absolute;
    bottom: 2px; left: 12px; right: 12px;
    height: 1.5px;
    background: var(--c-green-bright);
}

/* "Iniciar sesi&oacute;n" como texto limpio */
body.is-public-page nav.fixed a[href*="/login"] {
    color: var(--c-stone) !important;
    background: transparent !important;
    border-radius: 0 !important;
    font-weight: 500 !important;
    font-size: 0.875rem !important;
    padding: 0.5rem 0.75rem !important;
    transition: color 0.2s !important;
}
body.is-public-page nav.fixed a[href*="/login"]:hover {
    color: var(--c-ink) !important;
    background: transparent !important;
}

/* CTA "Registra tu negocio" — negro rectangular compacto */
body.is-public-page nav.fixed a[href*="/register/type"] {
    background: var(--c-ink) !important;
    color: var(--c-canvas) !important;
    border: none !important;
    border-radius: 6px !important;
    padding: 0.5rem 1rem !important;
    font-weight: 500 !important;
    font-size: 0.8125rem !important;
    box-shadow: none !important;
    transition: background 0.2s, color 0.2s !important;
    letter-spacing: -0.005em !important;
}
body.is-public-page nav.fixed a[href*="/register/type"]:hover {
    background: var(--c-green-bright) !important;
    color: var(--c-ink) !important;
}

/* ──── MOBILE MENU PÚBLICO (drawer derecho) ──────────────────── */
/* Panel del drawer — fondo canvas, borde sutil */
body.is-public-page .fixed.top-0.right-0[class*="w-[300px]"] {
    background: var(--c-canvas) !important;
    font-family: var(--f-sans);
}

/* Barra accent superior del drawer — usar verde brand solo */
body.is-public-page .fixed.top-0.right-0 .bg-gradient-to-r {
    background: var(--c-green-bright) !important;
    height: 2px !important;
}

/* Etiqueta "Menú" arriba */
body.is-public-page .fixed.top-0.right-0 .text-stone-400.uppercase {
    color: var(--c-stone);
    font-family: var(--f-mono);
    font-size: 0.6875rem;
    letter-spacing: 0.12em;
}

/* Bot&oacute;n X cerrar */
body.is-public-page .fixed.top-0.right-0 button.rounded-full {
    color: var(--c-ink) !important;
    background: transparent !important;
}
body.is-public-page .fixed.top-0.right-0 button.rounded-full:hover {
    background: rgba(14, 21, 17, 0.06) !important;
    color: var(--c-ink) !important;
}

/* Nav links del drawer — m&aacute;s limpios, sin pills pesadas */
body.is-public-page .fixed.top-0.right-0 nav a {
    border-radius: 8px !important;
    padding: 1rem 1rem !important;
    font-family: var(--f-sans) !important;
    font-size: 1rem !important;
    font-weight: 500 !important;
    color: var(--c-ink) !important;
    background: transparent !important;
    transition: background 0.2s, color 0.2s !important;
    gap: 0.875rem !important;
}
body.is-public-page .fixed.top-0.right-0 nav a:hover {
    background: rgba(21, 171, 146, 0.08) !important;
    color: var(--c-green-bright) !important;
}
body.is-public-page .fixed.top-0.right-0 nav a.bg-brand-50 {
    background: rgba(21, 171, 146, 0.12) !important;
    color: var(--c-green-bright) !important;
}
body.is-public-page .fixed.top-0.right-0 nav a span.w-9 {
    background: transparent !important;
    color: var(--c-stone) !important;
    width: 1.5rem !important;
    height: 1.5rem !important;
    font-size: 0.875rem !important;
}
body.is-public-page .fixed.top-0.right-0 nav a:hover span.w-9,
body.is-public-page .fixed.top-0.right-0 nav a.bg-brand-50 span.w-9 {
    color: var(--c-green-bright) !important;
}

/* Separador inferior */
body.is-public-page .fixed.top-0.right-0 .bg-stone-100 {
    background: rgba(14, 21, 17, 0.08) !important;
}

/* CTA "Registra tu negocio" del drawer — negro rectangular como navbar */
body.is-public-page .fixed.top-0.right-0 a.bg-brand-600 {
    background: var(--c-ink) !important;
    color: var(--c-canvas) !important;
    border-radius: 8px !important;
    padding: 0.875rem 1rem !important;
    font-weight: 600 !important;
    box-shadow: none !important;
    font-family: var(--f-sans) !important;
    transition: background 0.2s !important;
}
body.is-public-page .fixed.top-0.right-0 a.bg-brand-600:hover {
    background: var(--c-green-bright) !important;
    color: var(--c-ink) !important;
}

/* Link "Iniciar sesi&oacute;n" debajo del CTA */
body.is-public-page .fixed.top-0.right-0 a[href*="/login"]:not(.bg-brand-600) {
    color: var(--c-stone) !important;
    font-family: var(--f-sans) !important;
}
body.is-public-page .fixed.top-0.right-0 a[href*="/login"]:not(.bg-brand-600) .text-brand-600 {
    color: var(--c-green-bright) !important;
}

/* Footer "ipsoo.es" del drawer */
body.is-public-page .fixed.top-0.right-0 .text-stone-300 {
    color: var(--c-stone-soft) !important;
    font-family: var(--f-mono) !important;
    letter-spacing: 0.08em !important;
}

/* ─── MINI-SITES DEL ESCAPARATE (§ 01) ─────────────────────────────────── */
.ipsoo-minisite {
    width: 100%;
    max-width: 320px;
    background: #FFF;
    border: 1.5px solid var(--c-ink);
    border-radius: 3px;
    overflow: hidden;
    box-shadow: 6px 6px 0 var(--c-border-strong);
    transition: transform 0.3s cubic-bezier(.2,.8,.2,1), box-shadow 0.3s ease;
    display: flex;
    flex-direction: column;
}
.ipsoo-minisite:hover {
    transform: translate(-3px, -3px) rotate(0) !important;
    box-shadow: 10px 10px 0 var(--c-border-strong);
    z-index: 5;
}

.ipsoo-minisite__chrome {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.4375rem 0.625rem;
    background: var(--c-canvas-alt);
    border-bottom: 1px solid var(--c-border);
}
.ipsoo-minisite__dots { display: flex; gap: 4px; }
.ipsoo-minisite__dots span {
    width: 8px; height: 8px;
    border-radius: 50%;
    background: var(--c-border-strong);
}
.ipsoo-minisite__url {
    flex: 1;
    font-family: var(--f-mono);
    font-size: 0.625rem;
    color: var(--c-stone);
    text-align: center;
    opacity: 0.75;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.ipsoo-minisite__body {
    padding: 1rem 1.125rem 1.25rem;
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 0.625rem;
    min-height: 220px;
}

.ipsoo-minisite__title {
    font-family: var(--f-serif);
    font-size: 1.25rem;
    font-weight: 400;
    line-height: 1.05;
    letter-spacing: -0.01em;
}
.ipsoo-minisite__tagline {
    font-family: var(--f-mono);
    font-size: 0.625rem;
    opacity: 0.72;
    letter-spacing: 0.1em;
    text-transform: uppercase;
}
.ipsoo-minisite__services {
    display: flex;
    flex-direction: column;
    gap: 0.375rem;
    margin-top: auto;
    padding-top: 0.625rem;
    border-top: 1px solid currentColor;
    opacity: 0.92;
    font-size: 0.75rem;
    font-family: var(--f-mono);
}
.ipsoo-minisite__service {
    display: flex;
    justify-content: space-between;
    gap: 0.5rem;
}
.ipsoo-minisite__cta {
    margin-top: 0.75rem;
    padding: 0.5rem 0.75rem;
    text-align: center;
    font-family: var(--f-mono);
    font-size: 0.6875rem;
    font-weight: 500;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    border-radius: 2px;
}

/* Temas por negocio (data-theme) — background-color sólido + gradient como image */
.ipsoo-minisite[data-theme="barbershop"] .ipsoo-minisite__body { background-color: #2B1810; background-image: linear-gradient(180deg, #2B1810 0%, #180E07 100%); color: #E8D4A0; }
.ipsoo-minisite[data-theme="barbershop"] .ipsoo-minisite__cta  { background-color: #D4A15A; color: #1A0F09; }

.ipsoo-minisite[data-theme="nails"] .ipsoo-minisite__body      { background-color: #FCE8EF; background-image: linear-gradient(180deg, #FCE8EF 0%, #F5CEDC 100%); color: #5A2842; }
.ipsoo-minisite[data-theme="nails"] .ipsoo-minisite__cta       { background-color: #C74682; color: #FFFFFF; }

.ipsoo-minisite[data-theme="tattoo"] .ipsoo-minisite__body     { background-color: #0A0A0A; color: #D9D9D9; }
.ipsoo-minisite[data-theme="tattoo"] .ipsoo-minisite__cta      { background-color: #D4331F; color: #FFFFFF; }

.ipsoo-minisite[data-theme="spa"] .ipsoo-minisite__body        { background-color: #E8EEE3; background-image: linear-gradient(180deg, #E8EEE3 0%, #CFDCC9 100%); color: #263B21; }
.ipsoo-minisite[data-theme="spa"] .ipsoo-minisite__cta         { background-color: #3A5E32; color: #FFFFFF; }

.ipsoo-minisite[data-theme="fitness"] .ipsoo-minisite__body    { background-color: #0F0F0F; color: #D0FF6A; }
.ipsoo-minisite[data-theme="fitness"] .ipsoo-minisite__cta     { background-color: #D0FF6A; color: #0F0F0F; }

.ipsoo-minisite[data-theme="photo"] .ipsoo-minisite__body      { background-color: #F8F7F5; background-image: linear-gradient(180deg, #F8F7F5 0%, #E4E1DB 100%); color: #1A1A1A; }
.ipsoo-minisite[data-theme="photo"] .ipsoo-minisite__cta       { background-color: #1A1A1A; color: #FFFFFF; }

/* ─── HERO ─────────────────────────────────────────────────────────────── */
.ipsoo-hero {
    padding-top: clamp(1.5rem, 3vw, 2.5rem);
    padding-bottom: clamp(3rem, 6vw, 5rem);
    position: relative;
    overflow: hidden;
}
.ipsoo-hero__grid {
    display: grid;
    gap: clamp(2.5rem, 5vw, 4rem);
    grid-template-columns: 1fr;
}
@media (min-width: 1024px) {
    .ipsoo-hero__grid {
        grid-template-columns: minmax(0, 1.05fr) minmax(0, 1fr);
        align-items: center;
    }
}
.ipsoo-hero__text { max-width: 640px; }

/* Modo "solo t&iacute;tulo" — hero centrado sin columna derecha */
.ipsoo-hero--title-only .ipsoo-hero__text {
    max-width: 960px;
    margin: 0 auto;
    text-align: center;
}
.ipsoo-hero--title-only .ipsoo-hero__title {
    text-align: center;
}
.ipsoo-hero--title-only .ipsoo-hero__subtitle {
    margin-left: auto;
    margin-right: auto;
    max-width: 640px;
}
.ipsoo-hero--title-only .ipsoo-hero__ctas {
    justify-content: center;
}
.ipsoo-hero--title-only .ipsoo-hero__meta {
    margin-left: auto;
    margin-right: auto;
    justify-content: center;
    text-align: left;
}
/* Tama&ntilde;o display en modo solo t&iacute;tulo */
body.is-public-page .ipsoo-hero--title-only .ipsoo-hero__title {
    font-size: clamp(2.25rem, 5.5vw, 4.5rem) !important;
    line-height: 1.05 !important;
    letter-spacing: -0.03em !important;
    max-width: 22ch;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 1.75rem;
    font-weight: 700;
}
body.is-public-page .ipsoo-hero--title-only .ipsoo-hero__subtitle {
    font-size: clamp(1rem, 1.35vw, 1.1875rem);
    margin-bottom: 3rem; /* m&aacute;s aire antes de los CTAs */
}
body.is-public-page .ipsoo-hero--title-only .ipsoo-hero__ctas {
    margin-top: 0;
    margin-bottom: 3rem;
}
body.is-public-page .ipsoo-hero__title {
    font-family: var(--f-display);
    font-weight: 700;
    font-size: var(--fs-display);
    line-height: 0.92;
    letter-spacing: -0.04em;
    color: var(--c-ink);
    margin: 0 0 1.25rem;
}
body.is-public-page .ipsoo-hero__title em {
    font-style: normal;
    color: var(--c-green-bright);
    font-weight: 700;
}
.ipsoo-hero__subtitle {
    font-family: var(--f-sans);
    font-size: clamp(1.0625rem, 1.6vw, 1.3125rem);
    color: var(--c-ink);
    line-height: 1.42;
    margin: 0 0 2rem;
    max-width: 560px;
    font-weight: 400;
}
.ipsoo-hero__ctas {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    align-items: center;
    margin-bottom: 2.5rem;
}
.ipsoo-hero__meta {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.5rem;
    font-family: var(--f-mono);
    font-size: var(--fs-micro);
    color: var(--c-stone);
    text-transform: uppercase;
    letter-spacing: 0.08em;
    border-top: 1px solid var(--c-border);
    padding-top: 1.25rem;
    max-width: 520px;
}
.ipsoo-hero__meta-label { opacity: 0.6; display: block; margin-bottom: 0.25rem; }
.ipsoo-hero__meta-value { color: var(--c-ink); font-weight: 500; font-size: 0.8125rem; }

/* showcase (mini-sites arrangement) */
.ipsoo-hero__showcase {
    position: relative;
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.875rem;
}
@media (min-width: 640px) and (max-width: 1023px) {
    .ipsoo-hero__showcase { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}
@media (min-width: 1024px) {
    .ipsoo-hero__showcase {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 1.125rem;
    }
    .ipsoo-hero__showcase .ipsoo-minisite:nth-child(1) { transform: rotate(-2deg); }
    .ipsoo-hero__showcase .ipsoo-minisite:nth-child(2) { transform: translateY(2rem) rotate(1.5deg); }
    .ipsoo-hero__showcase .ipsoo-minisite:nth-child(3) { transform: translateY(-0.5rem) rotate(1deg); }
    .ipsoo-hero__showcase .ipsoo-minisite:nth-child(4) { transform: translateY(1.25rem) rotate(-1.2deg); }
    .ipsoo-hero__showcase .ipsoo-minisite:nth-child(5) { transform: rotate(-1.8deg); }
    .ipsoo-hero__showcase .ipsoo-minisite:nth-child(6) { transform: translateY(1.5rem) rotate(2deg); }
}
@media (max-width: 639px) {
    .ipsoo-hero__showcase { padding: 0.5rem 0; }
    .ipsoo-minisite { box-shadow: 4px 4px 0 var(--c-border-strong); }
    .ipsoo-minisite__body { min-height: 170px; padding: 0.875rem; }
    .ipsoo-minisite__title { font-size: 1rem; }
}

/* ─── EDITOR SPLIT (§ 02) ──────────────────────────────────────────────── */
.ipsoo-editor {
    display: grid;
    gap: 1.25rem;
    grid-template-columns: 1fr;
    margin-top: 2.75rem;
}
@media (min-width: 900px) {
    .ipsoo-editor { grid-template-columns: minmax(0, 1.25fr) minmax(0, 1fr); gap: 1.5rem; }
}

.ipsoo-editor__pane {
    border: 1.5px solid var(--c-ink);
    background: #FFF;
    border-radius: 3px;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    min-height: 460px;
    box-shadow: 6px 6px 0 var(--c-border-strong);
}
.ipsoo-editor__pane--editor { background: var(--c-canvas-alt); }

.ipsoo-editor__chrome {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 0.625rem 0.875rem;
    background: var(--c-canvas-alt);
    border-bottom: 1px solid var(--c-border);
}
.ipsoo-editor__pane--editor .ipsoo-editor__chrome { background: var(--c-ink); color: var(--c-canvas); border-bottom-color: var(--c-ink); }

.ipsoo-editor__label {
    font-family: var(--f-mono);
    font-size: var(--fs-micro);
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--c-stone);
    flex-shrink: 0;
}
.ipsoo-editor__pane--editor .ipsoo-editor__label { color: var(--c-stone-soft); }

/* Toolbar del editor (estilo real de un builder) */
.ipsoo-editor__toolbar {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    margin-left: auto;
    flex-wrap: wrap;
}
.ipsoo-editor__tool {
    width: 26px; height: 26px;
    background: transparent;
    border: 1px solid rgba(250, 248, 243, 0.25);
    border-radius: 3px;
    color: var(--c-stone-soft);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: all 0.2s;
}
.ipsoo-editor__tool:hover {
    background: rgba(250, 248, 243, 0.1);
    color: var(--c-canvas);
    border-color: var(--c-canvas);
}
.ipsoo-editor__divider {
    width: 1px;
    height: 16px;
    background: rgba(250, 248, 243, 0.2);
    margin: 0 0.25rem;
}
.ipsoo-editor__status {
    font-family: var(--f-mono);
    font-size: 0.625rem;
    color: var(--c-stone-soft);
    text-transform: uppercase;
    letter-spacing: 0.08em;
    white-space: nowrap;
}
.ipsoo-editor__publish {
    padding: 0.375rem 0.875rem;
    background: var(--c-green-bright);
    color: var(--c-ink);
    border: none;
    border-radius: 3px;
    font-family: var(--f-sans);
    font-size: 0.75rem;
    font-weight: 600;
    cursor: pointer;
    transition: background 0.2s;
    letter-spacing: -0.01em;
}
.ipsoo-editor__publish:hover { background: #19C2A6; }

.ipsoo-editor__sidelabel {
    font-family: var(--f-mono);
    font-size: var(--fs-micro);
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--c-stone);
    margin-bottom: 0.75rem;
}

.ipsoo-editor__content { padding: 1.25rem; flex: 1; }

.ipsoo-editor__preview {
    font-family: var(--f-serif);
}
.ipsoo-editor__preview h4 {
    font-size: 1.75rem;
    margin: 0 0 0.375rem;
    line-height: 1.05;
    color: var(--c-ink);
}
.ipsoo-editor__preview .sub {
    font-family: var(--f-mono);
    font-size: 0.6875rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--c-stone);
    margin-bottom: 1rem;
}
.ipsoo-editor__preview .services {
    font-family: var(--f-sans);
    font-size: 0.875rem;
    color: var(--c-ink);
    border-top: 1px solid var(--c-border);
    margin-top: 1rem;
    padding-top: 1rem;
}
.ipsoo-editor__preview .services div {
    display: flex;
    justify-content: space-between;
    padding: 0.5rem 0;
    border-bottom: 1px solid var(--c-border);
}
.ipsoo-editor__preview .services div:last-child { border-bottom: none; }
.ipsoo-editor__preview .services .price { font-family: var(--f-mono); color: var(--c-terracota); }

body.is-public-page .ipsoo-editor__preview-cta {
    display: inline-block;
    margin-top: 1rem;
    padding: 0.625rem 1.125rem;
    background: var(--c-ink);
    color: #FFFFFF;
    font-family: var(--f-sans);
    font-size: 0.8125rem;
    letter-spacing: 0.05em;
    text-decoration: none;
}

.ipsoo-editor__block {
    display: flex;
    align-items: center;
    gap: 0.625rem;
    padding: 0.75rem 0.875rem;
    background: rgba(250, 248, 243, 0.6);
    border: 1px solid var(--c-border);
    border-radius: 3px;
    margin-bottom: 0.5rem;
    font-family: var(--f-sans);
    font-size: 0.8125rem;
    color: var(--c-ink);
    transition: background 0.2s;
}
.ipsoo-editor__block:hover { background: #FFF; border-color: var(--c-green); }
.ipsoo-editor__block::before {
    content: "⋮⋮";
    color: var(--c-stone-soft);
    font-family: var(--f-mono);
    letter-spacing: -2px;
    font-weight: 700;
}
.ipsoo-editor__block .tag {
    margin-left: auto;
    font-family: var(--f-mono);
    font-size: 0.625rem;
    color: var(--c-stone);
    letter-spacing: 0.08em;
    text-transform: uppercase;
}
.ipsoo-editor__block--active {
    background: #FFF;
    border-color: var(--c-terracota);
    box-shadow: 0 0 0 2px var(--c-terracota-soft);
}

.ipsoo-editor__palette {
    margin-top: 1.25rem;
    padding-top: 1.25rem;
    border-top: 1px solid var(--c-border);
}
.ipsoo-editor__palette-label {
    font-family: var(--f-mono);
    font-size: var(--fs-micro);
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--c-stone);
    margin-bottom: 0.625rem;
}
.ipsoo-editor__swatches { display: flex; gap: 0.5rem; flex-wrap: wrap; }
.ipsoo-editor__swatch {
    width: 28px; height: 28px;
    border-radius: 50%;
    border: 1.5px solid var(--c-ink);
    cursor: pointer;
    transition: transform 0.18s ease;
    flex-shrink: 0;
}
.ipsoo-editor__swatch:hover { transform: scale(1.12); }
.ipsoo-editor__swatch--selected {
    outline: 2px solid var(--c-ink);
    outline-offset: 3px;
}

/* ─── STORYBOARD (§ 03) ────────────────────────────────────────────────── */
.ipsoo-storyboard {
    display: grid;
    gap: 1rem;
    grid-template-columns: 1fr;
    margin-top: 2.5rem;
}
@media (min-width: 640px)  { .ipsoo-storyboard { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1100px) { .ipsoo-storyboard { grid-template-columns: repeat(4, 1fr); } }

.ipsoo-frame {
    border: 1.5px solid var(--c-ink);
    padding: 1.75rem 1.375rem 1.5rem;
    position: relative;
    min-height: 260px;
    display: flex;
    flex-direction: column;
    gap: 0.625rem;
    background: var(--c-canvas);
    transition: transform 0.25s ease;
}
.ipsoo-frame:hover { transform: translate(-2px, -2px); box-shadow: 4px 4px 0 var(--c-ink); }
.ipsoo-frame:nth-child(even) { background: var(--c-canvas-alt); }

.ipsoo-frame__num {
    font-family: var(--f-mono);
    font-size: var(--fs-meta);
    color: var(--c-green);
    letter-spacing: 0.08em;
    text-transform: uppercase;
}
.ipsoo-frame__title {
    font-family: var(--f-serif);
    font-size: 1.625rem;
    line-height: 1.05;
    color: var(--c-ink);
    margin: 0;
    letter-spacing: -0.015em;
}
.ipsoo-frame__body {
    font-size: 0.9375rem;
    color: var(--c-stone);
    line-height: 1.55;
    margin: 0;
}
.ipsoo-frame__visual {
    margin-top: auto;
    padding-top: 1.25rem;
    border-top: 1px solid var(--c-border);
    font-family: var(--f-mono);
    font-size: 0.6875rem;
    color: var(--c-stone);
    text-transform: uppercase;
    letter-spacing: 0.08em;
    display: flex;
    align-items: center;
    gap: 0.5rem;
}
.ipsoo-frame__visual strong { color: var(--c-ink); font-weight: 500; }

/* ─── FEATURE INDEX (§ 04) ─────────────────────────────────────────────── */
.ipsoo-index { margin-top: 2.5rem; border-top: 1.5px solid var(--c-ink); }
.ipsoo-index__row {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 1rem 1.25rem;
    padding: 1.5rem 0;
    border-bottom: 1px solid var(--c-border);
    align-items: start;
}
@media (min-width: 768px) {
    .ipsoo-index__row {
        grid-template-columns: 3.5rem minmax(0, 1.1fr) minmax(0, 1.2fr);
        gap: 2rem;
        padding: 2rem 0;
        align-items: baseline;
    }
}
.ipsoo-index__num {
    font-family: var(--f-mono);
    font-size: var(--fs-meta);
    color: var(--c-green);
    letter-spacing: 0.05em;
}
.ipsoo-index__title {
    font-family: var(--f-serif);
    font-size: clamp(1.375rem, 2.5vw, 1.875rem);
    color: var(--c-ink);
    line-height: 1.05;
    margin: 0;
    letter-spacing: -0.015em;
}
.ipsoo-index__desc {
    font-size: 0.9375rem;
    color: var(--c-stone);
    margin: 0;
    line-height: 1.55;
    grid-column: 2;
}
@media (min-width: 768px) {
    .ipsoo-index__desc { grid-column: auto; }
}

/* ─── SHOWCASE (§ 05) ──────────────────────────────────────────────────── */
.ipsoo-showcase {
    display: grid;
    gap: 1.125rem;
    grid-template-columns: 1fr;
    margin-top: 2.5rem;
}
@media (min-width: 640px)  { .ipsoo-showcase { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .ipsoo-showcase { grid-template-columns: repeat(3, 1fr); } }

.ipsoo-showcase__card {
    border: 1.5px solid var(--c-ink);
    overflow: hidden;
    background: #FFF;
    transition: transform 0.25s cubic-bezier(.2,.8,.2,1), box-shadow 0.25s ease;
    display: flex;
    flex-direction: column;
    text-decoration: none !important;
}
.ipsoo-showcase__card:hover { transform: translate(-3px, -3px); box-shadow: 5px 5px 0 var(--c-ink); }
.ipsoo-showcase__media {
    aspect-ratio: 4/3;
    background: var(--c-canvas-alt);
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
}
.ipsoo-showcase__media img {
    width: 100%; height: 100%; object-fit: cover; display: block;
}
/* Iframe vivo de cada web real ------------------------------ */
.ipsoo-showcase__frame-wrap {
    position: relative;
    width: 100%;
    aspect-ratio: 4/3;
    overflow: hidden;
    background: var(--c-canvas-alt);
    pointer-events: none;
}
.ipsoo-showcase__frame-wrap iframe {
    position: absolute;
    top: 0; left: 0;
    width: 1440px;
    height: 1080px;
    border: 0;
    transform: scale(0.35);
    transform-origin: 0 0;
    pointer-events: none;
    background: #FFF;
}
@media (min-width: 640px) {
    .ipsoo-showcase__frame-wrap iframe { transform: scale(0.28); width: 1600px; height: 1200px; }
}
@media (min-width: 1024px) {
    .ipsoo-showcase__frame-wrap iframe { transform: scale(0.3); width: 1600px; height: 1200px; }
}
.ipsoo-showcase__media-label {
    position: absolute;
    bottom: 0.75rem;
    left: 0.75rem;
    padding: 0.25rem 0.625rem;
    background: var(--c-ink);
    color: var(--c-canvas);
    font-family: var(--f-mono);
    font-size: 0.625rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
}
.ipsoo-showcase__meta {
    padding: 1rem 1.125rem;
    border-top: 1.5px solid var(--c-ink);
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    gap: 1rem;
}
.ipsoo-showcase__title {
    font-family: var(--f-serif);
    font-size: 1.1875rem;
    color: var(--c-ink);
    line-height: 1.1;
    letter-spacing: -0.01em;
}
.ipsoo-showcase__cat {
    font-family: var(--f-mono);
    font-size: 0.625rem;
    color: var(--c-green); /* WCAG-safe green */
    text-transform: uppercase;
    letter-spacing: 0.08em;
    white-space: nowrap;
    font-weight: 500;
}

/* ─── PRICING (§ 06) ───────────────────────────────────────────────────── */
.ipsoo-pricing {
    border: 1.5px solid var(--c-ink);
    margin-top: 2.5rem;
    background: #FFF;
}
.ipsoo-pricing__row {
    display: grid;
    grid-template-columns: 1fr;
    border-bottom: 1px solid var(--c-border);
    padding: 0;
}
@media (min-width: 768px) {
    .ipsoo-pricing__row {
        grid-template-columns: 1.3fr 2.5fr auto;
        gap: 1.5rem;
        align-items: center;
        padding: 0;
    }
}
.ipsoo-pricing__row:last-child { border-bottom: none; }
.ipsoo-pricing__row--featured {
    background: var(--c-canvas);
    position: relative;
    border-top: 2px solid var(--c-green-bright);
    border-bottom: 2px solid var(--c-green-bright);
}

/* Badges (recomendado, primer mes gratis, etc.) */
.ipsoo-pricing__badges {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    margin-top: 0.5rem;
}
.ipsoo-pricing__badge {
    display: inline-flex;
    align-items: center;
    gap: 0.375rem;
    padding: 0.25rem 0.625rem;
    font-family: var(--f-sans);
    font-size: 0.6875rem;
    font-weight: 600;
    letter-spacing: 0.02em;
    border-radius: 2px;
    line-height: 1.2;
}
.ipsoo-pricing__badge--recommended {
    background: var(--c-green-bright);
    color: var(--c-ink);
}
.ipsoo-pricing__badge--free-month {
    background: var(--c-ink);
    color: var(--c-green-bright);
}
.ipsoo-pricing__badge--free-month::before {
    content: "★";
    font-size: 0.75rem;
    line-height: 1;
}
.ipsoo-pricing__plan {
    padding: 1.5rem 1.5rem 0.5rem;
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 1rem;
}
@media (min-width: 768px) { .ipsoo-pricing__plan { padding: 1.75rem 1.5rem; } }
.ipsoo-pricing__name {
    font-family: var(--f-serif);
    font-size: 1.625rem;
    color: var(--c-ink);
    line-height: 1;
    margin: 0;
}
.ipsoo-pricing__price {
    font-family: var(--f-mono);
    font-size: 1.1875rem;
    color: var(--c-ink);
    font-weight: 500;
}
.ipsoo-pricing__price-unit {
    font-size: 0.75rem;
    color: var(--c-stone);
    margin-left: 0.25rem;
}
.ipsoo-pricing__price--free {
    color: var(--c-green); /* WCAG-safe green */
}
.ipsoo-pricing__features {
    padding: 0 1.5rem;
    color: var(--c-stone);
    font-size: 0.875rem;
    line-height: 1.65;
}
@media (min-width: 768px) { .ipsoo-pricing__features { padding: 1.75rem 0; } }
.ipsoo-pricing__features ul {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem 1.25rem;
}
.ipsoo-pricing__features li {
    position: relative;
    padding-left: 0.75rem;
    font-size: 0.8125rem;
}
.ipsoo-pricing__features li::before {
    content: "·";
    position: absolute;
    left: 0;
    color: var(--c-green);
    font-weight: 700;
}
.ipsoo-pricing__action { padding: 0 1.5rem 1.5rem; }
@media (min-width: 768px) { .ipsoo-pricing__action { padding: 1.75rem 1.5rem; text-align: right; } }

/* Mobile: bot&oacute;n full-width, layout m&aacute;s limpio */
@media (max-width: 767px) {
    body.is-public-page .ipsoo-pricing__plan {
        flex-direction: column;
        align-items: flex-start;
        gap: 0.75rem;
        padding: 1.5rem 1.25rem 0.75rem;
    }
    body.is-public-page .ipsoo-pricing__features {
        padding: 0.5rem 1.25rem 1rem;
    }
    body.is-public-page .ipsoo-pricing__features ul {
        flex-direction: column;
        gap: 0.625rem;
    }
    body.is-public-page .ipsoo-pricing__features li {
        font-size: 0.9375rem;
        padding-left: 1rem;
    }
    body.is-public-page .ipsoo-pricing__features li::before {
        font-size: 1rem;
        top: -1px;
    }
    body.is-public-page .ipsoo-pricing__action {
        padding: 0 1.25rem 1.5rem;
    }
    body.is-public-page .ipsoo-pricing__action .ipsoo-btn {
        display: flex;
        width: 100%;
        justify-content: center;
    }
    body.is-public-page .ipsoo-pricing__price {
        font-size: 1.375rem;
    }
    body.is-public-page .ipsoo-pricing__name {
        font-size: 1.75rem;
    }
    body.is-public-page .ipsoo-pricing__row--featured::before {
        top: 0.625rem; right: 1rem;
    }
}

/* ─── FAQ (§ 07) ───────────────────────────────────────────────────────── */
.ipsoo-faq { margin-top: 2.5rem; max-width: 820px; }
.ipsoo-faq__item {
    border-bottom: 1px solid var(--c-border);
    padding: 1.375rem 0;
}
.ipsoo-faq__item:first-child { border-top: 1px solid var(--c-border); }
.ipsoo-faq__item summary {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    gap: 1rem;
    cursor: pointer;
    list-style: none;
    font-family: var(--f-sans);
    font-size: 1.0625rem;
    font-weight: 500;
    color: var(--c-ink);
    padding: 0.25rem 0;
    transition: color 0.2s;
}
.ipsoo-faq__item summary:hover { color: var(--c-terracota); }
.ipsoo-faq__item summary::-webkit-details-marker { display: none; }
.ipsoo-faq__num {
    font-family: var(--f-mono);
    font-size: 0.75rem;
    color: var(--c-green);
    font-weight: 400;
    vertical-align: top;
    margin-right: 0.5rem;
}
.ipsoo-faq__toggle {
    font-family: var(--f-mono);
    font-size: 1.375rem;
    color: var(--c-stone);
    transition: transform 0.2s, color 0.2s;
    line-height: 1;
    flex-shrink: 0;
    font-weight: 300;
}
.ipsoo-faq__item[open] .ipsoo-faq__toggle { transform: rotate(45deg); color: var(--c-terracota); }
.ipsoo-faq__answer {
    padding: 0.75rem 0 0;
    color: var(--c-stone);
    font-size: 0.9375rem;
    line-height: 1.65;
    max-width: 680px;
}

/* ─── CTA FINAL (§ 08) ─────────────────────────────────────────────────── */
.ipsoo-cta-final {
    background: var(--c-canvas-alt);
    padding-block: clamp(3rem, 8vw, 6rem);
    text-align: center;
    border-top: 1.5px solid var(--c-ink);
    border-bottom: 1.5px solid var(--c-ink);
    position: relative;
}
.ipsoo-cta-final .ipsoo-wrap {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
}
body.is-public-page .ipsoo-cta-final__title {
    font-family: var(--f-display);
    font-weight: 700;
    font-size: clamp(2.25rem, 5.5vw, 4rem);
    line-height: 1.05;
    letter-spacing: -0.03em;
    color: var(--c-ink);
    max-width: 22ch;
    margin: 0 auto 1.5rem;
    text-align: center;
}
body.is-public-page .ipsoo-cta-final__title em { font-style: normal; color: var(--c-green-bright); font-weight: 700; }
.ipsoo-cta-final__body {
    color: var(--c-stone);
    font-size: 1.0625rem;
    max-width: 440px;
    margin: 0 auto 2rem;
    text-align: center;
}

/* ─── FOOTER COLOFÓN ───────────────────────────────────────────────────── */
.ipsoo-colofon {
    background: var(--c-ink);
    color: var(--c-canvas);
    padding-block: clamp(3rem, 6vw, 5rem);
    font-family: var(--f-sans);
}
.ipsoo-colofon a { color: var(--c-stone-soft); transition: color 0.2s; }
.ipsoo-colofon a:hover { color: var(--c-canvas); }
.ipsoo-colofon__grid { display: grid; grid-template-columns: 1fr; gap: 2.5rem; }
@media (min-width: 640px)  { .ipsoo-colofon__grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .ipsoo-colofon__grid { grid-template-columns: 2fr 1fr 1fr 1fr; gap: 3rem; } }

.ipsoo-colofon__brand {
    font-family: var(--f-serif);
    font-weight: 400;
    font-size: 2.25rem;
    line-height: 1;
    color: var(--c-canvas);
    margin: 0 0 0.625rem;
    letter-spacing: -0.02em;
}
.ipsoo-colofon__tag {
    font-family: var(--f-mono);
    font-size: var(--fs-micro);
    color: var(--c-green-bright); /* sobre fondo oscuro, verde brillante s&iacute; pasa */
    text-transform: uppercase;
    letter-spacing: 0.1em;
    margin-bottom: 1.5rem;
}
body.is-public-page .ipsoo-colofon__desc {
    color: #C7C2B8; /* lighter on dark for WCAG AA 5:1 */
    font-size: 0.875rem;
    line-height: 1.6;
    max-width: 320px;
    margin-bottom: 1.5rem;
}
.ipsoo-colofon__social { display: flex; gap: 0.625rem; }
.ipsoo-colofon__social a {
    width: 38px; height: 38px;
    border: 1px solid rgba(250, 248, 243, 0.18);
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 2px;
    transition: border-color 0.2s, color 0.2s, background 0.2s;
    color: var(--c-stone-soft);
}
.ipsoo-colofon__social a:hover {
    border-color: var(--c-terracota);
    background: var(--c-terracota);
    color: #FFF;
}
.ipsoo-colofon__heading {
    font-family: var(--f-mono);
    font-size: var(--fs-micro);
    color: var(--c-stone-soft);
    text-transform: uppercase;
    letter-spacing: 0.12em;
    margin: 0 0 1.25rem;
}
.ipsoo-colofon__list {
    list-style: none; padding: 0; margin: 0;
    display: flex; flex-direction: column; gap: 0.625rem;
}
.ipsoo-colofon__list a { font-size: 0.875rem; }
.ipsoo-colofon__bottom {
    margin-top: clamp(2rem, 5vw, 3.5rem);
    padding-top: 1.25rem;
    border-top: 1px solid rgba(250, 248, 243, 0.1);
    display: flex;
    flex-direction: column;
    gap: 0.625rem;
    justify-content: space-between;
    font-family: var(--f-mono);
    font-size: var(--fs-micro);
    color: var(--c-stone-soft);
    text-transform: uppercase;
    letter-spacing: 0.1em;
}
@media (min-width: 768px) {
    .ipsoo-colofon__bottom {
        flex-direction: row;
        align-items: center;
    }
}
.ipsoo-colofon__bottom span {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
}

/* ─── PWA safe-areas (respeta diseño standalone) ───────────────────────── */
@supports (padding-top: env(safe-area-inset-top)) {
    @media (display-mode: standalone) {
        body.is-public-page nav.fixed { padding-top: env(safe-area-inset-top); }
    }
}

/* ─── FOCUS VISIBILITY (a11y) ──────────────────────────────────────────── */
body.is-public-page a:focus-visible,
body.is-public-page button:focus-visible,
body.is-public-page summary:focus-visible {
    outline: 2px solid var(--c-terracota);
    outline-offset: 3px;
    border-radius: 2px;
}

/* ─── REDUCED MOTION ───────────────────────────────────────────────────── */
@media (prefers-reduced-motion: reduce) {
    body.is-public-page *,
    body.is-public-page *::before,
    body.is-public-page *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
        scroll-behavior: auto !important;
    }
    .ipsoo-hero__showcase .ipsoo-minisite { transform: none !important; }
    .ipsoo-minisite:hover { transform: none !important; }
}

/* ─── UTILITIES ────────────────────────────────────────────────────────── */
.ipsoo-mono        { font-family: var(--f-mono); }
.ipsoo-serif       { font-family: var(--f-serif); }
.ipsoo-muted       { color: var(--c-stone); }
.ipsoo-em          { color: var(--c-green-bright); }
.ipsoo-green       { color: var(--c-green); }
.ipsoo-em-italic   { font-style: normal; color: var(--c-green-bright); font-weight: 700; }
.ipsoo-section-head {
    max-width: 720px;
    margin-bottom: 1rem;
}
.ipsoo-section-head p { font-size: 1.0625rem; color: var(--c-stone); margin-top: 0.5rem; }

/* ═══════════════════════════════════════════════════════════════════
   AUTH (login, register, forgot-password, reset-password, verify-email)
   Estética editorial unificada. Funciona en web y en PWA standalone.
   ═══════════════════════════════════════════════════════════════════ */

body.is-public-page .auth-shell {
    min-height: calc(100vh - 72px);
    display: flex;
    align-items: flex-start;
    justify-content: center;
    padding: clamp(2rem, 6vw, 4rem) 1.25rem clamp(2.5rem, 6vw, 4rem);
    background: var(--c-canvas);
}
body.is-public-page .auth-shell__inner {
    width: 100%;
    max-width: 460px;
}
body.is-public-page .auth-shell--wide .auth-shell__inner { max-width: 560px; }
body.is-public-page .auth-shell--xwide .auth-shell__inner { max-width: 820px; }

/* Cabecera */
body.is-public-page .auth-head {
    margin-bottom: 1.75rem;
    text-align: center;
}
body.is-public-page .auth-head .ipsoo-marker {
    justify-content: center;
    margin-bottom: 0.875rem;
}
body.is-public-page .auth-head h1 {
    font-family: var(--f-display);
    font-weight: 700;
    font-size: clamp(1.875rem, 5vw, 2.5rem);
    line-height: 1.05;
    letter-spacing: -0.025em;
    color: var(--c-ink);
    margin: 0 0 0.75rem;
}
body.is-public-page .auth-head h1 em {
    font-style: normal;
    color: var(--c-green-bright);
    font-weight: 700;
}
body.is-public-page .auth-head p {
    font-family: var(--f-sans);
    font-size: 0.9375rem;
    color: var(--c-stone);
    line-height: 1.5;
    margin: 0;
    max-width: 380px;
    margin-left: auto;
    margin-right: auto;
}
body.is-public-page .auth-head p strong {
    color: var(--c-ink);
    font-weight: 600;
    word-break: break-word;
}

/* Tarjeta */
body.is-public-page .auth-card {
    background: #FFF;
    border: 1.5px solid var(--c-ink);
    box-shadow: 6px 6px 0 var(--c-border-strong);
    padding: 1.75rem 1.5rem 2rem;
}
@media (min-width: 500px) {
    body.is-public-page .auth-card {
        padding: 2rem 2rem 2.25rem;
    }
}

/* Formulario */
body.is-public-page .auth-form {
    display: flex;
    flex-direction: column;
    gap: 1.125rem;
}
body.is-public-page .auth-form__row {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.125rem;
}
@media (min-width: 480px) {
    body.is-public-page .auth-form__row {
        grid-template-columns: repeat(2, 1fr);
    }
}
body.is-public-page .auth-form__field {
    display: flex;
    flex-direction: column;
    gap: 0.4375rem;
}
body.is-public-page .auth-form__label-row {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    gap: 0.75rem;
}
body.is-public-page .auth-form__label {
    font-family: var(--f-mono);
    font-size: var(--fs-micro);
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--c-stone);
    font-weight: 400;
    margin: 0;
}
body.is-public-page .auth-form__label .req {
    color: var(--c-green);
    font-family: var(--f-mono);
}
body.is-public-page .auth-form__forgot {
    font-family: var(--f-sans);
    font-size: 0.75rem;
    color: var(--c-green);
    font-weight: 500;
    border-bottom: 1px solid currentColor;
    padding-bottom: 1px;
    transition: color 0.15s;
}
body.is-public-page .auth-form__forgot:hover {
    color: var(--c-ink);
}

body.is-public-page .auth-form__input {
    width: 100%;
    padding: 0.8125rem 1rem;
    font-family: var(--f-sans);
    font-size: 0.9375rem;
    color: var(--c-ink);
    background: var(--c-canvas);
    border: 1.5px solid var(--c-border-strong);
    border-radius: 2px;
    transition: border-color 0.15s, background 0.15s, box-shadow 0.15s;
    appearance: none;
}
body.is-public-page .auth-form__input::placeholder {
    color: var(--c-stone-soft);
}
body.is-public-page .auth-form__input:hover {
    border-color: var(--c-ink);
}
body.is-public-page .auth-form__input:focus {
    outline: none;
    border-color: var(--c-ink);
    background: #FFF;
    box-shadow: 0 0 0 3px var(--c-green-soft);
}
body.is-public-page .auth-form__select {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%230E1511' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 0.875rem center;
    padding-right: 2.5rem;
    cursor: pointer;
}

body.is-public-page .auth-form__hint {
    font-family: var(--f-sans);
    font-size: 0.75rem;
    color: var(--c-stone);
    margin: 0;
    line-height: 1.4;
}

/* Checkbox */
body.is-public-page .auth-form__check {
    display: flex;
    align-items: flex-start;
    gap: 0.625rem;
    cursor: pointer;
    font-family: var(--f-sans);
    font-size: 0.875rem;
    color: var(--c-ink);
    line-height: 1.45;
    user-select: none;
}
body.is-public-page .auth-form__check-input {
    position: absolute;
    opacity: 0;
    width: 1px;
    height: 1px;
    pointer-events: none;
}
body.is-public-page .auth-form__check-box {
    flex-shrink: 0;
    width: 18px;
    height: 18px;
    margin-top: 1px;
    border: 1.5px solid var(--c-border-strong);
    background: var(--c-canvas);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: transparent;
    transition: border-color 0.15s, background 0.15s, color 0.15s;
    border-radius: 2px;
}
body.is-public-page .auth-form__check-input:focus-visible + .auth-form__check-box {
    box-shadow: 0 0 0 3px var(--c-green-soft);
    border-color: var(--c-ink);
}
body.is-public-page .auth-form__check-input:checked + .auth-form__check-box {
    background: var(--c-green-bright);
    border-color: var(--c-ink);
    color: var(--c-ink);
}
body.is-public-page .auth-form__check-text a {
    color: var(--c-green);
    border-bottom: 1px solid currentColor;
}
body.is-public-page .auth-form__check-text a:hover {
    color: var(--c-ink);
}

/* Submit */
body.is-public-page .auth-form__submit {
    width: 100%;
    justify-content: center;
    margin-top: 0.25rem;
}

/* Divider */
body.is-public-page .auth-divider {
    display: flex;
    align-items: center;
    gap: 0.875rem;
    margin: 1.5rem 0 1.25rem;
    font-family: var(--f-mono);
    font-size: var(--fs-micro);
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--c-stone-soft);
}
body.is-public-page .auth-divider::before,
body.is-public-page .auth-divider::after {
    content: '';
    flex: 1;
    height: 1px;
    background: var(--c-border);
}
body.is-public-page .auth-divider span {
    font-weight: 400;
}

/* Google button */
body.is-public-page .auth-google {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.625rem;
    width: 100%;
    padding: 0.8125rem 1rem;
    font-family: var(--f-sans);
    font-size: 0.9375rem;
    font-weight: 500;
    color: var(--c-ink);
    background: #FFF;
    border: 1.5px solid var(--c-ink);
    border-radius: 2px;
    min-height: 48px;
    transition: background 0.15s, transform 0.18s cubic-bezier(.2,.8,.2,1);
    text-decoration: none;
}
body.is-public-page .auth-google:hover {
    background: var(--c-canvas-alt);
}
body.is-public-page .auth-google:active {
    transform: translate(1px, 1px);
}

/* Secondary link-button dentro del card */
body.is-public-page .auth-secondary {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    width: 100%;
    padding: 0.75rem 1rem;
    font-family: var(--f-sans);
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--c-stone);
    background: transparent;
    border: 1.5px solid var(--c-border-strong);
    border-radius: 2px;
    min-height: 44px;
    cursor: pointer;
    transition: color 0.15s, border-color 0.15s, background 0.15s;
    text-decoration: none;
}
body.is-public-page .auth-secondary:hover {
    color: var(--c-ink);
    border-color: var(--c-ink);
    background: var(--c-canvas-alt);
}

/* Alertas */
body.is-public-page .auth-alert {
    display: flex;
    align-items: flex-start;
    gap: 0.625rem;
    padding: 0.875rem 1rem;
    border: 1.5px solid;
    font-family: var(--f-sans);
    font-size: 0.875rem;
    line-height: 1.45;
    font-weight: 500;
    margin-bottom: 1.25rem;
    border-radius: 2px;
}
body.is-public-page .auth-alert svg {
    flex-shrink: 0;
    margin-top: 1px;
}
body.is-public-page .auth-alert--ok {
    background: var(--c-green-soft);
    border-color: var(--c-green-bright);
    color: var(--c-green-dark);
}
body.is-public-page .auth-alert--err {
    background: #FBEAEA;
    border-color: #C74545;
    color: #8F1F1F;
}
body.is-public-page .auth-alert--info {
    background: var(--c-canvas-alt);
    border-color: var(--c-ink);
    color: var(--c-ink);
}
body.is-public-page .auth-alert--warn {
    background: #FFF7E6;
    border-color: #C78A2E;
    color: #6E4914;
}
body.is-public-page .auth-alert ul {
    list-style: none;
    padding: 0;
    margin: 0.375rem 0 0;
    display: flex;
    flex-direction: column;
    gap: 0.1875rem;
}
body.is-public-page .auth-alert ul li::before {
    content: '\2022';
    margin-right: 0.5rem;
    color: currentColor;
    opacity: 0.6;
}

/* Footer de auth (debajo del card) */
body.is-public-page .auth-footer {
    margin-top: 1.5rem;
    text-align: center;
    font-family: var(--f-sans);
    font-size: 0.875rem;
    color: var(--c-stone);
}
body.is-public-page .auth-footer a {
    color: var(--c-ink);
    font-weight: 600;
    border-bottom: 1.5px solid var(--c-ink);
    padding-bottom: 1px;
    transition: color 0.15s, border-color 0.15s;
}
body.is-public-page .auth-footer a:hover {
    color: var(--c-green);
    border-color: var(--c-green);
}

/* Destacado con icono (éxito, email pendiente, etc) */
body.is-public-page .auth-emblem {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 56px;
    height: 56px;
    margin: 0 auto 1.25rem;
    background: var(--c-canvas);
    border: 1.5px solid var(--c-ink);
    border-radius: 50%;
    color: var(--c-ink);
}
body.is-public-page .auth-emblem--green {
    background: var(--c-green-soft);
    border-color: var(--c-green-bright);
    color: var(--c-green-dark);
}

/* Lista de pasos/ventajas dentro de un card (verify-email-*) */
body.is-public-page .auth-steps {
    display: flex;
    flex-direction: column;
    gap: 0.375rem;
    padding: 1rem 1.125rem;
    background: var(--c-canvas-alt);
    border: 1.5px solid var(--c-ink);
    margin: 1rem 0 1.25rem;
}
body.is-public-page .auth-steps__title {
    font-family: var(--f-mono);
    font-size: var(--fs-micro);
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--c-stone);
    margin: 0 0 0.5rem;
}
body.is-public-page .auth-steps ol,
body.is-public-page .auth-steps ul {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 0.4375rem;
    counter-reset: step;
}
body.is-public-page .auth-steps li {
    display: flex;
    align-items: center;
    gap: 0.625rem;
    font-family: var(--f-sans);
    font-size: 0.875rem;
    color: var(--c-ink);
    line-height: 1.45;
}
body.is-public-page .auth-steps ol li::before {
    counter-increment: step;
    content: counter(step, decimal-leading-zero);
    font-family: var(--f-mono);
    font-size: 0.75rem;
    color: var(--c-green);
    flex-shrink: 0;
    min-width: 1.5rem;
    letter-spacing: 0.05em;
}
body.is-public-page .auth-steps ul li::before {
    content: '\2713';
    font-family: var(--f-mono);
    color: var(--c-green-bright);
    flex-shrink: 0;
    min-width: 1.25rem;
    font-weight: 700;
}

/* Cards de selección (register-type) */
body.is-public-page .auth-choice {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1rem;
    margin: 0 0 1.5rem;
}
@media (min-width: 680px) {
    body.is-public-page .auth-choice {
        grid-template-columns: repeat(2, 1fr);
    }
}
body.is-public-page .auth-choice__item {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    padding: 1.5rem 1.375rem;
    background: #FFF;
    border: 1.5px solid var(--c-ink);
    text-decoration: none;
    color: var(--c-ink);
    transition: transform 0.2s cubic-bezier(.2,.8,.2,1), box-shadow 0.2s ease;
    cursor: pointer;
}
body.is-public-page .auth-choice__item:hover {
    transform: translate(-3px, -3px);
    box-shadow: 6px 6px 0 var(--c-ink);
}
body.is-public-page .auth-choice__tag {
    font-family: var(--f-mono);
    font-size: var(--fs-micro);
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--c-green);
}
body.is-public-page .auth-choice__title {
    font-family: var(--f-display);
    font-size: 1.5rem;
    font-weight: 700;
    line-height: 1.05;
    letter-spacing: -0.015em;
    color: var(--c-ink);
    margin: 0.25rem 0 0.5rem;
}
body.is-public-page .auth-choice__body {
    font-family: var(--f-sans);
    font-size: 0.9375rem;
    color: var(--c-stone);
    line-height: 1.5;
    margin: 0 0 0.75rem;
}
body.is-public-page .auth-choice__list {
    list-style: none;
    padding: 0;
    margin: 0 0 0.75rem;
    display: flex;
    flex-direction: column;
    gap: 0.375rem;
}
body.is-public-page .auth-choice__list li {
    font-family: var(--f-sans);
    font-size: 0.8125rem;
    color: var(--c-stone);
    padding-left: 1rem;
    position: relative;
}
body.is-public-page .auth-choice__list li::before {
    content: '\2713';
    position: absolute;
    left: 0;
    color: var(--c-green);
    font-weight: 700;
    font-family: var(--f-mono);
}
body.is-public-page .auth-choice__cta {
    margin-top: auto;
    padding-top: 0.5rem;
    display: flex;
    align-items: center;
    gap: 0.375rem;
    font-family: var(--f-mono);
    font-size: var(--fs-micro);
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--c-ink);
    font-weight: 500;
}
body.is-public-page .auth-choice__cta::after {
    content: '\2192';
    transition: transform 0.2s;
}
body.is-public-page .auth-choice__item:hover .auth-choice__cta::after {
    transform: translateX(3px);
}

/* Modal editorial (verify-email-pending change email) */
body.is-public-page .auth-modal {
    position: fixed;
    inset: 0;
    background: rgba(14, 21, 17, 0.5);
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1.25rem;
    z-index: 50;
}
body.is-public-page .auth-modal__panel {
    background: #FFF;
    border: 1.5px solid var(--c-ink);
    box-shadow: 6px 6px 0 rgba(14, 21, 17, 0.4);
    padding: 1.5rem 1.375rem 1.75rem;
    max-width: 420px;
    width: 100%;
}
body.is-public-page .auth-modal__head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 1rem;
    margin-bottom: 1.25rem;
}
body.is-public-page .auth-modal__title {
    font-family: var(--f-display);
    font-weight: 700;
    font-size: 1.25rem;
    color: var(--c-ink);
    line-height: 1.1;
    letter-spacing: -0.015em;
    margin: 0.25rem 0 0.375rem;
}
body.is-public-page .auth-modal__close {
    background: transparent;
    border: none;
    color: var(--c-stone);
    cursor: pointer;
    font-size: 1.25rem;
    line-height: 1;
    padding: 0.25rem 0.5rem;
    font-family: var(--f-mono);
    margin: -0.25rem -0.5rem -0.25rem 0;
}
body.is-public-page .auth-modal__close:hover {
    color: var(--c-ink);
}
body.is-public-page .auth-modal__actions {
    display: flex;
    gap: 0.5rem;
    margin-top: 1.25rem;
}
body.is-public-page .auth-modal__actions > * {
    flex: 1 1 0;
    justify-content: center;
}

/* ===== PWA standalone ===== */
@media (display-mode: standalone) {
    body.is-public-page .auth-shell {
        padding-top: clamp(1.5rem, 6vw, 3rem);
        min-height: 100vh;
    }
    body.is-public-page .auth-card {
        box-shadow: none;
        border-left: none;
        border-right: none;
    }
}

/* Pantallas muy pequeñas */
@media (max-width: 380px) {
    body.is-public-page .auth-shell {
        padding-left: 0.875rem;
        padding-right: 0.875rem;
    }
    body.is-public-page .auth-card {
        padding: 1.5rem 1.25rem 1.75rem;
        box-shadow: 4px 4px 0 var(--c-border-strong);
    }
    body.is-public-page .auth-head h1 {
        font-size: 1.625rem;
    }
    body.is-public-page .auth-modal__panel {
        padding: 1.25rem 1.125rem 1.375rem;
        box-shadow: 4px 4px 0 rgba(14, 21, 17, 0.4);
    }
}

/* ═══════════════════════════════════════════════════════════════════
   PWA NATIVE — Auth shell rediseñado para modo standalone (iOS/Android)
   Cuando la PWA está instalada: look & feel de app nativa.
   No afecta al navegador móvil (solo aplica con display-mode: standalone).
   ═══════════════════════════════════════════════════════════════════ */
@media (display-mode: standalone) {
    /* Capa base: fondo blanco limpio, sin marcas editoriales agresivas */
    body.is-public-page {
        background: #FFFFFF !important;
        font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', system-ui, 'Inter', sans-serif !important;
    }

    /* Shell ocupa toda la altura disponible, contenido centrado */
    body.is-public-page .auth-shell {
        background: #FFFFFF !important;
        min-height: calc(100dvh - env(safe-area-inset-top) - 64px);
        align-items: stretch;
        padding: 0 !important;
    }
    body.is-public-page .auth-shell__inner {
        max-width: 100% !important;
        padding: 24px 22px 32px;
        padding-bottom: calc(32px + env(safe-area-inset-bottom));
        display: flex;
        flex-direction: column;
        justify-content: flex-start;
    }
    body.is-public-page .auth-shell--xwide .auth-shell__inner {
        max-width: 100% !important;
    }

    /* Header limpio sin marker editorial */
    body.is-public-page .auth-head {
        text-align: left;
        margin-bottom: 24px;
        padding-top: 8px;
    }
    body.is-public-page .auth-head .ipsoo-marker {
        display: none !important;
    }
    body.is-public-page .auth-head h1 {
        font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', system-ui, sans-serif !important;
        font-size: 28px !important;
        font-weight: 800 !important;
        letter-spacing: -0.025em;
        line-height: 1.15 !important;
        color: #0F172A;
        margin: 0 0 8px !important;
    }
    body.is-public-page .auth-head h1 em {
        font-style: normal;
        color: #15ab92;
        font-weight: 800;
    }
    body.is-public-page .auth-head p {
        font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', system-ui, sans-serif !important;
        font-size: 15px !important;
        color: #64748B !important;
        line-height: 1.45 !important;
        max-width: none !important;
        margin: 0 !important;
    }
    body.is-public-page .auth-head p strong {
        color: #0F172A;
        font-weight: 600;
    }

    /* Card sin bordes/offset shadow — diseño plano nativo */
    body.is-public-page .auth-card {
        background: transparent !important;
        border: none !important;
        box-shadow: none !important;
        padding: 0 !important;
    }

    /* Inputs estilo iOS/Android */
    body.is-public-page .auth-form {
        gap: 16px !important;
    }
    body.is-public-page .auth-form__row {
        gap: 16px !important;
    }
    body.is-public-page .auth-form__field {
        gap: 6px;
    }
    body.is-public-page .auth-form__label {
        font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', system-ui, sans-serif !important;
        font-size: 13px !important;
        text-transform: none !important;
        letter-spacing: 0 !important;
        font-weight: 600 !important;
        color: #334155 !important;
    }
    body.is-public-page .auth-form__label .req {
        color: #EF4444;
        font-family: inherit;
    }
    body.is-public-page .auth-form__input {
        padding: 14px 16px !important;
        font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', system-ui, sans-serif !important;
        font-size: 16px !important; /* 16px evita zoom auto en iOS */
        background: #F8FAFC !important;
        border: 1.5px solid #E2E8F0 !important;
        border-radius: 12px !important;
        color: #0F172A !important;
        -webkit-appearance: none;
        appearance: none;
    }
    body.is-public-page .auth-form__input::placeholder {
        color: #94A3B8 !important;
    }
    body.is-public-page .auth-form__input:hover {
        border-color: #CBD5E1 !important;
    }
    body.is-public-page .auth-form__input:focus {
        background: #FFFFFF !important;
        border-color: #15ab92 !important;
        box-shadow: 0 0 0 3px rgba(21, 171, 146, 0.15) !important;
    }
    body.is-public-page .auth-form__hint {
        font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', system-ui, sans-serif !important;
        font-size: 12px !important;
        color: #64748B !important;
        padding: 0 2px;
    }
    body.is-public-page .auth-form__forgot {
        font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', system-ui, sans-serif !important;
        font-size: 13px !important;
        font-weight: 600 !important;
        color: #15ab92 !important;
        border-bottom: none !important;
        padding-bottom: 0 !important;
    }

    /* Checkbox nativo */
    body.is-public-page .auth-form__check {
        font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', system-ui, sans-serif !important;
        font-size: 14px !important;
        color: #475569 !important;
        align-items: center;
    }
    body.is-public-page .auth-form__check-box {
        width: 22px !important;
        height: 22px !important;
        border-radius: 6px !important;
        border: 1.5px solid #CBD5E1 !important;
        background: #FFFFFF !important;
    }
    body.is-public-page .auth-form__check-input:checked + .auth-form__check-box {
        background: #15ab92 !important;
        border-color: #15ab92 !important;
        color: #FFFFFF !important;
    }
    body.is-public-page .auth-form__check-text a {
        color: #15ab92 !important;
        border-bottom: none !important;
        font-weight: 600;
    }

    /* Botón primario nativo */
    body.is-public-page .auth-form__submit,
    body.is-public-page .ipsoo-btn--primary.auth-form__submit,
    body.is-public-page .verify-form__submit,
    body.is-public-page .reset-link__cta {
        width: 100% !important;
        justify-content: center !important;
        padding: 16px 20px !important;
        font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', system-ui, sans-serif !important;
        font-size: 16px !important;
        font-weight: 700 !important;
        background: #15ab92 !important;
        color: #FFFFFF !important;
        border: none !important;
        border-radius: 14px !important;
        box-shadow: 0 4px 14px rgba(21, 171, 146, 0.25) !important;
        margin-top: 8px;
        transition: transform 0.1s ease, box-shadow 0.15s ease, background 0.15s ease;
    }
    body.is-public-page .auth-form__submit:active,
    body.is-public-page .verify-form__submit:active,
    body.is-public-page .reset-link__cta:active {
        transform: scale(0.98);
        background: #0e8a76 !important;
    }

    /* Divider "o" — más sutil */
    body.is-public-page .auth-divider {
        margin: 22px 0 18px !important;
    }
    body.is-public-page .auth-divider::before,
    body.is-public-page .auth-divider::after {
        background: #E2E8F0 !important;
    }
    body.is-public-page .auth-divider span {
        background: #FFFFFF !important;
        font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', system-ui, sans-serif !important;
        font-size: 12px !important;
        color: #94A3B8 !important;
        text-transform: lowercase;
        letter-spacing: 0;
    }

    /* Botón Google estilo nativo */
    body.is-public-page .auth-google {
        padding: 14px 20px !important;
        background: #FFFFFF !important;
        border: 1.5px solid #E2E8F0 !important;
        border-radius: 14px !important;
        font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', system-ui, sans-serif !important;
        font-size: 15px !important;
        font-weight: 600 !important;
        color: #334155 !important;
        gap: 10px;
    }
    body.is-public-page .auth-google:active {
        background: #F8FAFC !important;
        transform: scale(0.98);
    }

    /* Footer auth */
    body.is-public-page .auth-footer {
        text-align: center;
        margin-top: 28px !important;
        font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', system-ui, sans-serif !important;
        font-size: 14px !important;
        color: #64748B !important;
    }
    body.is-public-page .auth-footer a {
        color: #15ab92 !important;
        font-weight: 600 !important;
        border-bottom: none !important;
        text-decoration: none !important;
    }
    body.is-public-page .auth-footnote {
        text-align: center;
        margin-top: 14px !important;
        font-size: 12px !important;
        color: #94A3B8 !important;
    }
    body.is-public-page .auth-footnote a {
        color: #64748B !important;
        border-bottom: none !important;
        text-decoration: underline !important;
    }

    /* Alerts más limpios */
    body.is-public-page .auth-alert {
        border-radius: 12px !important;
        padding: 12px 14px !important;
        font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', system-ui, sans-serif !important;
        font-size: 14px !important;
        border: none !important;
    }
    body.is-public-page .auth-alert--err {
        background: #FEF2F2 !important;
        color: #991B1B !important;
    }
    body.is-public-page .auth-alert--ok {
        background: #ECFDF5 !important;
        color: #065F46 !important;
    }
    body.is-public-page .auth-alert--info {
        background: #EFF6FF !important;
        color: #1E40AF !important;
    }
    body.is-public-page .auth-alert--warn {
        background: #FFFBEB !important;
        color: #92400E !important;
    }

    /* Emblema circular más suave */
    body.is-public-page .auth-emblem {
        width: 72px !important;
        height: 72px !important;
        border-radius: 50% !important;
        border: none !important;
        background: linear-gradient(135deg, #F0FDF4, #ECFDF5) !important;
        color: #15ab92 !important;
        margin: 0 auto 20px !important;
        display: flex;
        align-items: center;
        justify-content: center;
        box-shadow: 0 8px 24px rgba(21, 171, 146, 0.12) !important;
    }
    body.is-public-page .auth-emblem--green {
        background: linear-gradient(135deg, #ECFDF5, #D1FAE5) !important;
        color: #047857 !important;
    }

    /* Steps list (verify-email-pending, verify-email-success) */
    body.is-public-page .auth-steps {
        background: #F8FAFC;
        border-radius: 14px;
        padding: 16px 18px;
        margin-bottom: 18px;
    }
    body.is-public-page .auth-steps__title {
        font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', system-ui, sans-serif !important;
        font-size: 13px !important;
        font-weight: 700 !important;
        text-transform: none !important;
        letter-spacing: 0 !important;
        color: #0F172A !important;
        margin: 0 0 10px !important;
    }
    body.is-public-page .auth-steps ol,
    body.is-public-page .auth-steps ul {
        padding-left: 18px;
        margin: 0;
    }
    body.is-public-page .auth-steps li {
        font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', system-ui, sans-serif !important;
        font-size: 14px !important;
        color: #475569 !important;
        line-height: 1.5;
        padding: 4px 0;
    }

    /* Botón secundario "Cambiar email" */
    body.is-public-page .auth-secondary {
        width: 100%;
        padding: 14px 20px !important;
        background: #F1F5F9 !important;
        color: #334155 !important;
        border: none !important;
        border-radius: 14px !important;
        font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', system-ui, sans-serif !important;
        font-size: 15px !important;
        font-weight: 600 !important;
        margin-top: 10px;
        cursor: pointer;
        transition: background 0.15s ease;
    }
    body.is-public-page .auth-secondary:active {
        background: #E2E8F0 !important;
    }

    /* Modal estilo bottom-sheet (tipo iOS) */
    body.is-public-page .auth-modal {
        align-items: flex-end !important;
        background: rgba(15, 23, 42, 0.4) !important;
        backdrop-filter: blur(4px);
    }
    body.is-public-page .auth-modal__panel {
        width: 100% !important;
        max-width: none !important;
        border-radius: 20px 20px 0 0 !important;
        padding: 22px 22px calc(28px + env(safe-area-inset-bottom)) !important;
        box-shadow: 0 -8px 32px rgba(0, 0, 0, 0.18) !important;
        border: none !important;
        animation: pwaModalSlideUp 0.28s cubic-bezier(.16,1,.3,1);
    }
    @keyframes pwaModalSlideUp {
        from { transform: translateY(100%); }
        to { transform: translateY(0); }
    }
    body.is-public-page .auth-modal__head {
        margin-bottom: 14px !important;
    }
    body.is-public-page .auth-modal__title {
        font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', system-ui, sans-serif !important;
        font-size: 18px !important;
        font-weight: 700 !important;
        color: #0F172A !important;
        margin: 4px 0 !important;
    }
    body.is-public-page .auth-modal__close {
        width: 32px;
        height: 32px;
        border-radius: 50% !important;
        background: #F1F5F9 !important;
        font-size: 20px !important;
        color: #64748B !important;
        border: none !important;
    }
    body.is-public-page .auth-modal__actions {
        display: flex;
        gap: 10px;
        margin-top: 16px;
    }
    body.is-public-page .auth-modal__actions > * {
        flex: 1;
        margin-top: 0 !important;
    }

    /* Choice cards (register-type) — estilo lista nativa */
    body.is-public-page .auth-choice {
        display: flex !important;
        flex-direction: column !important;
        gap: 12px !important;
        grid-template-columns: 1fr !important;
    }
    body.is-public-page .auth-choice__item {
        background: #FFFFFF !important;
        border: 1.5px solid #E2E8F0 !important;
        border-radius: 16px !important;
        padding: 18px 18px !important;
        box-shadow: 0 2px 8px rgba(15, 23, 42, 0.04) !important;
        transition: transform 0.1s ease, border-color 0.15s ease, box-shadow 0.15s ease;
        text-decoration: none !important;
    }
    body.is-public-page .auth-choice__item:active {
        transform: scale(0.99);
        border-color: #15ab92 !important;
        box-shadow: 0 4px 16px rgba(21, 171, 146, 0.15) !important;
    }
    body.is-public-page .auth-choice__tag {
        font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', system-ui, sans-serif !important;
        font-size: 11px !important;
        font-weight: 700 !important;
        text-transform: uppercase;
        letter-spacing: 0.06em;
        color: #15ab92 !important;
        background: none !important;
        padding: 0 !important;
    }
    body.is-public-page .auth-choice__title {
        font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', system-ui, sans-serif !important;
        font-size: 19px !important;
        font-weight: 700 !important;
        color: #0F172A !important;
        margin: 6px 0 4px !important;
    }
    body.is-public-page .auth-choice__body {
        font-size: 14px !important;
        color: #64748B !important;
        line-height: 1.45;
        margin: 0 0 12px !important;
    }
    body.is-public-page .auth-choice__list {
        margin: 0 0 14px !important;
        padding: 0;
        list-style: none;
    }
    body.is-public-page .auth-choice__list li {
        font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', system-ui, sans-serif !important;
        font-size: 13.5px !important;
        color: #475569 !important;
        padding: 4px 0 4px 20px;
        position: relative;
        line-height: 1.4;
    }
    body.is-public-page .auth-choice__list li::before {
        content: '';
        position: absolute;
        left: 0;
        top: 11px;
        width: 12px;
        height: 12px;
        border-radius: 50%;
        background: #15ab92;
        opacity: 0.15;
    }
    body.is-public-page .auth-choice__list li::after {
        content: '✓';
        position: absolute;
        left: 1px;
        top: 4px;
        font-size: 10px;
        color: #15ab92;
        font-weight: 700;
    }
    body.is-public-page .auth-choice__cta {
        display: inline-flex;
        align-items: center;
        gap: 6px;
        font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', system-ui, sans-serif !important;
        font-size: 14px !important;
        font-weight: 700 !important;
        color: #15ab92 !important;
        background: none !important;
        padding: 0 !important;
        border: none !important;
    }
    body.is-public-page .auth-choice__cta::after {
        content: '→';
        font-size: 16px;
    }

    /* Auth meta (trust badges en register-type) */
    body.is-public-page .auth-meta {
        margin: 24px 0 16px !important;
        padding: 16px !important;
        background: #F8FAFC !important;
        border-radius: 14px;
        border-top: none !important;
    }
    body.is-public-page .auth-meta__item {
        font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', system-ui, sans-serif !important;
    }
    body.is-public-page .auth-meta__item strong {
        font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', system-ui, sans-serif !important;
        font-size: 13px !important;
        color: #0F172A !important;
    }
    body.is-public-page .auth-meta__item span {
        font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', system-ui, sans-serif !important;
        font-size: 11px !important;
        text-transform: none !important;
        letter-spacing: 0 !important;
    }

    /* reset-link estilo nativo */
    body.is-public-page .reset-link__intro {
        font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', system-ui, sans-serif !important;
        font-size: 14px !important;
        color: #64748B !important;
    }
    body.is-public-page .reset-link__details summary {
        font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', system-ui, sans-serif !important;
        font-size: 13px !important;
        text-transform: none !important;
        letter-spacing: 0 !important;
        color: #15ab92 !important;
        font-weight: 600;
    }
    body.is-public-page .reset-link__url {
        background: #F8FAFC !important;
        border: 1px solid #E2E8F0 !important;
        border-radius: 10px !important;
        font-size: 12px !important;
    }
    body.is-public-page .reset-link__expiry {
        font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', system-ui, sans-serif !important;
        font-size: 12px !important;
        text-transform: none !important;
        letter-spacing: 0 !important;
        color: #94A3B8 !important;
        border-top-color: #E2E8F0 !important;
    }
}

/* iOS específico: soporte para safe-area + status bar transparente */
@supports (padding-top: env(safe-area-inset-top)) {
    @media (display-mode: standalone) {
        body.is-public-page .auth-shell {
            padding-top: env(safe-area-inset-top);
        }
    }
}
