/* ════════════════════════════════════════════════════════
   SWISS VERTICAL 2703 — lista de servicios en filas amplias
   Móvil: carrusel horizontal con snap (mismo patrón que proceso-servicios)
   Tablet/Desktop: layout vertical en filas
   ════════════════════════════════════════════════════════ */

.swiss-vertical2703 {
    background: var(--bg-surface-soft);
}

/* ─── Cabecera de sección ─────────────────────────────── */
.cabecera-swiss-vertical2703 {
    padding: 0 0 var(--space-7) 0;
}

/* ════════════════════════════════════════════════════════
   MÓVIL — carrusel horizontal con snap
   ════════════════════════════════════════════════════════ */

.swiss-vertical2703__carrusel {
    position: relative;
}

.swiss-vertical2703__lista {
    list-style: none;
    margin: 0;
    padding: 0;

    display: flex;
    gap: var(--space-4);

    overflow-x: auto;
    overflow-y: hidden;
    scroll-snap-type: x mandatory;
    scroll-behavior: smooth;

    padding-block: var(--space-4);

    scrollbar-width: none;
    -ms-overflow-style: none;
}

.swiss-vertical2703__lista::-webkit-scrollbar {
    display: none;
}

/* ─── Item — slide en mobile ──────────────────────────── */
.swiss-vertical2703__item {
    flex: 0 0 100%;
    width: 100%;
    scroll-snap-align: start;
    scroll-snap-stop: always;

    display: grid;
    grid-template-columns: auto 1fr;
    grid-template-rows: auto auto;
    gap: 0 var(--space-1);
    align-items: baseline;

    border: 1px solid var(--border-soft);
    border-radius: var(--radius-2);
    padding: var(--space-4);

    background-color: transparent;
    color: inherit;
    transition: background-color 250ms cubic-bezier(0.16, 1, 0.3, 1),
                color            250ms cubic-bezier(0.16, 1, 0.3, 1);
}

/* ─── Número ──────────────────────────────────────────── */
.swiss-vertical2703__numero {
    grid-column: 1;
    grid-row:    1;
    font-family: var(--ff-headings);
    font-weight: var(--fw-3);
    font-size:   var(--fs-hero);
    letter-spacing: var(--ls-0);
    font-variant-numeric: tabular-nums;
    line-height: var(--lh-1); 
    opacity: 0.08;
}

/* ─── Bloque título ───────────────────────────────────── */
.swiss-vertical2703__bloque-titulo {
    grid-column: 2;
    grid-row: 1;
    display: flex;
    align-items: flex-start;
    min-width: 0;
}

.swiss-vertical2703__titulo {
    font-family: var(--ff-headings); text-transform: uppercase;
    font-size: var(--fs-5);
    margin: 0; 
line-height: var(--lh-1);
    font-weight: var(--fw-2);
    letter-spacing: var(--ls-1);

    color: var(--text-dark);
    transition: color 250ms cubic-bezier(0.16, 1, 0.3, 1);
}

/* ─── Bloque descripción ──────────────────────────────── */
.swiss-vertical2703__bloque-descripcion {
    grid-column: 1 / -1;
    grid-row: 2;
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
    min-width: 0;
    margin-top: var(--space-1);
}

.swiss-vertical2703__descripcion {
    font-size: var(--fs-body);
    color: var(--text-soft);
    line-height: 1.5;
    margin: 0;
    transition: color 250ms cubic-bezier(0.16, 1, 0.3, 1);
}

/* ─── Sublista — oculta en mobile ────────────────────── */
.swiss-vertical2703__sublista {
    display: none;
    list-style: none;
    margin: 0;
    padding: 0;
    flex-direction: column;
    gap: 0;
}

.swiss-vertical2703__subitem {
    display: flex;
    align-items: flex-start;
    gap: 0.5rem;
    font-size: var(--fs-ui);
    color: rgb(var(--text-soft) / 0.5);
    line-height: 1.5;
    transition: color 250ms cubic-bezier(0.16, 1, 0.3, 1);
}

.swiss-vertical2703__subitem-icono {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 0.875rem;
    height: 0.875rem;
    flex-shrink: 0;
    margin-top: 0.3em;
    color: currentColor;
}

.swiss-vertical2703__subitem-icono svg {
    width: 100%;
    height: 100%;
    display: block;
}

.swiss-vertical2703__subitem-texto {
    flex: 1;
    min-width: 0;
}

/* ════════════════════════════════════════════════════════
   CONTROLES DEL CARRUSEL (solo móvil)
   ════════════════════════════════════════════════════════ */

.swiss-vertical2703__controles {
    display: flex;
    align-items: center;
}

/* Contador "01 / 06" */
.swiss-vertical2703__contador {
    font-family: var(--font-mono);
    font-size: var(--fs-ui);
    color: var(--text-soft);
    letter-spacing: 0.05em;
    font-variant-numeric: tabular-nums;
    flex-shrink: 0;
}

