/* ═══════════════════════════════════════════════════════════════
   SAIYAN PUBLIC SITE — public-site.css  v4.0
   Temas: :root = claro (por defecto), html[data-public-theme="dark"] = oscuro.
   JS: localStorage 'saiyan-public-site-theme' === 'dark'
   ═══════════════════════════════════════════════════════════════ */

:root {
    --l-bg:              #fafafa;
    --l-bg-subtle:       #f4f4f5;
    --l-bg-card:         rgba(0,0,0,.04);
    --l-bg-card-hover:   rgba(0,0,0,.08);
    --l-surface:         #ffffff;
    --l-border:          rgba(0,0,0,.1);
    --l-border-accent:   rgba(234,88,12,.35);
    --l-text:            #27272a;
    --l-text-muted:      #52525b;
    --l-text-dim:        #71717a;
    --l-heading:         #18181b;
    --l-accent:          #ea580c;
    --l-accent-light:    #f97316;
    --l-accent-glow:     rgba(234,88,12,.12);
    --l-green:           #16a34a;
    --l-blue:            #2563eb;
    --l-purple:          #9333ea;
    --l-red:             #dc2626;
    --l-yellow:          #ca8a04;
    --l-radius:          12px;
    --l-radius-lg:       20px;
    --l-radius-pill:     100px;
    --l-shadow:          0 2px 24px rgba(0,0,0,.08);
    --l-shadow-glow:     0 0 60px rgba(234,88,12,.1);
    --l-nav-h:           72px;
    --l-section-gap:     128px;
    --l-container-w:     1200px;
    --l-ease:            cubic-bezier(.4,0,.2,1);
    --l-t:               .3s var(--l-ease);
    --l-nav-scrolled-bg: rgba(255,255,255,.94);
    --l-mobile-nav-bg:   rgba(250,250,250,.98);
    --l-nav-link-hover:  rgba(0,0,0,.06);
    --l-link-on-muted-hover: var(--l-heading);
    --l-ghost-hover-text:    var(--l-heading);
    --l-ghost-hover-border:  rgba(0,0,0,.18);
    --l-ghost-hover-bg:      rgba(0,0,0,.04);
    --l-footer-link-hover:   var(--l-heading);
    --l-faq-q-hover-bg:      rgba(0,0,0,.04);
    --l-burger-line:         var(--l-heading);
    --l-hero-grid-a:         rgba(0,0,0,.05);
    --l-hero-noise-op:       .035;
    --l-hero-orb-op-1:       .22;
    --l-hero-orb-op-2:       .14;
    --l-hero-card-bg:        #17171f;
    --l-hero-card-fg:        #f4f4f5;
    --l-hero-card-border:    rgba(255,255,255,.1);
    --l-hero-card-row:       rgba(255,255,255,.06);
    --l-hero-card-stat-div:  rgba(255,255,255,.08);
    --l-hero-card-xp-track:  rgba(255,255,255,.1);
    --l-topnav-bar-bg:       rgba(255, 255, 255, 0.92);
    color-scheme: light;
}

html[data-public-theme="dark"] {
    color-scheme: dark;
    --l-bg:              #08080d;
    --l-bg-subtle:       #0c0c14;
    --l-bg-card:         rgba(255,255,255,.035);
    --l-bg-card-hover:   rgba(255,255,255,.065);
    --l-surface:         #12121e;
    --l-border:          rgba(255,255,255,.07);
    --l-border-accent:   rgba(249,115,22,.28);
    --l-text:            #e8e8ed;
    --l-text-muted:      #8a8a9a;
    --l-text-dim:        #55556a;
    --l-heading:         #ffffff;
    --l-accent:          #F97316;
    --l-accent-light:    #fb923c;
    --l-accent-glow:     rgba(249,115,22,.14);
    --l-green:           #22C55E;
    --l-blue:            #3B82F6;
    --l-purple:          #A855F7;
    --l-red:             #ef4444;
    --l-yellow:          #facc15;
    --l-shadow:          0 2px 32px rgba(0,0,0,.4);
    --l-shadow-glow:     0 0 80px rgba(249,115,22,.07);
    --l-nav-scrolled-bg: rgba(8,8,13,.94);
    --l-mobile-nav-bg:   rgba(8,8,13,.98);
    --l-nav-link-hover:  rgba(255,255,255,.06);
    --l-link-on-muted-hover: #fff;
    --l-ghost-hover-text:    #fff;
    --l-ghost-hover-border:  rgba(255,255,255,.2);
    --l-ghost-hover-bg:      rgba(255,255,255,.04);
    --l-footer-link-hover:   #fff;
    --l-faq-q-hover-bg:      rgba(255,255,255,.03);
    --l-burger-line:         var(--l-text);
    --l-hero-grid-a:         rgba(255,255,255,.03);
    --l-hero-noise-op:       .025;
    --l-hero-orb-op-1:       .3;
    --l-hero-orb-op-2:       .18;
    --l-hero-card-bg:        #12121e;
    --l-hero-card-fg:        #ffffff;
    --l-hero-card-border:    var(--l-border);
    --l-hero-card-row:       rgba(255,255,255,.04);
    --l-hero-card-stat-div:  rgba(255,255,255,.04);
    --l-hero-card-xp-track:  rgba(255,255,255,.06);
    --l-topnav-bar-bg:       rgba(8, 8, 13, 0.72);
}

/* Logos: logodark (letras oscuras) → fondo claro | logowhite (letras claras) → fondo oscuro.
   Las imágenes comparten celda grid; solo una tiene display distinto de none (ver bloque al final de reglas .l-topnav-logo / .l-footer-logo). */
.l-brand-mark {
    display: inline-grid;
    align-items: center;
    justify-items: start;
    vertical-align: middle;
}
.l-brand-mark > img {
    grid-area: 1 / 1;
    max-width: 100%;
}

