﻿/* =========================================================
   HALLO RESPONSIVE (solo Home)
   ========================================================= */

/* Contenedor centrado y responsive */
.hallo {
    width: 100%;
    max-width: 1200px;
    margin: 0 auto;
    padding: clamp(16px, 2.5vw, 28px);
    color: #fff;
    position: relative;
}

/* HERO: dos columnas en desktop, una en móvil */
.hallo-hero {
    display: grid;
    grid-template-columns: 1.15fr 0.85fr;
    gap: clamp(16px, 3vw, 48px);
    align-items: center;
}

@media (max-width: 992px) {
    .hallo-hero {
        grid-template-columns: 1fr;
    }
}

/* Imagen hero en ratio (sin heights fijos) */
.hallo-heroMedia {
    position: relative;
    width: 100%;
    aspect-ratio: 16 / 10;
    border-radius: 16px;
    overflow: hidden;
    background: #000;
}

    .hallo-heroMedia img {
        width: 100%;
        height: 100%;
        object-fit: cover;
        display: block;
    }

/* Overlay degradado negro */
.hallo-heroOverlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(0deg, rgba(0,0,0,.90) 10%, rgba(0,0,0,0) 60%);
    pointer-events: none;
}

/* Texto hero */
.hallo-title {
    font-size: clamp(28px, 4vw, 54px);
    font-weight: 900;
    line-height: 1.02;
    margin: 0 0 12px 0;
    text-transform: uppercase;
}

.hallo-subtitle {
    font-size: clamp(14px, 1.6vw, 18px);
    line-height: 1.35;
    margin: 0 0 18px 0;
    max-width: 56ch;
    opacity: .95;
}

.hallo-cta {
    background: #ffc700;
    color: #000;
    border: 0;
    border-radius: 12px;
    padding: 14px 18px;
    font-weight: 900;
    width: min(520px, 100%);
    cursor: pointer;
    box-shadow: 0 10px 26px rgba(0,0,0,.25);
    margin-top: 8px;
}

/* Imagen producto */
.hallo-product {
    margin-top: clamp(22px, 4vw, 52px);
    display: flex;
    justify-content: center;
}

    .hallo-product img {
        width: min(520px, 92vw);
        height: auto;
        display: block;
    }

/* “Cómo funciona” */
.hallo-how {
    margin-top: clamp(18px, 3.5vw, 46px);
    text-align: center;
}

.hallo-howTitle {
    margin: 0;
    font-size: clamp(20px, 2.4vw, 30px);
    font-weight: 900;
}

.hallo-howSubtitle {
    margin: 10px 0 0 0;
    opacity: .9;
}

/* Pasos: grid 2 columnas -> 1 columna */
.hallo-steps {
    margin-top: clamp(18px, 3.5vw, 46px);
}

.hallo-stepsList {
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    grid-template-columns: repeat(2, minmax(0,1fr));
    gap: 16px;
}

@media (max-width: 768px) {
    .hallo-stepsList {
        grid-template-columns: 1fr;
    }
}

/* Tarjetas de paso */
.hallo-stepCard {
    background: #414141;
    border-radius: 12px;
    padding: 20px;
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 14px;
    align-items: start;
}
/* Número de paso (estilo grande como el original) */
.hallo-stepNum {
    display: inline-flex;
    align-items: flex-start;
    gap: 10px;
    font-family: var(--large-title-3-strong-font-family);
    font-weight: var(--large-title-3-strong-font-weight);
    font-size: var(--large-title-3-strong-font-size); /* ✅ CLAVE */
    line-height: var(--large-title-3-strong-line-height);
    letter-spacing: var(--large-title-3-strong-letter-spacing);
    color: var(--resaltat);
    white-space: nowrap;
}


.hallo-stepTitle {
    margin: 0;
    font-size: 18px;
    font-weight: 800;
}

.hallo-stepText {
    margin: 8px 0 0 0;
    opacity: .92;
    line-height: 1.35;
}

.hallo-heroCopy {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
}

.hallo-heroSubtitle {
    max-width: 289px; /* ✅ mismo ancho visual */
    margin: 0 0 18px 0; /* espacio inferior */
    font-family: var(--h2-font-family);
    font-weight: var(--h2-font-weight);
    font-size: var(--h2-font-size);
    line-height: var(--h2-line-height);
    letter-spacing: var(--h2-letter-spacing);
    color: var(--texto-secundario);
    text-align: center;
    display: flex; /* ✅ como antes */
    align-items: center;
    justify-content: center;
}

/* Contenedor del botón inferior */
.hallo-bottomCta {
    margin-top: clamp(18px, 3vw, 34px);
    display: flex;
    justify-content: center;
}

/* Botón “Participar” (outline) similar a .BOTO-participa */
/* Contenedor del CTA inferior: centrado */
.hallo-bottomCta {
    margin-top: clamp(24px, 4vw, 40px);
    display: flex;
    justify-content: center; /* ✅ centrado horizontal */
}

/* Botón PARTICIPAR (mismo tamaño que "Participa ahora") */
.hallo-ctaOutline {
    display: flex;
    align-items: center;
    justify-content: center;
    width: min(520px, 92%); /* ✅ MISMO ancho que el CTA principal */
    height: 48px; /* ✅ MISMA altura */
    padding: 10px 24px;
    border-radius: 10px;
    background: transparent;
    border: 1px solid #ffc700;
    box-shadow: 0px 0px 0px 1px #6c7278, 0px 1px 2px #6c7278;
    color: #fff;
    font-size: 16px;
    font-weight: 900;
    letter-spacing: 0.3px;
    cursor: pointer;
    transition: transform .12s ease, box-shadow .12s ease, opacity .12s ease;
}

    /* Hover / active (opcional pero recomendado) */
    .hallo-ctaOutline:hover {
        transform: translateY(-1px);
        box-shadow: 0px 0px 0px 1px #6c7278, 0px 10px 22px rgba(0,0,0,.35);
    }

    .hallo-ctaOutline:active {
        transform: translateY(0);
        box-shadow: 0px 0px 0px 1px #6c7278, 0px 1px 2px #6c7278;
    }



``