.swiss-vertical2703__contador-actual {
    color: var(--text-soft);
    font-weight: 600;
}

.swiss-vertical2703__contador-separador {
    margin: 0 0.25rem;
    color: var(--text-soft);
}

/* Barra de progreso */
.swiss-vertical2703__barra {
    flex: 1;
    height: 1px;
    background-color: var(--border-soft);
    position: relative;
    overflow: hidden;
}

.swiss-vertical2703__barra-progreso {
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    background-color: var(--text-soft);
    transition: width 250ms ease;
    will-change: width;
}

/* Botones prev/next */
.swiss-vertical2703__botones {
    display: flex;
    gap: 0.5rem;
    flex-shrink: 0;
}

.swiss-vertical2703__boton {
    width: 44px;
    height: 44px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: transparent;
    border: 1px solid var(--border-soft);
    border-radius: 6px;
    cursor: pointer;
    color: var(--text-soft);
    transition: border-color 200ms ease,
                background-color 200ms ease,
                color 200ms ease;
}



.swiss-vertical2703__boton:disabled {
    opacity: 0.3;
    cursor: not-allowed;
}

.swiss-vertical2703__boton svg {
    width: 20px;
    height: 20px;
}

/* ════════════════════════════════════════════════════════
   TABLET (≥768px) — vuelve a lista vertical, ocultar controles
   ════════════════════════════════════════════════════════ */

@media (min-width: 768px) {
    .swiss-vertical2703__lista {
        display: flex;
        flex-direction: column;
        gap: 0;
        overflow: visible;
        scroll-snap-type: none;
        padding-block: 0;
        border-top: 1px solid var(--border-soft);
    }

    .swiss-vertical2703__item {
        flex: initial;
        width: auto;
        scroll-snap-align: none;
        grid-template-columns: auto 1fr;
        grid-template-rows: auto auto;
        gap: var(--space-2);
        padding: var(--space-2) 0;
        align-items: baseline;

        border: none;
        border-radius: 0;
        border-bottom: 1px solid var(--border-soft);
    }

    .swiss-vertical2703__item:hover {
        background-color: var(--bg-surface-soft-hover);
        color: var(--text-soft);
    }

    .swiss-vertical2703__item:hover .swiss-vertical2703__titulo,
    .swiss-vertical2703__item:hover .swiss-vertical2703__descripcion,
    .swiss-vertical2703__item:hover .swiss-vertical2703__subitem {
        color: var(--text-soft);
    }

   

    .swiss-vertical2703__bloque-descripcion {
        grid-column: 1 / -1;
        grid-row: 2;
        margin-top: 0;
        gap: var(--space-1);
    }

    .swiss-vertical2703__controles {
        display: none;
    }
}

/* ════════════════════════════════════════════════════════
   DESKTOP (≥1200px) — tres columnas: número / título / descripción
   ════════════════════════════════════════════════════════ */

@media (min-width: 1200px) {
    .swiss-vertical2703__item {
        grid-template-columns: auto 1fr 1fr;
        grid-template-rows: auto;
        gap: var(--space-7);
        padding: var(--space-2) var(--space-4)  var(--space-2) 0;
        align-items: center;
    }

    .swiss-vertical2703__numero {
        grid-column: auto;
        grid-row: auto;
    }

    .swiss-vertical2703__bloque-titulo {
        grid-column: auto;padding-left: var(--space-4);
        grid-row: auto;
    }

    .swiss-vertical2703__bloque-descripcion {
        grid-column: auto;
        grid-row: auto;
        margin-top: 0; padding: var(--space-4) 0;
    }

    .swiss-vertical2703__sublista {
        display: flex; margin-top: var(--space-3);
    }
}

/* ─── Foco accesible ──────────────────────────────────── */
.swiss-vertical2703 :focus-visible {
    outline: 2px solid rgb(var(--text-accent));
    outline-offset: -2px;
}

/* ─── Reduce motion ───────────────────────────────────── */
@media (prefers-reduced-motion: reduce) {
    .swiss-vertical2703__item,
    .swiss-vertical2703__lista,
    .swiss-vertical2703__barra-progreso,
    .swiss-vertical2703__titulo,
    .swiss-vertical2703__descripcion,
    .swiss-vertical2703__subitem {
        transition: none;
        scroll-behavior: auto;
    }
}


.swiss-vertical2703__enlace {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-m);
    width: 100%;
    color: inherit;
    text-decoration: none;
}

.swiss-vertical2703__enlace:hover,
.swiss-vertical2703__enlace:focus-visible {
    outline: none;
}

.swiss-vertical2703__titulo-texto {
    display: inline;
}

.swiss-vertical2703__flecha {
    width: 1rem;
    height: 1rem;
    flex-shrink: 0;
    transition: transform 200ms ease;
}

.swiss-vertical2703__enlace:hover .swiss-vertical2703__flecha,
.swiss-vertical2703__enlace:focus-visible .swiss-vertical2703__flecha {
    transform: translate(3px, -3px);
}