/* Tema: solo icono (luna/sol), sin círculo ni borde */
.l-theme-toggle {
    display: inline-flex; align-items: center; justify-content: center;
    width: auto; height: auto; min-width: 40px; min-height: 40px;
    padding: 8px; margin: 0; border-radius: 8px;
    border: none; background: transparent;
    color: var(--l-text-muted); cursor: pointer;
    transition: color var(--l-t), background var(--l-t), transform var(--l-t);
}
.l-theme-toggle:hover {
    color: var(--l-heading); background: rgba(0, 0, 0, .06);
}
html[data-public-theme="dark"] .l-theme-toggle:hover {
    background: rgba(255, 255, 255, .08);
}
.l-theme-toggle:focus-visible {
    outline: 2px solid var(--l-accent); outline-offset: 2px;
}
.l-theme-toggle i { font-size: 1.15rem; }
.l-mobile-nav-tools {
    display: flex; align-items: center; justify-content: space-between;
    padding-bottom: 16px; margin-bottom: 8px; border-bottom: 1px solid var(--l-border);
}
.l-mobile-nav-tools-label { font-size: .82rem; font-weight: 600; color: var(--l-text-dim); }

/* ══ CRITICAL: Override saiyan.css body ══ */
body.is-landing-page,
body:has(> main.landing) {
    display: block !important;
    max-width: none !important;
    width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    overflow-x: hidden !important;
    background: var(--l-bg) !important;
    transition: background-color .22s ease;
}
body.l-no-scroll { overflow: hidden !important; }

main.landing {
    display: block !important;
    width: 100% !important;
    max-width: none !important;
    margin: 0 !important;
    padding: 0 !important;
    background: var(--l-bg) !important;
    color: var(--l-text) !important;
    font-family: 'DM Sans', system-ui, -apple-system, sans-serif !important;
    font-size: 16px !important;
    line-height: 1.6 !important;
    -webkit-font-smoothing: antialiased;
    overflow-x: hidden;
    transition: background-color .22s ease, color .22s ease;
}
.landing a { color: inherit; text-decoration: none; }
.landing img { max-width: 100%; height: auto; }
.l-container { width: 100%; max-width: var(--l-container-w); margin: 0 auto; padding: 0 24px; }

/* ══════════════════════════════════════════════════════════════
   TOP NAV — LOGO ONLY (no text)
   ══════════════════════════════════════════════════════════════ */
.l-topnav {
    position: fixed; top: 0; left: 0; right: 0; z-index: 1000;
    height: var(--l-nav-h);
    display: flex !important; align-items: center;
    background: var(--l-topnav-bar-bg);
    backdrop-filter: blur(12px) saturate(1.2);
    -webkit-backdrop-filter: blur(12px) saturate(1.2);
    box-shadow: 0 1px 0 var(--l-border);
    transition: background var(--l-t), box-shadow var(--l-t), backdrop-filter var(--l-t);
    font-family: 'Inter', system-ui, -apple-system, 'Segoe UI', sans-serif;
    -webkit-font-smoothing: antialiased;
}
.l-topnav.is-scrolled {
    background: var(--l-nav-scrolled-bg);
    backdrop-filter: blur(24px) saturate(1.5);
    -webkit-backdrop-filter: blur(24px) saturate(1.5);
    box-shadow: 0 1px 0 var(--l-border), var(--l-shadow);
}
.l-topnav-inner {
    width: 100%; max-width: var(--l-container-w); margin: 0 auto; padding: 0 24px;
    height: 100%; display: flex; align-items: center; gap: 32px;
}
.l-topnav-brand {
    display: flex !important; align-items: center; flex-shrink: 0;
    text-decoration: none !important;
}
.l-topnav-logo {
    height: 44px !important;
    width: auto !important;
    object-fit: contain;
    border-radius: 10px;
    transition: transform var(--l-t);
}
.l-topnav-brand:hover .l-topnav-logo { transform: scale(1.05); }

/* Solo un logo visible: evita conflicto con .l-topnav-logo { display } más abajo */
html:not([data-public-theme="dark"]) .l-logo-on-light-bg { display: block !important; }
html:not([data-public-theme="dark"]) .l-logo-on-dark-bg { display: none !important; }
html[data-public-theme="dark"] .l-logo-on-light-bg { display: none !important; }
html[data-public-theme="dark"] .l-logo-on-dark-bg { display: block !important; }

.l-topnav-links { display: flex; gap: 4px; margin-left: auto; align-items: center; }
.l-topnav-link {
    color: var(--l-text-muted) !important; text-decoration: none !important;
    font-size: 0.9375rem; font-weight: 500; padding: 9px 14px;
    letter-spacing: -0.015em;
    border-radius: 10px;
    transition: color var(--l-t), background var(--l-t);
}
.l-topnav-link:hover { color: var(--l-link-on-muted-hover) !important; background: var(--l-nav-link-hover); }
.l-topnav-actions { display: flex; gap: 8px; align-items: center; }

/* Entrar: texto plano, acento naranja (estilo “Log in” premium) */
.l-topnav-login {
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    padding: 9px 14px;
    font-family: inherit;
    font-size: 0.9375rem;
    font-weight: 600;
    letter-spacing: -0.02em;
    line-height: 1.35;
    color: var(--l-accent) !important;
    text-decoration: none !important;
    border: none;
    background: transparent !important;
    border-radius: 10px;
    cursor: pointer;
    transition: color var(--l-t), background var(--l-t);
    white-space: nowrap;
}
.l-topnav-login:hover {
    color: var(--l-accent-light) !important;
    background: var(--l-accent-glow) !important;
}
.l-topnav-login:focus-visible {
    outline: 2px solid var(--l-accent);
    outline-offset: 2px;
}
.l-topnav-login--block {
    width: 100%;
    box-sizing: border-box;
    padding: 14px 16px;
    font-size: 1rem;
    margin-top: 6px;
}

/* CTA barra superior: forma de botón, no píldora */
.l-topnav-actions .l-btn--primary {
    border-radius: 8px;
    padding: 10px 18px;
    font-size: 0.9375rem;
    font-weight: 600;
    letter-spacing: -0.02em;
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.06);
}
html[data-public-theme="dark"] .l-topnav-actions .l-btn--primary {
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.35);
}
.l-topnav-actions .l-btn--primary:hover {
    transform: translateY(-1px);
}

/* Burger */
/* Tema en barra solo móvil (escritorio va dentro de .l-topnav-actions) */
.l-theme-toggle--bar-mobile {
    display: none !important;
}
.l-topnav-burger {
    display: none; flex-direction: column; gap: 5px;
    background: none; border: none; padding: 8px; cursor: pointer; margin-left: 0;
}
.l-topnav-burger span {
    display: block; width: 24px; height: 2px; background: var(--l-burger-line);
    border-radius: 2px; transition: transform var(--l-t), opacity var(--l-t);
}
.l-topnav-burger.is-active span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.l-topnav-burger.is-active span:nth-child(2) { opacity: 0; }
.l-topnav-burger.is-active span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* Mobile nav */
.l-mobile-nav {
    position: fixed; top: var(--l-nav-h); left: 0; right: 0; bottom: 0; z-index: 999;
    background: var(--l-mobile-nav-bg); backdrop-filter: blur(24px);
    -webkit-backdrop-filter: blur(24px);
    padding: 24px 24px 32px; display: flex; flex-direction: column; gap: 8px;
    transform: translateY(-12px); opacity: 0; pointer-events: none;
    transition: transform var(--l-t), opacity var(--l-t);
    font-family: 'Inter', system-ui, -apple-system, 'Segoe UI', sans-serif;
    -webkit-font-smoothing: antialiased;
}
.l-mobile-nav.is-open { transform: translateY(0); opacity: 1; pointer-events: auto; }
.l-mobile-nav-header { padding-bottom: 16px; border-bottom: 1px solid var(--l-border); margin-bottom: 8px; }
.l-mobile-nav-logo {
    height: 40px !important; width: auto !important; display: block !important; object-fit: contain;
}
.l-mobile-nav-link {
    color: var(--l-text-muted) !important; text-decoration: none !important;
    font-size: 1.1rem; font-weight: 500; padding: 14px 0;
    border-bottom: 1px solid var(--l-border); transition: color var(--l-t);
}
.l-mobile-nav-link:hover { color: var(--l-link-on-muted-hover) !important; }
.l-mobile-nav-sep { border: none; border-top: 1px solid var(--l-border); margin: 8px 0; }

/* ══════════════════════════════════════════════════════════════
   BUTTONS
   ══════════════════════════════════════════════════════════════ */
.l-btn {
    display: inline-flex !important; align-items: center !important;
    justify-content: center !important; gap: 8px;
    padding: 11px 24px; font-family: inherit !important;
    font-size: .9rem; font-weight: 600; line-height: 1.4;
    text-decoration: none !important; border: none;
    border-radius: 8px; cursor: pointer;
    transition: all var(--l-t); white-space: nowrap; min-height: 0 !important;
}
.l-btn--primary {
    background: var(--l-accent) !important; color: #fff !important;
}
.l-btn--primary:hover {
    background: var(--l-accent-light) !important; color: #fff !important;
    box-shadow: 0 0 32px rgba(249,115,22,.4); transform: translateY(-2px);
}
.l-btn--ghost {
    background: transparent !important; color: var(--l-text-muted) !important;
    border: 1px solid var(--l-border) !important;
}
.l-btn--ghost:hover {
    color: var(--l-ghost-hover-text) !important; border-color: var(--l-ghost-hover-border) !important;
    background: var(--l-ghost-hover-bg) !important;
}
.l-btn--lg { padding: 15px 36px; font-size: 1.05rem; }
.l-btn--block { width: 100%; text-align: center; }
.l-btn--pulse { animation: l-pulse 2.5s ease-in-out infinite; }
@keyframes l-pulse {
    0%, 100% { box-shadow: 0 0 0 0 rgba(249,115,22,.4); }
    50%      { box-shadow: 0 0 0 12px rgba(249,115,22,0); }
}

/* ══════════════════════════════════════════════════════════════
   HERO
   ══════════════════════════════════════════════════════════════ */
.l-hero {
    position: relative; width: 100% !important;
    min-height: 100vh; min-height: 100dvh;
    display: flex !important; align-items: flex-start;
    justify-content: stretch;
    padding: calc(var(--l-nav-h) + 12px) 0 52px; overflow: hidden;
}
.l-hero-bg { position: absolute; inset: 0; pointer-events: none; overflow: hidden; }
.l-hero-orb {
    position: absolute; border-radius: 50%;
    filter: blur(130px); opacity: var(--l-hero-orb-op-1);
    animation: l-float 16s ease-in-out infinite alternate;
}
.l-hero-orb--1 {
    width: 650px; height: 650px;
    background: radial-gradient(circle, var(--l-accent) 0%, transparent 70%);
    top: -18%; right: -10%;
}
.l-hero-orb--2 {
    width: 500px; height: 500px;
    background: radial-gradient(circle, var(--l-green) 0%, transparent 70%);
    bottom: -20%; left: -12%;
    animation-delay: -8s; opacity: var(--l-hero-orb-op-2);
}
.l-hero-noise {
    position: absolute; inset: 0;
    background: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
    opacity: var(--l-hero-noise-op); mix-blend-mode: overlay; pointer-events: none;
}
.l-hero-grid-lines {
    position: absolute; inset: 0;
    background-image:
        linear-gradient(var(--l-hero-grid-a) 1px, transparent 1px),
        linear-gradient(90deg, var(--l-hero-grid-a) 1px, transparent 1px);
    background-size: 80px 80px;
    mask-image: radial-gradient(ellipse 70% 60% at 50% 40%, black 20%, transparent 70%);
    -webkit-mask-image: radial-gradient(ellipse 70% 60% at 50% 40%, black 20%, transparent 70%);
}
@keyframes l-float {
    0%   { transform: translate(0, 0) scale(1); }
    100% { transform: translate(30px, -20px) scale(1.08); }
}

.l-hero-inner {
    position: relative; z-index: 1; width: 100%;
    max-width: var(--l-container-w); margin: 0 auto; padding: 0 24px;
    display: grid; grid-template-columns: 1fr 440px; gap: 72px; align-items: start;
    padding-top: 4px;
}

/* Hero content */
.l-hero-content { animation: l-fade-up .7s ease-out both; }
.l-badge {
    display: inline-flex; align-items: center; gap: 7px;
    padding: 7px 18px; font-size: .82rem; font-weight: 600;
    color: var(--l-accent) !important; background: var(--l-accent-glow);
    border: 1px solid var(--l-border-accent);
    border-radius: 999px; margin-bottom: 18px;
}
.l-badge--glow { box-shadow: 0 0 28px rgba(249,115,22,.12); }
.l-hero-title {
    font-size: clamp(2.4rem, 5vw, 3.8rem) !important;
    font-weight: 700 !important; line-height: 1.08 !important;
    letter-spacing: -.035em; color: var(--l-heading) !important; margin: 0 0 24px !important;
}
.l-hero-title-accent {
    background: linear-gradient(135deg, var(--l-accent) 0%, #fbbf24 50%, var(--l-accent-light) 100%);
    background-size: 200% auto;
    -webkit-background-clip: text; -webkit-text-fill-color: transparent;
    background-clip: text;
    animation: l-shimmer 3s linear infinite;
}
@keyframes l-shimmer {
    0%   { background-position: 0% center; }
    100% { background-position: 200% center; }
}
.l-hero-subtitle {
    font-size: 1.15rem; color: var(--l-text-muted) !important;
    max-width: 540px; margin: 0 0 36px; line-height: 1.8;
}
.l-hero-cta { display: flex; gap: 14px; flex-wrap: wrap; margin-bottom: 44px; }
.l-hero-proof { display: flex; align-items: center; gap: 12px; }
.l-hero-proof-avatars { display: flex; }
.l-hero-proof-dot {
    width: 34px; height: 34px; border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    font-size: .75rem; font-weight: 700; color: #fff;
    border: 2.5px solid var(--l-bg); margin-left: -8px;
}
.l-hero-proof-dot:first-child { margin-left: 0; }
.l-hero-proof-text { font-size: .88rem; color: var(--l-text-muted); margin: 0; }
.l-hero-proof-text strong { color: var(--l-heading); }

/* Hero card — workout preview */
.l-hero-visual { animation: l-fade-up .7s .25s ease-out both; }
.l-hero-card {
    background: var(--l-hero-card-bg); border: 1px solid var(--l-hero-card-border);
    border-radius: var(--l-radius-lg); padding: 0; overflow: hidden;
    box-shadow: var(--l-shadow), var(--l-shadow-glow); position: relative;
}
.l-hero-card::before {
    content: ''; position: absolute; inset: -1px;
    border-radius: inherit; padding: 1px;
    background: linear-gradient(160deg, rgba(249,115,22,.3) 0%, transparent 40%, transparent 60%, rgba(34,197,94,.2) 100%);
    -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
    mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
    -webkit-mask-composite: xor; mask-composite: exclude; pointer-events: none;
}
.l-hero-card-header {
    display: flex; align-items: center; gap: 14px;
    padding: 24px 28px; border-bottom: 1px solid var(--l-hero-card-border);
}
.l-brand-mark--sm {
    width: 44px;
    height: 44px;
}
.l-brand-mark--sm .l-hero-card-logo {
    width: 44px !important; height: 44px !important;
    border-radius: 12px; object-fit: contain;
}
.l-hero-card-name { font-weight: 700; font-size: 1.05rem; color: var(--l-hero-card-fg); }
.l-hero-card-tag { font-size: .78rem; color: var(--l-text-dim); margin-top: 2px; }
.l-hero-card-features {
    list-style: none !important; padding: 0 !important; margin: 0 !important;
}
.l-hero-card-features li {
    display: flex; align-items: center; gap: 12px;
    padding: 14px 28px; border-bottom: 1px solid var(--l-hero-card-row);
    font-size: .9rem;
}
.l-hero-card-features li:last-child { border-bottom: none; }
.l-hero-card-features i { color: var(--l-accent); font-size: .8rem; width: 20px; text-align: center; flex-shrink: 0; }
.l-hero-card-exercise { flex: 1; color: var(--l-text-muted); }
.l-hero-card-sets { font-weight: 600; color: var(--l-accent); font-size: .85rem; font-variant-numeric: tabular-nums; }
.l-hero-card-footer {
    display: grid; grid-template-columns: repeat(3, 1fr);
    border-top: 1px solid var(--l-hero-card-border);
    background: rgba(255,255,255,.03);
}
.l-hero-card-stat {
    padding: 16px 28px; text-align: center;
    border-right: 1px solid var(--l-hero-card-stat-div);
}
.l-hero-card-stat:last-child { border-right: none; }
.l-hero-card-stat-val { display: block; font-weight: 700; font-size: 1rem; color: var(--l-hero-card-fg); font-variant-numeric: tabular-nums; }
.l-hero-card-stat-label { font-size: .7rem; color: var(--l-text-dim); text-transform: uppercase; letter-spacing: .05em; }
.l-hero-card-xp { padding: 16px 28px; border-top: 1px solid var(--l-hero-card-border); }
.l-hero-card-xp-top { display: flex; justify-content: space-between; margin-bottom: 8px; }
.l-hero-card-xp-label { font-size: .75rem; font-weight: 600; color: var(--l-text-dim); text-transform: uppercase; letter-spacing: .05em; }
.l-hero-card-xp-pct { font-size: .75rem; font-weight: 700; color: var(--l-accent); }
.l-hero-card-xp-bar { height: 6px; background: var(--l-hero-card-xp-track); border-radius: 3px; overflow: hidden; }
.l-hero-card-xp-fill {
    height: 100%; width: 72%;
    background: linear-gradient(90deg, var(--l-accent), #fbbf24);
    border-radius: 3px; animation: l-bar-grow 1.5s .9s ease-out both;
}
@keyframes l-bar-grow { from { width: 0; } to { width: 72%; } }

/* ══════════════════════════════════════════════════════════════
   TRUST BAR
   ══════════════════════════════════════════════════════════════ */
.l-trust-bar {
    border-top: 1px solid var(--l-border); border-bottom: 1px solid var(--l-border);
    padding: 20px 0; background: var(--l-bg-subtle);
}
.l-trust-bar-inner {
    display: flex; justify-content: center; flex-wrap: wrap; gap: 32px;
}
.l-trust-item {
    display: flex; align-items: center; gap: 8px;
    font-size: .82rem; font-weight: 500; color: var(--l-text-dim);
    letter-spacing: .02em;
}
.l-trust-item i { color: var(--l-accent); font-size: .75rem; }

/* ══════════════════════════════════════════════════════════════
   SECTION SHARED
   ══════════════════════════════════════════════════════════════ */
.l-section-kicker {
    display: block; text-align: center;
    font-size: .78rem; font-weight: 700; text-transform: uppercase;
    letter-spacing: .1em; color: var(--l-accent) !important;
    margin-bottom: 12px;
}
.l-section-kicker--left { text-align: left; }
.l-section-title {
    font-size: clamp(1.7rem, 3.5vw, 2.5rem) !important;
    font-weight: 700 !important; letter-spacing: -.025em;
    color: var(--l-heading) !important; text-align: center;
    margin: 0 0 14px !important; line-height: 1.2;
}
.l-section-title--left { text-align: left; }
.l-section-subtitle {
    font-size: 1.08rem; color: var(--l-text-muted);
    text-align: center; max-width: 600px; margin: 0 auto 64px;
}
.l-text-accent { color: var(--l-accent) !important; }

/* ══════════════════════════════════════════════════════════════
   FEATURES — 6-card grid
   ══════════════════════════════════════════════════════════════ */
.l-features { padding: var(--l-section-gap) 0; }
.l-features-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.l-feature-card {
    background: var(--l-bg-card); border: 1px solid var(--l-border);
    border-radius: var(--l-radius-lg); padding: 36px 28px;
    transition: background var(--l-t), border-color var(--l-t), transform var(--l-t);
}
.l-feature-card:hover { background: var(--l-bg-card-hover); border-color: var(--l-border-accent); transform: translateY(-4px); }
.l-feature-icon {
    width: 50px; height: 50px; display: flex; align-items: center; justify-content: center;
    border-radius: 14px; font-size: 1.15rem; margin-bottom: 20px;
    background: var(--l-accent-glow); color: var(--l-accent);
}
.l-feature-icon--green { background: rgba(34,197,94,.12); color: var(--l-green); }
.l-feature-icon--blue  { background: rgba(59,130,246,.12); color: var(--l-blue); }
.l-feature-icon--purple{ background: rgba(168,85,247,.12); color: var(--l-purple); }
.l-feature-icon--red   { background: rgba(239,68,68,.1); color: var(--l-red); }
.l-feature-icon--yellow{ background: rgba(250,204,21,.1); color: var(--l-yellow); }
.l-feature-card h3 { font-size: 1.12rem; font-weight: 700; color: var(--l-heading); margin: 0 0 8px; }
.l-feature-card p { font-size: .9rem; color: var(--l-text-muted); margin: 0; line-height: 1.7; }

/* ══════════════════════════════════════════════════════════════
   STEPS
   ══════════════════════════════════════════════════════════════ */
.l-steps { padding: var(--l-section-gap) 0; background: var(--l-bg-subtle); }
.l-steps-grid { display: flex; align-items: flex-start; justify-content: center; gap: 0; }
.l-step { flex: 1; max-width: 320px; text-align: center; padding: 0 20px; }
.l-step-number {
    width: 58px; height: 58px; display: flex; align-items: center; justify-content: center;
    margin: 0 auto 22px; border-radius: 50%; font-size: 1.3rem; font-weight: 800;
    color: var(--l-accent); background: var(--l-accent-glow);
    border: 2px solid var(--l-border-accent);
}
.l-step-title { font-size: 1.12rem; font-weight: 700; color: var(--l-heading); margin: 0 0 8px; }
.l-step-desc { font-size: .9rem; color: var(--l-text-muted); margin: 0; line-height: 1.7; }
.l-step-connector {
    display: flex; align-items: center; padding-top: 18px; flex-shrink: 0; width: 40px;
}
.l-step-connector span {
    display: block; width: 100%; height: 2px;
    background: linear-gradient(90deg, var(--l-border-accent), var(--l-border));
}

/* ══════════════════════════════════════════════════════════════
   SHOWCASE
   ══════════════════════════════════════════════════════════════ */
.l-showcase { padding: var(--l-section-gap) 0; }
.l-showcase-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 36px; align-items: end; }
.l-showcase-item { text-align: center; }
.l-showcase-phone {
    margin: 0 auto 28px; width: 240px;
    border-radius: 32px; background: var(--l-surface);
    border: 2px solid var(--l-border); padding: 6px;
    box-shadow: var(--l-shadow); transition: transform var(--l-t), box-shadow var(--l-t);
}
.l-showcase-phone--featured { transform: scale(1.06); }
.l-showcase-item:hover .l-showcase-phone {
    transform: translateY(-8px); box-shadow: var(--l-shadow), 0 0 48px rgba(249,115,22,.1);
}
.l-showcase-item:hover .l-showcase-phone--featured { transform: translateY(-8px) scale(1.06); }
.l-showcase-screen { border-radius: 26px; background: #0a0a16; overflow: hidden; }
.l-mock-notch {
    width: 100px; height: 5px; margin: 8px auto 6px;
    border-radius: 4px; background: rgba(255,255,255,.08);
}
.l-mock-body { padding: 14px 16px 18px; }
.l-mock-title { font-size: .8rem; font-weight: 700; color: #fff; margin-bottom: 14px; text-align: left; }
.l-mock-row {
    display: flex; justify-content: space-between; align-items: center;
    padding: 9px 0; border-bottom: 1px solid rgba(255,255,255,.05);
}
.l-mock-machine { font-size: .72rem; color: var(--l-text-muted); }
.l-mock-val { font-size: .72rem; font-weight: 600; color: var(--l-accent); font-variant-numeric: tabular-nums; }
.l-mock-xp { margin-top: 14px; height: 4px; background: rgba(255,255,255,.06); border-radius: 2px; overflow: hidden; }
.l-mock-xp-fill { height: 100%; background: linear-gradient(90deg, var(--l-accent), var(--l-green)); border-radius: 2px; }
.l-mock-level { font-size: .65rem; color: var(--l-text-dim); margin-top: 6px; text-align: right; }
.l-mock-chart { display: flex; align-items: flex-end; gap: 6px; height: 90px; padding: 8px 0; }
.l-mock-bar { flex: 1; background: rgba(249,115,22,.25); border-radius: 3px 3px 0 0; min-height: 8px; transition: height .6s var(--l-ease); }
.l-mock-bar--accent { background: var(--l-accent); }
.l-mock-stat-row { display: flex; justify-content: space-between; font-size: .7rem; color: var(--l-text-muted); padding: 7px 0; border-bottom: 1px solid rgba(255,255,255,.04); }
.l-mock-stat-val { font-weight: 700; color: var(--l-green); }
.l-mock-rank { display: flex; align-items: center; gap: 8px; padding: 7px 8px; border-radius: 8px; margin-bottom: 4px; font-size: .72rem; }
.l-mock-rank--you { background: var(--l-accent-glow); border: 1px solid var(--l-border-accent); }
.l-mock-rank-pos { width: 22px; text-align: center; font-size: .78rem; }
.l-mock-rank-name { flex: 1; color: var(--l-text-muted); font-weight: 500; }
.l-mock-rank--you .l-mock-rank-name { color: #fff; font-weight: 700; }
.l-mock-rank-xp { font-weight: 600; color: var(--l-accent); font-size: .65rem; }
.l-showcase-label { font-size: 1.08rem; font-weight: 700; color: var(--l-heading); margin: 0 0 6px; }
.l-showcase-desc { font-size: .88rem; color: var(--l-text-muted); margin: 0 auto; max-width: 280px; line-height: 1.65; }

/* ══════════════════════════════════════════════════════════════
   GAMIFICATION
   ══════════════════════════════════════════════════════════════ */
.l-gamification { padding: var(--l-section-gap) 0; background: var(--l-bg-subtle); position: relative; overflow: hidden; }
.l-gamification::before {
    content: ''; position: absolute; top: -200px; right: -200px;
    width: 500px; height: 500px; border-radius: 50%;
    background: radial-gradient(circle, rgba(249,115,22,.06) 0%, transparent 70%); pointer-events: none;
}
.l-gamification-layout { display: grid; grid-template-columns: 1fr 400px; gap: 72px; align-items: center; }
.l-gamification-intro { font-size: 1.08rem; color: var(--l-text-muted); margin: 0 0 40px; line-height: 1.8; max-width: 520px; }
.l-gamification-items { display: flex; flex-direction: column; gap: 28px; }
.l-gamification-item { display: flex; gap: 18px; align-items: flex-start; }
.l-gamification-item-icon {
    width: 48px; height: 48px; flex-shrink: 0;
    display: flex; align-items: center; justify-content: center;
    border-radius: 14px; font-size: 1.05rem;
    background: var(--l-accent-glow); color: var(--l-accent);
    border: 1px solid rgba(249,115,22,.15);
}
.l-gamification-item-icon--saga { background: rgba(239,68,68,.1); color: var(--l-red); border-color: rgba(239,68,68,.15); }
.l-gamification-item-icon--zeni { background: rgba(250,204,21,.1); border-color: rgba(250,204,21,.15); }
.l-gamification-item-icon--relic { background: rgba(168,85,247,.1); color: var(--l-purple); border-color: rgba(168,85,247,.15); }
.l-zeni-coin { width: 24px; height: 24px; object-fit: contain; display: block; }
.l-zeni-coin--card { width: 22px; height: 22px; }
.l-gamification-item h3 { font-size: 1.02rem; font-weight: 700; color: var(--l-heading); margin: 0 0 6px; }
.l-gamification-item p { font-size: .88rem; color: var(--l-text-muted); margin: 0; line-height: 1.65; }

.l-gamification-visual { display: flex; flex-direction: column; gap: 16px; }
.l-gam-card {
    background: var(--l-bg-card); border: 1px solid var(--l-border);
    border-radius: var(--l-radius); padding: 22px;
    transition: border-color var(--l-t), transform var(--l-t);
}
.l-gam-card:hover { border-color: var(--l-border-accent); transform: translateX(-4px); }
.l-gam-card-icon { font-size: 1.15rem; margin-bottom: 10px; display: flex; align-items: center; }
.l-gam-card--level .l-gam-card-icon { color: var(--l-accent); }
.l-gam-card--saga .l-gam-card-icon  { color: var(--l-red); }
.l-gam-card--zeni .l-gam-card-icon  { color: var(--l-yellow); }
.l-gam-card-label { font-size: .72rem; font-weight: 600; text-transform: uppercase; letter-spacing: .06em; color: var(--l-text-dim); margin-bottom: 4px; }
.l-gam-card-title { font-size: 1.12rem; font-weight: 700; color: var(--l-heading); }
.l-gam-card-meta { font-size: .82rem; color: var(--l-text-muted); margin-top: 6px; }
.l-gam-card-bar { height: 6px; background: var(--l-bg-card-hover); border-radius: 3px; overflow: hidden; margin-top: 14px; }
.l-gam-card-bar-fill { height: 100%; background: linear-gradient(90deg, var(--l-accent), #fbbf24); border-radius: 3px; }

/* ══════════════════════════════════════════════════════════════
   TESTIMONIALS
   ══════════════════════════════════════════════════════════════ */
.l-testimonials { padding: var(--l-section-gap) 0; }
.l-testimonials-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.l-testimonial {
    background: var(--l-bg-card); border: 1px solid var(--l-border);
    border-radius: var(--l-radius-lg); padding: 36px 28px; margin: 0;
    transition: border-color var(--l-t), transform var(--l-t);
    display: flex; flex-direction: column;
}
.l-testimonial:hover { border-color: var(--l-border-accent); transform: translateY(-4px); }
.l-testimonial-stars { color: var(--l-yellow); font-size: .95rem; margin-bottom: 18px; letter-spacing: 2px; }
.l-star-empty { color: var(--l-text-dim); }
.l-testimonial-text { font-size: .95rem; color: var(--l-text); line-height: 1.8; margin: 0 0 auto; padding-bottom: 24px; }
.l-testimonial-author { display: flex; align-items: center; gap: 12px; padding-top: 20px; border-top: 1px solid var(--l-border); }
.l-testimonial-avatar {
    width: 40px; height: 40px; border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    font-size: .82rem; font-weight: 700; color: #fff; flex-shrink: 0;
}
.l-testimonial-name { font-style: normal; font-weight: 600; font-size: .92rem; color: var(--l-heading); }
.l-testimonial-level { display: block; font-size: .78rem; color: var(--l-text-dim); margin-top: 2px; }

/* ══════════════════════════════════════════════════════════════
   FAQ
   ══════════════════════════════════════════════════════════════ */
.l-faq { padding: var(--l-section-gap) 0; background: var(--l-bg-subtle); }
.l-faq-grid { max-width: 720px; margin: 0 auto; display: flex; flex-direction: column; gap: 12px; }
.l-faq-item {
    background: var(--l-bg-card); border: 1px solid var(--l-border);
    border-radius: var(--l-radius); overflow: hidden;
    transition: border-color var(--l-t);
}
.l-faq-item[open] { border-color: var(--l-border-accent); }
.l-faq-q {
    display: flex; justify-content: space-between; align-items: center;
    padding: 20px 24px; cursor: pointer; font-weight: 600; font-size: .98rem;
    color: var(--l-heading); list-style: none; gap: 16px;
    transition: background var(--l-t);
}
.l-faq-q::-webkit-details-marker { display: none; }
.l-faq-q:hover { background: var(--l-faq-q-hover-bg); }
.l-faq-q i { color: var(--l-text-dim); font-size: .7rem; transition: transform var(--l-t); flex-shrink: 0; }
.l-faq-item[open] .l-faq-q i { transform: rotate(180deg); }
.l-faq-a { padding: 0 24px 20px; font-size: .92rem; color: var(--l-text-muted); line-height: 1.7; margin: 0; }

/* ══════════════════════════════════════════════════════════════
   CTA FINAL
   ══════════════════════════════════════════════════════════════ */
.l-cta-final { padding: var(--l-section-gap) 0; position: relative; }
.l-cta-final::before {
    content: ''; position: absolute; bottom: 0; left: 50%; transform: translateX(-50%);
    width: 700px; height: 450px; border-radius: 50%;
    background: radial-gradient(ellipse, var(--l-accent-glow) 0%, transparent 70%);
    pointer-events: none; filter: blur(40px);
}
.l-cta-final-inner { position: relative; z-index: 1; text-align: center; max-width: 560px; margin: 0 auto; }
.l-cta-final-logo {
    width: 80px !important; height: 80px !important;
    border-radius: 20px; margin: 0 auto 28px; display: block !important;
    object-fit: contain; box-shadow: 0 0 56px rgba(249,115,22,.2);
}
.l-cta-final-title {
    font-size: clamp(1.6rem, 3vw, 2.2rem) !important;
    font-weight: 700 !important; color: var(--l-heading) !important;
    margin: 0 0 14px !important; letter-spacing: -.02em;
}
.l-cta-final-desc { font-size: 1.08rem; color: var(--l-text-muted); margin: 0 0 32px; }
.l-cta-final-note { font-size: .82rem; color: var(--l-text-dim); margin-top: 22px; }

/* ══════════════════════════════════════════════════════════════
   FOOTER — LOGO ONLY (no text)
   ══════════════════════════════════════════════════════════════ */
.l-footer { padding: 36px 0; border-top: 1px solid var(--l-border); }
.l-footer-inner { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 16px; }
.l-footer-brand { display: flex !important; align-items: center; text-decoration: none !important; }
.l-footer-logo {
    height: 36px !important; width: auto !important;
    object-fit: contain; border-radius: 8px;
    transition: transform var(--l-t);
}
.l-footer-brand:hover .l-footer-logo { transform: scale(1.05); }
.l-footer-links { display: flex; flex-wrap: wrap; gap: 16px 24px; align-items: center; }
.l-footer-links a { color: var(--l-text-muted) !important; text-decoration: none !important; font-size: .88rem; transition: color var(--l-t); }
.l-footer-links a:hover { color: var(--l-footer-link-hover) !important; }
.l-footer-cookie-settings {
    font: inherit;
    font-size: .88rem;
    color: var(--l-text-muted);
    background: none;
    border: none;
    padding: 0;
    cursor: pointer;
    text-decoration: underline;
    text-underline-offset: 2px;
    transition: color var(--l-t);
}
.l-footer-cookie-settings:hover { color: var(--l-footer-link-hover); }
.l-footer-login {
    color: var(--l-accent) !important;
    font-weight: 600;
}
.l-footer-login:hover {
    color: var(--l-accent-light) !important;
}
.l-footer-copy { font-size: .82rem; color: var(--l-text-dim); margin: 0; }

.l-footer--pro {
    padding: 48px 0 42px;
}
.l-footer-pro-inner {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 1.15rem;
    max-width: 560px;
    margin: 0 auto;
}
.l-footer-social {
    display: flex;
    flex-wrap: wrap;
    gap: 0.55rem;
    justify-content: center;
}
.l-footer-social-link {
    width: 42px;
    height: 42px;
    border-radius: 50%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 1px solid var(--l-border);
    color: var(--l-text-muted);
    text-decoration: none !important;
    font-size: 1rem;
    transition: color 0.2s, border-color 0.2s, background 0.2s, transform 0.15s;
}
.l-footer-social-link:hover {
    color: var(--l-accent);
    border-color: rgba(232, 93, 4, 0.4);
    background: rgba(232, 93, 4, 0.08);
    transform: translateY(-1px);
}
.l-footer-links--pro {
    justify-content: center;
    gap: 10px 16px;
}
.l-footer-status-pill {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.02em;
    color: var(--l-text-muted);
    padding: 0.38rem 0.95rem;
    border-radius: 999px;
    border: 1px solid rgba(34, 197, 94, 0.35);
    background: rgba(34, 197, 94, 0.09);
}
.l-footer-status-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: #22c55e;
    box-shadow: 0 0 0 3px rgba(34, 197, 94, 0.22);
}
.l-footer-copy--pro {
    max-width: 420px;
    line-height: 1.55;
    margin-top: 0.25rem;
}

.l-brand-mark--footer {
    height: 36px;
    min-width: 72px;
}

/* Pie global (views/footer.php): en layout público no hay saiyan.css — estilos propios */
body.is-landing-page .app-footer,
body:has(> main.landing) .app-footer {
    box-sizing: border-box;
    width: 100%;
    margin: 0;
    padding: 18px 24px 24px;
    border-top: 1px solid var(--l-border);
    background: var(--l-bg-subtle);
    font-family: 'DM Sans', system-ui, -apple-system, sans-serif;
}
body.is-landing-page .app-footer-inner,
body:has(> main.landing) .app-footer-inner {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    gap: 6px 14px;
    max-width: var(--l-container-w);
    margin: 0 auto;
    font-size: 0.8125rem;
    line-height: 1.5;
    color: var(--l-text-muted);
}
body.is-landing-page .app-footer-copy,
body:has(> main.landing) .app-footer-copy {
    color: var(--l-text-muted);
}
body.is-landing-page .app-footer-sep,
body:has(> main.landing) .app-footer-sep {
    color: var(--l-text-dim);
    user-select: none;
}
body.is-landing-page .app-footer-brand-link,
body:has(> main.landing) .app-footer-brand-link {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    color: var(--l-text-muted);
    text-decoration: none;
}
body.is-landing-page .app-footer-brand-link:hover,
body:has(> main.landing) .app-footer-brand-link:hover {
    color: var(--l-heading);
}
body.is-landing-page .app-footer-by,
body:has(> main.landing) .app-footer-by {
    font-size: 0.8125rem;
    color: var(--l-text-dim);
}
body.is-landing-page .app-footer-logo-icheks,
body:has(> main.landing) .app-footer-logo-icheks {
    height: 20px;
    width: auto;
    max-width: 120px;
    object-fit: contain;
    object-position: left center;
    display: block;
    flex-shrink: 0;
}

/* ══════════════════════════════════════════════════════════════
   ANIMATIONS
   ══════════════════════════════════════════════════════════════ */
@keyframes l-fade-up { from { opacity: 0; transform: translateY(28px); } to { opacity: 1; transform: translateY(0); } }
[data-anim] { opacity: 0; transition: opacity .6s ease-out, transform .6s ease-out; }
[data-anim="up"]   { transform: translateY(32px); }
[data-anim="left"] { transform: translateX(-28px); }
[data-anim].is-visible { opacity: 1; transform: translate(0); }
.l-features-grid [data-anim]:nth-child(2) { transition-delay: .08s; }
.l-features-grid [data-anim]:nth-child(3) { transition-delay: .16s; }
.l-features-grid [data-anim]:nth-child(4) { transition-delay: .08s; }
.l-features-grid [data-anim]:nth-child(5) { transition-delay: .16s; }
.l-features-grid [data-anim]:nth-child(6) { transition-delay: .24s; }
.l-showcase-grid [data-anim]:nth-child(2) { transition-delay: .12s; }
.l-showcase-grid [data-anim]:nth-child(3) { transition-delay: .24s; }
.l-testimonials-grid [data-anim]:nth-child(2) { transition-delay: .1s; }
.l-testimonials-grid [data-anim]:nth-child(3) { transition-delay: .2s; }
.l-gamification-items [data-anim]:nth-child(2) { transition-delay: .1s; }
.l-gamification-items [data-anim]:nth-child(3) { transition-delay: .2s; }
.l-gamification-items [data-anim]:nth-child(4) { transition-delay: .3s; }
.l-faq-grid [data-anim]:nth-child(2) { transition-delay: .08s; }
.l-faq-grid [data-anim]:nth-child(3) { transition-delay: .16s; }
.l-faq-grid [data-anim]:nth-child(4) { transition-delay: .24s; }

/* ══════════════════════════════════════════════════════════════
   RESPONSIVE
   ══════════════════════════════════════════════════════════════ */
@media (max-width: 1024px) {
    :root { --l-section-gap: 88px; }
    .l-hero-inner { grid-template-columns: 1fr; gap: 48px; }
    .l-hero-visual { max-width: 420px; margin: 0 auto; }
    .l-gamification-layout { grid-template-columns: 1fr; gap: 48px; }
    .l-gamification-visual { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
    .l-features-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 768px) {
    :root { --l-section-gap: 72px; --l-nav-h: 60px; }
    .l-topnav-links, .l-topnav-actions { display: none !important; }
    .l-theme-toggle--bar-mobile {
        display: inline-flex !important;
        margin-left: auto;
    }
    .l-topnav-burger { display: flex !important; margin-left: 8px; }
    .l-features-grid, .l-testimonials-grid { grid-template-columns: 1fr; gap: 14px; }
    .l-showcase-grid { grid-template-columns: 1fr; gap: 40px; }
    .l-showcase-phone { width: 220px; }
    .l-showcase-phone--featured { transform: none; }
    .l-showcase-item:hover .l-showcase-phone--featured { transform: translateY(-8px); }
    .l-steps-grid { flex-direction: column; align-items: center; gap: 0; }
    .l-step-connector { width: 2px; height: 32px; }
    .l-step-connector span { width: 2px; height: 100%; display: block; }
    .l-gamification-visual { grid-template-columns: 1fr; }
    .l-section-title { font-size: clamp(1.4rem, 5vw, 2rem) !important; }
    .l-hero-title { font-size: clamp(1.9rem, 7vw, 2.8rem) !important; }
    .l-section-subtitle { font-size: .95rem; margin-bottom: 40px; }
    .l-footer-inner { flex-direction: column; text-align: center; gap: 12px; }
    .l-trust-bar-inner { gap: 20px; justify-content: center; }
    .l-trust-item { font-size: .75rem; }
}
@media (max-width: 480px) {
    .l-container { padding: 0 16px; }
    .l-hero { padding-top: calc(var(--l-nav-h) + 10px); padding-bottom: 40px; }
    .l-hero-cta { flex-direction: column; }
    .l-hero-cta .l-btn { width: 100%; }
    .l-feature-card, .l-testimonial { padding: 24px 20px; }
    .l-hero-card-footer { grid-template-columns: 1fr; }
    .l-hero-card-stat { border-right: none; border-bottom: 1px solid var(--l-hero-card-stat-div); padding: 10px 28px; }
    .l-hero-card-stat:last-child { border-bottom: none; }
}

/* Print */
@media print {
    .l-topnav, .l-mobile-nav, .l-hero-bg, .l-cta-final::before, .l-trust-bar { display: none !important; }
    .landing, body.is-landing-page { background: #fff !important; color: #111 !important; }
    .l-hero { min-height: auto; }
}
