@import url('https://fonts.googleapis.com/css2?family=Instrument+Sans:wght@400;500;600;700;800&display=swap');

:root {
    --bsx-black: #020304;
    --bsx-white: #ffffff;
    --bsx-blue: #095cb6;
    --bsx-muted: rgba(255,255,255,.64);
    --bsx-soft: rgba(255,255,255,.10);
}

html {
    scroll-behavior: smooth;
}

body.bsx-body {
    margin: 0;
    background: var(--bsx-black);
    color: var(--bsx-white);
    font-family: "Instrument Sans", Arial, Helvetica, sans-serif;
    overflow-x: hidden;
}

body.bsx-body #page,
body.bsx-body .site,
body.bsx-body .site-content,
body.bsx-body .content-area,
body.bsx-body .entry-content,
body.bsx-body .ast-container {
    max-width: none !important;
    width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    background: var(--bsx-black) !important;
}

.bsx {
    width: 100%;
    min-height: 100vh;
    overflow: hidden;
    background: var(--bsx-black);
    color: var(--bsx-white);
}

.bsx * {
    box-sizing: border-box;
}

.bsx a {
    color: inherit;
    text-decoration: none;
}

/* ================================
   HEADER / MENU
================================ */

.bsx-header {
    position: fixed;
    z-index: 99;
    top: 0;
    left: 0;
    width: 100%;
    height: 76px;
    padding: 22px 32px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    color: #fff;
    background: transparent;
    pointer-events: none;
}

.bsx-brand,
.bsx-nav,
.bsx-menu-button {
    pointer-events: auto;
}

.bsx-brand {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 15px;
    line-height: 1;
    letter-spacing: -0.04em;
    text-transform: lowercase;
    color: rgba(255,255,255,.9);
}

.bsx-mark,
.bsx-small-mark {
    width: 28px;
    height: 28px;
    border: 1px solid rgba(255,255,255,.72);
    border-radius: 50%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 9px;
    font-weight: 800;
    letter-spacing: -0.04em;
}

.bsx-nav {
    margin-left: auto;
    display: flex;
    align-items: center;
    gap: 26px;
    padding: 0;
    border: none;
    border-radius: 0;
    background: transparent;
    backdrop-filter: none;
}

.bsx-nav a {
    position: relative;
    font-size: 14px;
    line-height: 1;
    font-weight: 500;
    letter-spacing: -0.03em;
    color: rgba(255,255,255,.68);
    transition: color .25s ease, transform .25s ease;
}

.bsx-nav a::after {
    content: "";
    position: absolute;
    left: 0;
    bottom: -7px;
    width: 0;
    height: 1px;
    background: rgba(255,255,255,.88);
    transition: width .25s ease;
}

.bsx-nav a:hover {
    color: #fff;
    transform: translateY(-1px);
}

.bsx-nav a:hover::after {
    width: 100%;
}

.bsx-menu-button {
    display: none;
    border: 1px solid rgba(255,255,255,.16);
    background: rgba(255,255,255,.06);
    color: #fff;
    align-items: center;
    gap: 10px;
    cursor: pointer;
    padding: 11px 16px;
    border-radius: 999px;
    font: inherit;
    backdrop-filter: blur(12px);
}

.bsx-menu-button span {
    font-size: 14px;
    letter-spacing: -0.04em;
}

.bsx-menu-button i {
    display: block;
    width: 28px;
    height: 1px;
    background: #fff;
}

/* ================================
   HERO ESPACIAL
================================ */

.bsx-hero {
    position: relative;
    min-height: 100vh;
    padding: 120px 32px 90px;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    background: #020304;
}

.bsx-space-bg {
    position: absolute;
    inset: 0;
    overflow: hidden;
    background:
        radial-gradient(circle at 50% 35%, rgba(9,92,182,.12), transparent 38%),
        linear-gradient(180deg, #020304 0%, #03060b 52%, #010101 100%);
}

.bsx-stars {
    position: absolute;
    inset: 0;
    opacity: .74;
    background-image:
        radial-gradient(circle at 8% 18%, rgba(255,255,255,.75) 0 1px, transparent 1.4px),
        radial-gradient(circle at 24% 44%, rgba(255,255,255,.44) 0 1px, transparent 1.4px),
        radial-gradient(circle at 52% 22%, rgba(255,255,255,.58) 0 1px, transparent 1.4px),
        radial-gradient(circle at 70% 62%, rgba(255,255,255,.48) 0 1px, transparent 1.4px),
        radial-gradient(circle at 88% 28%, rgba(255,255,255,.60) 0 1px, transparent 1.4px),
        radial-gradient(circle at 94% 74%, rgba(255,255,255,.38) 0 1px, transparent 1.4px);
    background-size: 420px 420px;
    animation: bsxStars 26s linear infinite;
}

/* Planeta CSS más limpio, sin franja horizontal */
.bsx-planet {
    position: absolute;
    width: clamp(360px, 40vw, 620px);
    height: clamp(360px, 40vw, 620px);
    left: 50%;
    top: 46%;
    transform: translate(-50%, -50%) scale(.96);
    border-radius: 50%;
    opacity: 0;
    background:
        radial-gradient(circle at 31% 24%, rgba(255,255,255,.78) 0%, rgba(255,255,255,.28) 13%, transparent 28%),
        radial-gradient(circle at 39% 38%, rgba(122,172,226,.44) 0%, rgba(70,117,177,.22) 22%, transparent 43%),
        radial-gradient(circle at 67% 62%, rgba(4,16,32,.36) 0%, transparent 38%),
        radial-gradient(circle at 45% 42%, #7f95a8 0%, #496b91 26%, #1e4674 49%, #0a2346 72%, #020915 100%);
    box-shadow:
        inset -90px -70px 130px rgba(0,0,0,.72),
        inset 26px 20px 80px rgba(255,255,255,.11),
        0 0 44px rgba(255,255,255,.08),
        0 0 130px rgba(9,92,182,.18);
    filter: saturate(1.05) contrast(1.08);
    animation:
        bsxPlanetReveal 2s cubic-bezier(.2,.8,.2,1) forwards .18s,
        bsxPlanetDrift 9s ease-in-out infinite alternate 2.2s;
}

.bsx-planet::before {
    content: "";
    position: absolute;
    inset: -2px;
    border-radius: 50%;
    background:
        radial-gradient(circle at 27% 20%, rgba(255,255,255,.20), transparent 24%),
        linear-gradient(115deg, rgba(255,255,255,.08), transparent 38%, rgba(0,0,0,.24) 74%);
    mix-blend-mode: screen;
    pointer-events: none;
}

.bsx-planet::after {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: 50%;
    background: radial-gradient(circle at 72% 70%, rgba(0,0,0,.54), transparent 48%);
    pointer-events: none;
}

.bsx-hero-glow {
    position: absolute;
    width: 62vw;
    height: 62vw;
    min-width: 520px;
    min-height: 520px;
    left: 50%;
    top: 47%;
    transform: translate(-50%, -50%);
    border-radius: 50%;
    background: radial-gradient(circle, rgba(9,92,182,.23), rgba(9,92,182,.09) 38%, transparent 70%);
    filter: blur(28px);
    opacity: 0;
    animation: bsxGlowIn 2s ease forwards .28s;
}

/* Sacamos la superficie lunar inferior que se veía rara */
.bsx-moon-surface {
    display: none !important;
}

.bsx-hero-content {
    position: relative;
    z-index: 4;
    width: min(1120px, 100%);
    text-align: center;
    color: #fff;
    animation: bsxContentIn .9s ease both .3s;
}

.bsx-main-title {
    margin: 0;
    display: inline;
    color: #fff;
    font-size: clamp(66px, 12vw, 172px);
    line-height: .82;
    font-weight: 800;
    letter-spacing: -0.075em;
    text-align: center;
    text-shadow:
        0 0 24px rgba(255,255,255,.08),
        0 0 86px rgba(9,92,182,.16);
}

.bsx-rotating-label {
    display: inline-block;
    vertical-align: top;
    margin: 8px 0 0 18px;
    min-width: 180px;
    color: rgba(255,255,255,.96);
    font-size: clamp(24px, 3.4vw, 58px);
    line-height: 1;
    font-weight: 800;
    letter-spacing: -0.06em;
    text-transform: lowercase;
    text-align: left;
    transition: opacity .35s ease, transform .35s ease;
}

.bsx-rotating-label.is-changing {
    opacity: 0;
    transform: translateY(10px);
}

.bsx-hero-subtitle {
    margin: 28px 0 0;
    color: rgba(255,255,255,.56);
    font-size: clamp(12px, 1.2vw, 16px);
    line-height: 1;
    font-weight: 500;
    letter-spacing: .18em;
    text-transform: uppercase;
}

/* Ocultamos labels viejos del hero */
.bsx-hero-word {
    display: none !important;
}

/* ================================
   TICKER / PROYECTOS
================================ */

.bsx-ticker {
    width: 100%;
    padding: 70px 0 130px;
    overflow: hidden;
    perspective: 1200px;
    background: #020304;
}

.bsx-ticker-track {
    display: flex;
    gap: 18px;
    width: max-content;
    transform: rotateX(12deg) rotateY(10deg);
    animation: bsxTicker 38s linear infinite;
}

.bsx-project-card {
    flex: 0 0 clamp(260px, 31vw, 420px);
    height: clamp(380px, 46vw, 610px);
    position: relative;
    overflow: hidden;
    background: #111;
    display: flex;
    justify-content: center;
    align-items: center;
}

.bsx-project-card::before {
    content: "";
    position: absolute;
    inset: 0;
    background:
        linear-gradient(135deg, rgba(255,255,255,.18), rgba(255,255,255,.02)),
        radial-gradient(circle at 30% 20%, rgba(255,255,255,.2), transparent 38%),
        linear-gradient(160deg, #2a2a2a, #050505);
    transform: scale(1.02);
    transition: .5s ease;
}

.bsx-project-card:nth-child(2n)::before {
    background:
        radial-gradient(circle at 70% 30%, rgba(9,92,182,.22), transparent 40%),
        linear-gradient(160deg, #242424, #000);
}

.bsx-project-card:nth-child(3n)::before {
    background:
        radial-gradient(circle at 40% 60%, rgba(255,255,255,.20), transparent 36%),
        linear-gradient(160deg, #303030, #050505);
}

.bsx-project-card::after {
    content: "";
    position: absolute;
    inset: 0;
    background: rgba(0,0,0,.48);
    opacity: 0;
    transition: .35s ease;
}

.bsx-project-card span {
    position: relative;
    z-index: 2;
    font-size: clamp(24px, 3vw, 38px);
    line-height: 1.1;
    text-align: center;
    font-weight: 500;
    letter-spacing: 0;
    color: #fff;
    opacity: 0;
    transform: translateY(10px);
    transition: .35s ease;
}

.bsx-project-card:hover::after {
    opacity: 1;
}

.bsx-project-card:hover::before {
    transform: scale(1.08);
}

.bsx-project-card:hover span {
    opacity: 1;
    transform: translateY(0);
}

/* ================================
   STATEMENT / NOSOTROS
================================ */

.bsx-statement {
    min-height: 92vh;
    position: relative;
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 130px 24px 155px;
    overflow: hidden;
    background: #020304;
}

.bsx-statement h2 {
    position: relative;
    z-index: 3;
    max-width: 820px;
    margin: 0;
    font-size: clamp(28px, 3.2vw, 42px);
    line-height: 1.12;
    font-weight: 400;
    letter-spacing: 0;
    text-transform: uppercase;
    text-align: center;
    color: #fff;
}

.bsx-statement h2 span {
    font-weight: 800;
}

.bsx-floating-label {
    position: absolute;
    z-index: 1;
    opacity: .45;
    font-weight: 700;
    letter-spacing: -0.03em;
    color: #fff;
    font-size: clamp(22px, 3vw, 38px);
    line-height: 1;
    white-space: nowrap;
}

.label-one {
    left: 8vw;
    top: 18%;
}

.label-two {
    left: 15vw;
    top: 27%;
}

.label-three {
    right: 8vw;
    top: 24%;
}

.bsx-floating-buttons {
    position: absolute;
    z-index: 4;
    left: 50%;
    bottom: 70px;
    transform: translateX(-50%);
    width: auto;
    height: auto;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
}

.bsx-floating-buttons a {
    position: static;
    transform: none;
    display: block;
    width: fit-content;
    padding: 10px 16px;
    border-radius: 70px;
    background: rgba(255,255,255,.13);
    border: 1px solid rgba(255,255,255,.11);
    backdrop-filter: blur(6px);
    font-size: 16px;
    line-height: 1;
    text-transform: uppercase;
    letter-spacing: -0.04em;
    white-space: nowrap;
    color: #fff;
    transition: .25s ease;
}

.bsx-floating-buttons a:hover {
    background: #fff;
    color: #000;
}

/* ================================
   SERVICIOS
================================ */

.bsx-services {
    position: relative;
    min-height: 900px;
    background: #0a0a0a;
    display: grid;
    grid-template-columns: minmax(420px, 600px) 1fr;
    gap: 40px;
    align-items: center;
    padding: 100px 25px;
    overflow: hidden;
}

.bsx-services-list {
    width: 100%;
    max-width: 600px;
    position: relative;
    z-index: 5;
    background: #0a0a0a;
}

.bsx-services-head {
    height: 64px;
    padding: 0 20px;
    display: flex;
    align-items: center;
    gap: 24px;
    border-bottom: 1px solid #222;
    background: #0a0a0a;
    position: sticky;
    top: 0;
    z-index: 2;
}

.bsx-services-head strong {
    font-size: 20px;
    font-weight: 800;
    color: #fff;
}

.bsx-services-list a {
    min-height: 64px;
    padding: 0 20px 0 60px;
    display: flex;
    align-items: center;
    font-size: 16px;
    line-height: 1.4;
    font-weight: 400;
    letter-spacing: -0.01em;
    border-bottom: 1px solid #111;
    color: rgba(255,255,255,.9);
    transition: .2s ease;
}

.bsx-services-list a:hover {
    color: rgba(255,255,255,.55);
    padding-left: 74px;
}

.bsx-floating-gallery {
    position: relative;
    top: auto;
    right: auto;
    width: 100%;
    max-width: 600px;
    height: 760px;
    justify-self: end;
}

.bsx-float-img {
    position: absolute;
    border-radius: 8px;
    background:
        linear-gradient(135deg, rgba(255,255,255,.26), rgba(255,255,255,.04)),
        linear-gradient(160deg, #343434, #0b0b0b);
    box-shadow:
        -1px -1px 2px rgba(0,0,0,.08),
        -8px -7px 20px rgba(0,0,0,.10),
        -46px -35px 104px rgba(0,0,0,.05);
    animation: bsxFloat 5s ease-in-out infinite alternate;
}

.img-one {
    width: 170px;
    height: 170px;
    left: 90px;
    top: 40px;
}

.img-two {
    width: 248px;
    height: 324px;
    right: 80px;
    top: 70px;
    animation-delay: .4s;
}

.img-three {
    width: 219px;
    height: 242px;
    left: 20px;
    top: 430px;
    animation-delay: .8s;
}

.img-four {
    width: 300px;
    height: 340px;
    left: 150px;
    bottom: 40px;
    animation-delay: 1.2s;
}

.img-five {
    width: 221px;
    height: 312px;
    right: 0;
    bottom: 120px;
    animation-delay: 1.6s;
}

/* ================================
   TRABAJOS
================================ */

.bsx-work {
    background: #fff;
    color: #0a0a0a;
    padding: 110px 25px;
}

.bsx-work h2 {
    margin: 0 0 42px;
    font-size: clamp(60px, 12vw, 160px);
    line-height: .8;
    font-weight: 800;
    letter-spacing: -0.08em;
    text-transform: lowercase;
}

.bsx-work-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 22px;
}

.bsx-work-grid article div {
    height: clamp(280px, 38vw, 460px);
    background:
        linear-gradient(135deg, rgba(0,0,0,.12), rgba(0,0,0,.04)),
        linear-gradient(160deg, #dadada, #8e8e8e);
    overflow: hidden;
}

.bsx-work-grid article p {
    margin: 12px 0 0;
    font-size: 18px;
    text-transform: uppercase;
    letter-spacing: -0.04em;
}

/* ================================
   FOOTER
================================ */

.bsx-footer {
    background: #0a0a0a;
    color: #fff;
    padding: 28px 25px;
}

.bsx-footer nav {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 18px;
    flex-wrap: wrap;
    font-size: 16px;
    letter-spacing: -0.04em;
}

.bsx-footer a,
.bsx-footer span {
    text-transform: uppercase;
    color: rgba(255,255,255,.82);
}

.bsx-footer a:hover {
    color: #fff;
}

/* ================================
   ANIMACIONES
================================ */

@keyframes bsxStars {
    from {
        background-position: 0 0;
    }

    to {
        background-position: 420px 420px;
    }
}

@keyframes bsxPlanetReveal {
    0% {
        opacity: 0;
        transform: translate(-50%, -48%) scale(.88);
        filter: brightness(.3) blur(8px);
    }

    70% {
        opacity: 1;
        filter: brightness(1.18) blur(0);
    }

    100% {
        opacity: .95;
        transform: translate(-50%, -50%) scale(1);
        filter: brightness(1) blur(0);
    }
}

@keyframes bsxPlanetDrift {
    from {
        transform: translate(-50%, -50%) scale(1);
    }

    to {
        transform: translate(-50%, -52%) scale(1.018);
    }
}

@keyframes bsxGlowIn {
    from {
        opacity: 0;
    }

    to {
        opacity: 1;
    }
}

@keyframes bsxContentIn {
    from {
        opacity: 0;
        transform: translateY(22px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes bsxTicker {
    from {
        transform: rotateX(12deg) rotateY(10deg) translateX(0);
    }

    to {
        transform: rotateX(12deg) rotateY(10deg) translateX(-50%);
    }
}

@keyframes bsxFloat {
    from {
        transform: translateY(0) rotate(-1deg);
    }

    to {
        transform: translateY(-18px) rotate(1.5deg);
    }
}

/* ================================
   RESPONSIVE
================================ */

@media (max-width: 1024px) {
    .bsx-services {
        grid-template-columns: 1fr;
        padding: 80px 25px;
    }

    .bsx-services-list {
        max-width: none;
    }

    .bsx-floating-gallery {
        justify-self: center;
        max-width: 680px;
        height: 560px;
    }

    .img-one {
        left: 4%;
        top: 30px;
    }

    .img-two {
        right: 12%;
        top: 20px;
    }

    .img-three {
        left: 8%;
        top: 310px;
    }

    .img-four {
        left: 36%;
        bottom: 20px;
    }

    .img-five {
        right: 6%;
        bottom: 90px;
    }
}

@media (max-width: 820px) {
    .bsx-header {
        height: 72px;
        padding: 16px 18px;
    }

    .bsx-brand span:last-child {
        display: none;
    }

    .bsx-nav {
        position: fixed;
        left: 18px;
        right: 18px;
        top: 78px;
        display: none;
        flex-direction: column;
        align-items: stretch;
        gap: 0;
        padding: 10px;
        border-radius: 18px;
        background: rgba(5,5,5,.82);
        border: 1px solid rgba(255,255,255,.14);
        backdrop-filter: blur(18px);
    }

    .bsx-nav.is-open {
        display: flex;
    }

    .bsx-nav a {
        padding: 14px 12px;
        font-size: 16px;
        border-bottom: 1px solid rgba(255,255,255,.08);
    }

    .bsx-nav a:last-child {
        border-bottom: 0;
    }

    .bsx-menu-button {
        display: flex;
    }

    .bsx-hero {
        min-height: 100vh;
        padding: 118px 18px 72px;
    }

    .bsx-planet {
        width: 360px;
        height: 360px;
        top: 45%;
    }

    .bsx-hero-glow {
        width: 520px;
        height: 520px;
        min-width: 520px;
        min-height: 520px;
    }

    .bsx-main-title {
        display: block;
        font-size: clamp(54px, 17vw, 86px);
        line-height: .86;
    }

    .bsx-rotating-label {
        display: block;
        margin: 12px auto 0;
        min-width: auto;
        text-align: center;
        font-size: clamp(34px, 11vw, 56px);
    }

    .bsx-hero-subtitle {
        margin-top: 20px;
        font-size: 12px;
        letter-spacing: .14em;
    }

    .bsx-ticker {
        padding: 60px 0 80px;
    }

    .bsx-ticker-track {
        gap: 14px;
        transform: rotateX(9deg) rotateY(7deg);
        animation: bsxTickerMobile 34s linear infinite;
    }

    .bsx-project-card {
        flex-basis: 245px;
        height: 360px;
    }

    .bsx-statement {
        min-height: 760px;
        padding: 115px 18px 150px;
        align-items: center;
    }

    .bsx-statement h2 {
        max-width: 100%;
        font-size: clamp(30px, 8vw, 40px);
        line-height: 1.08;
        text-align: left;
    }

    .bsx-floating-label {
        font-size: 20px;
        opacity: .35;
    }

    .label-one {
        left: 18px;
        top: 58px;
    }

    .label-two {
        left: 18px;
        top: 88px;
    }

    .label-three {
        right: 18px;
        top: 118px;
    }

    .bsx-floating-buttons {
        bottom: 42px;
        left: 18px;
        right: 18px;
        transform: none;
        align-items: flex-start;
    }

    .bsx-floating-buttons a {
        font-size: 14px;
    }

    .bsx-services {
        padding: 0;
        min-height: auto;
    }

    .bsx-services-head {
        height: 62px;
    }

    .bsx-services-list a {
        min-height: 58px;
        height: auto;
        padding: 16px 20px 16px 46px;
        line-height: 1.25;
    }

    .bsx-services-list a:hover {
        padding-left: 46px;
    }

    .bsx-floating-gallery {
        height: 420px;
        overflow: hidden;
    }

    .img-one {
        width: 82px;
        height: 82px;
        left: 18px;
        top: 40px;
    }

    .img-two {
        width: 126px;
        height: 180px;
        right: 64px;
        top: 30px;
    }

    .img-three {
        width: 96px;
        height: 104px;
        left: 22px;
        top: 245px;
    }

    .img-four {
        width: 130px;
        height: 170px;
        left: 42%;
        bottom: 18px;
    }

    .img-five {
        width: 116px;
        height: 166px;
        right: 18px;
        bottom: 65px;
    }

    .bsx-work {
        padding: 72px 18px;
    }

    .bsx-work h2 {
        font-size: clamp(56px, 18vw, 86px);
    }

    .bsx-work-grid {
        grid-template-columns: 1fr;
    }

    .bsx-footer {
        padding: 24px 18px;
    }

    .bsx-footer nav {
        flex-direction: column;
        align-items: flex-start;
        gap: 12px;
        font-size: 15px;
    }
}

@keyframes bsxTickerMobile {
    from {
        transform: rotateX(9deg) rotateY(7deg) translateX(0);
    }

    to {
        transform: rotateX(9deg) rotateY(7deg) translateX(-50%);
    }
}

/* ===== AJUSTES FINALES HERO ===== */

.bsx-hero {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 110px 32px 60px;
  overflow: hidden;
  position: relative;
}

.bsx-hero-inner,
.bsx-hero-content {
  position: relative;
  z-index: 3;
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
}

.bsx-title-row,
.bsx-lockup {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 18px;
  flex-wrap: wrap;
}

/* bit&soul */
.bsx-wordmark,
.bsx-brand,
.bsx-main-wordmark {
  margin: 0;
  font-size: clamp(62px, 7vw, 110px);
  line-height: 0.95;
  font-weight: 800;
  letter-spacing: -0.06em;
  color: #ffffff;
}

/* agency / studio */
.bsx-rotating-label {
  display: inline-block;
  margin: 0;
  font-size: clamp(62px, 7vw, 110px);
  line-height: 0.95;
  font-weight: 800;
  letter-spacing: -0.06em;
  color: #ffffff;
  min-width: 4ch;
  text-align: left;
}

/* subtítulo */
.bsx-tagline,
.bsx-subtitle {
  margin-top: 22px;
  font-size: clamp(15px, 1.2vw, 24px);
  letter-spacing: 0.20em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.72);
  text-align: center;
}

/* planeta */
.bsx-planet,
.bsx-hero-planet {
  width: min(42vw, 560px);
  aspect-ratio: 1 / 1;
  position: absolute;
  top: 55%;
  left: 50%;
  transform: translate(-50%, -50%);
  border-radius: 50%;
  box-shadow:
    0 0 60px rgba(54, 122, 214, 0.20),
    0 0 120px rgba(19, 72, 156, 0.12),
    inset -50px -60px 120px rgba(0, 0, 0, 0.45),
    inset 18px 20px 80px rgba(255, 255, 255, 0.10);
}

/* oculta el “pedacito” raro de abajo si sigue apareciendo */
.bsx-horizon,
.bsx-planet-bottom,
.bsx-bottom-glow {
  display: none !important;
}

@media (max-width: 768px) {
  .bsx-hero {
    padding: 100px 20px 50px;
  }

  .bsx-title-row,
  .bsx-lockup {
    flex-direction: column;
    gap: 8px;
  }

  .bsx-rotating-label {
    min-width: auto;
    text-align: center;
  }

  .bsx-planet,
  .bsx-hero-planet {
    width: min(78vw, 420px);
    top: 52%;
  }

  .bsx-wordmark,
  .bsx-brand,
  .bsx-main-wordmark,
  .bsx-rotating-label {
    font-size: clamp(48px, 12vw, 80px);
  }
}

/* ================================
   FIX HERO + HEADER BRAND + ESPACIADO
   Pegar al final del CSS
================================ */

/* Corrige el logo chico del header que se agrandó por error */
.bsx-header .bsx-brand {
    font-size: 15px !important;
    line-height: 1 !important;
    font-weight: 500 !important;
    letter-spacing: -0.04em !important;
    transform: none !important;
}

.bsx-header .bsx-brand span:last-child {
    display: inline !important;
    font-size: 15px !important;
    line-height: 1 !important;
    font-weight: 500 !important;
    letter-spacing: -0.04em !important;
}

.bsx-header .bsx-mark {
    width: 28px !important;
    height: 28px !important;
    font-size: 9px !important;
    line-height: 1 !important;
    flex: 0 0 28px !important;
}

/* Hero más equilibrado */
.bsx-hero {
    min-height: 112vh;
    padding-top: 120px;
    padding-bottom: 140px;
}

/* Baja un poco el planeta */
.bsx-planet {
    top: 53% !important;
    width: clamp(390px, 42vw, 640px);
    height: clamp(390px, 42vw, 640px);
}

.bsx-hero-glow {
    top: 53% !important;
}

/* Centra mejor el texto sobre el planeta */
.bsx-hero-content {
    transform: translateY(20px);
}

/* Achica el wordmark principal */
.bsx-main-title {
    font-size: clamp(64px, 8.8vw, 132px) !important;
    line-height: .86 !important;
}

/* Agency / studio al mismo peso visual */
.bsx-rotating-label {
    font-size: clamp(48px, 5.8vw, 96px) !important;
    line-height: .9 !important;
    margin-top: 10px !important;
    min-width: 230px;
}

/* Mejor alineación entre bit&soul y agency/studio */
.bsx-title-row {
    align-items: center !important;
    gap: 24px !important;
}

/* Tagline más prolijo */
.bsx-hero-subtitle {
    margin-top: 24px !important;
    font-size: clamp(12px, 1vw, 15px) !important;
    letter-spacing: .22em !important;
    opacity: .72;
}

/* Separa la sección siguiente del hero */
.bsx-ticker {
    padding-top: 120px !important;
}

/* Evita que los bloques de abajo se peguen visualmente al hero */
.bsx-hero::after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    height: 140px;
    background: linear-gradient(
        to bottom,
        rgba(2,3,4,0),
        rgba(2,3,4,.95)
    );
    z-index: 2;
    pointer-events: none;
}

/* Mobile */
@media (max-width: 820px) {
    .bsx-hero {
        min-height: 100vh;
        padding-bottom: 100px;
    }

    .bsx-planet {
        top: 50% !important;
        width: min(82vw, 430px);
        height: min(82vw, 430px);
    }

    .bsx-hero-glow {
        top: 50% !important;
    }

    .bsx-title-row {
        flex-direction: column;
        gap: 8px !important;
    }

    .bsx-main-title {
        font-size: clamp(50px, 15vw, 78px) !important;
    }

    .bsx-rotating-label {
        font-size: clamp(38px, 11vw, 58px) !important;
        min-width: 0;
        text-align: center;
        margin-top: 0 !important;
    }

    .bsx-ticker {
        padding-top: 80px !important;
    }
}

/* ================================
   TICKER / CARDS FUTURISTAS
   Pegar al final del CSS
================================ */

.bsx-ticker {
    position: relative;
    padding-top: 150px !important;
    padding-bottom: 150px !important;
    background:
        radial-gradient(circle at 50% 0%, rgba(9,92,182,.10), transparent 34%),
        linear-gradient(180deg, #020304 0%, #05070b 45%, #020304 100%);
    overflow: hidden;
}

.bsx-ticker::before {
    content: "";
    position: absolute;
    inset: 0;
    background-image:
        linear-gradient(rgba(255,255,255,.025) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,.025) 1px, transparent 1px);
    background-size: 80px 80px;
    mask-image: linear-gradient(to bottom, transparent, #000 25%, #000 75%, transparent);
    pointer-events: none;
}

.bsx-ticker-track {
    gap: 24px !important;
    transform: rotateX(10deg) rotateY(8deg) !important;
    animation: bsxTickerCards 42s linear infinite !important;
    will-change: transform;
}

.bsx-project-card {
    flex: 0 0 clamp(270px, 29vw, 390px) !important;
    height: clamp(390px, 44vw, 560px) !important;
    position: relative;
    overflow: hidden;
    border-radius: 26px;
    background:
        linear-gradient(145deg, rgba(255,255,255,.14), rgba(255,255,255,.025)),
        linear-gradient(180deg, #151922 0%, #07090d 100%);
    border: 1px solid rgba(255,255,255,.13);
    box-shadow:
        0 24px 80px rgba(0,0,0,.42),
        inset 0 1px 0 rgba(255,255,255,.12);
    transform: translateZ(0);
    transition:
        transform .45s cubic-bezier(.2,.8,.2,1),
        border-color .45s ease,
        box-shadow .45s ease,
        filter .45s ease;
}

/* textura / profundidad interna */
.bsx-project-card::before {
    content: "";
    position: absolute;
    inset: 0;
    background:
        radial-gradient(circle at 26% 18%, rgba(255,255,255,.20), transparent 22%),
        radial-gradient(circle at 76% 72%, rgba(9,92,182,.26), transparent 34%),
        linear-gradient(135deg, rgba(255,255,255,.06), transparent 34%),
        linear-gradient(180deg, rgba(255,255,255,.05), rgba(0,0,0,.20));
    opacity: .95;
    transform: scale(1.02);
    transition: transform .55s ease, opacity .45s ease;
}

/* líneas futuristas */
.bsx-project-card::after {
    content: "";
    position: absolute;
    inset: 18px;
    border-radius: 20px;
    border: 1px solid rgba(255,255,255,.10);
    background:
        linear-gradient(90deg, transparent 0 42%, rgba(255,255,255,.10) 42% 43%, transparent 43% 100%),
        linear-gradient(180deg, transparent 0 64%, rgba(255,255,255,.08) 64% 65%, transparent 65% 100%);
    opacity: .55;
    transition: opacity .4s ease, inset .4s ease;
    pointer-events: none;
}

/* nombre fijo */
.bsx-project-card span {
    position: absolute !important;
    z-index: 4;
    left: 24px;
    right: 24px;
    bottom: 24px;
    opacity: 1 !important;
    transform: none !important;
    color: #ffffff;
    font-size: clamp(24px, 2.8vw, 38px) !important;
    line-height: .95 !important;
    font-weight: 700 !important;
    letter-spacing: .08em !important;
    text-transform: uppercase;
    text-align: left !important;
    text-shadow: 0 0 28px rgba(0,0,0,.55);
}

/* etiqueta pequeña superior */
.bsx-project-card span::before {
    content: "PROJECT";
    display: block;
    margin-bottom: 12px;
    font-size: 11px;
    line-height: 1;
    font-weight: 600;
    letter-spacing: .24em;
    color: rgba(255,255,255,.52);
}

/* esquina técnica */
.bsx-project-card span::after {
    content: "↗";
    position: absolute;
    right: 0;
    bottom: 0;
    width: 34px;
    height: 34px;
    border-radius: 999px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 16px;
    letter-spacing: 0;
    color: rgba(255,255,255,.85);
    border: 1px solid rgba(255,255,255,.18);
    background: rgba(255,255,255,.06);
    backdrop-filter: blur(8px);
}

/* variaciones para que no parezcan todas iguales */
.bsx-project-card:nth-child(2n) {
    background:
        linear-gradient(145deg, rgba(255,255,255,.12), rgba(255,255,255,.02)),
        linear-gradient(180deg, #121820 0%, #05070a 100%);
}

.bsx-project-card:nth-child(2n)::before {
    background:
        radial-gradient(circle at 72% 22%, rgba(255,255,255,.16), transparent 24%),
        radial-gradient(circle at 32% 68%, rgba(9,92,182,.28), transparent 34%),
        linear-gradient(135deg, rgba(255,255,255,.05), transparent 36%);
}

.bsx-project-card:nth-child(3n) {
    background:
        linear-gradient(145deg, rgba(255,255,255,.15), rgba(255,255,255,.02)),
        linear-gradient(180deg, #181818 0%, #060606 100%);
}

.bsx-project-card:nth-child(3n)::before {
    background:
        radial-gradient(circle at 44% 28%, rgba(255,255,255,.18), transparent 26%),
        radial-gradient(circle at 68% 78%, rgba(9,92,182,.18), transparent 32%),
        linear-gradient(160deg, rgba(255,255,255,.06), transparent 40%);
}

/* hover desktop */
.bsx-project-card:hover {
    transform: translateY(-18px) scale(1.018);
    border-color: rgba(255,255,255,.28);
    box-shadow:
        0 34px 110px rgba(0,0,0,.56),
        0 0 70px rgba(9,92,182,.18),
        inset 0 1px 0 rgba(255,255,255,.18);
    filter: brightness(1.08);
}

.bsx-project-card:hover::before {
    transform: scale(1.08);
    opacity: 1;
}

.bsx-project-card:hover::after {
    inset: 14px;
    opacity: .9;
}

/* pausa suave al interactuar */
.bsx-ticker-track:hover {
    animation-play-state: paused;
}

/* click/tap */
.bsx-project-card:active {
    transform: translateY(-8px) scale(.99);
}

/* nueva animación ticker */
@keyframes bsxTickerCards {
    from {
        transform: rotateX(10deg) rotateY(8deg) translateX(0);
    }

    to {
        transform: rotateX(10deg) rotateY(8deg) translateX(-50%);
    }
}

/* Mobile: nombre fijo, cards más legibles */
@media (max-width: 820px) {
    .bsx-ticker {
        padding-top: 90px !important;
        padding-bottom: 100px !important;
    }

    .bsx-ticker-track {
        gap: 16px !important;
        transform: rotateX(6deg) rotateY(4deg) !important;
        animation: bsxTickerCardsMobile 36s linear infinite !important;
    }

    .bsx-project-card {
        flex-basis: 260px !important;
        height: 360px !important;
        border-radius: 22px;
    }

    .bsx-project-card::after {
        inset: 14px;
        border-radius: 17px;
        opacity: .7;
    }

    .bsx-project-card span {
        left: 20px;
        right: 20px;
        bottom: 20px;
        font-size: 25px !important;
        letter-spacing: .06em !important;
    }

    .bsx-project-card span::after {
        width: 30px;
        height: 30px;
    }

    .bsx-project-card:hover {
        transform: none;
    }

    .bsx-project-card:active {
        transform: scale(.98);
        filter: brightness(1.12);
    }
}

@keyframes bsxTickerCardsMobile {
    from {
        transform: rotateX(6deg) rotateY(4deg) translateX(0);
    }

    to {
        transform: rotateX(6deg) rotateY(4deg) translateX(-50%);
    }
}

/* ================================
   FIX CARDS — MOVIMIENTO + VISUALES
   Pegar al final del CSS
================================ */

/* Más aire entre hero y ticker */
.bsx-ticker {
    padding-top: 170px !important;
    padding-bottom: 160px !important;
    overflow: hidden !important;
}

/* Vuelve a mover el carrusel */
.bsx-ticker-track {
    display: flex !important;
    width: max-content !important;
    gap: 26px !important;
    animation: bsxTickerMoveClean 46s linear infinite !important;
    transform: rotateX(8deg) rotateY(6deg) !important;
    will-change: transform !important;
}

/* Sacamos la pausa: así no queda estático al apoyar el mouse */
.bsx-ticker-track:hover {
    animation-play-state: running !important;
}

/* Base de card más sofisticada, sin cruz */
.bsx-project-card {
    position: relative !important;
    flex: 0 0 clamp(280px, 28vw, 400px) !important;
    height: clamp(380px, 42vw, 540px) !important;
    border-radius: 28px !important;
    overflow: hidden !important;
    background:
        radial-gradient(circle at 50% 35%, rgba(255,255,255,.12), transparent 24%),
        linear-gradient(180deg, #171b22 0%, #07090d 100%) !important;
    border: 1px solid rgba(255,255,255,.14) !important;
    box-shadow:
        0 30px 90px rgba(0,0,0,.46),
        inset 0 1px 0 rgba(255,255,255,.12) !important;
    transition:
        transform .45s cubic-bezier(.2,.8,.2,1),
        filter .45s ease,
        border-color .45s ease,
        box-shadow .45s ease !important;
}

/* Eliminamos la cruz/mira interna */
.bsx-project-card::after {
    display: none !important;
}

/* Capa visual propia de cada card */
.bsx-project-card::before {
    content: "" !important;
    position: absolute !important;
    inset: 0 !important;
    opacity: .95 !important;
    transform: scale(1) !important;
    transition: transform .55s ease, opacity .45s ease, filter .45s ease !important;
    background:
        radial-gradient(circle at 50% 40%, rgba(255,255,255,.16), transparent 28%),
        linear-gradient(180deg, rgba(255,255,255,.06), rgba(0,0,0,.22)) !important;
}

/* BRAND FILM — lente / spotlight cinematográfico */
.bsx-project-card:nth-child(1)::before,
.bsx-project-card:nth-child(7)::before {
    background:
        radial-gradient(circle at 50% 34%, rgba(255,255,255,.22) 0 9%, transparent 10%),
        radial-gradient(circle at 50% 34%, transparent 0 18%, rgba(255,255,255,.08) 19%, transparent 20%),
        radial-gradient(circle at 50% 34%, transparent 0 31%, rgba(9,92,182,.18) 32%, transparent 34%),
        linear-gradient(135deg, transparent 0 45%, rgba(255,255,255,.08) 46%, transparent 48%),
        linear-gradient(180deg, #1a1d22 0%, #07090d 100%) !important;
}

/* SOCIAL ADS — módulos / feed */
.bsx-project-card:nth-child(2)::before,
.bsx-project-card:nth-child(8)::before {
    background:
        linear-gradient(90deg, transparent 0 14%, rgba(255,255,255,.09) 14% 15%, transparent 15% 100%),
        linear-gradient(180deg, transparent 0 24%, rgba(255,255,255,.08) 24% 25%, transparent 25% 100%),
        radial-gradient(circle at 72% 24%, rgba(9,92,182,.28), transparent 24%),
        linear-gradient(145deg, #1d232c 0%, #080b10 100%) !important;
    background-size: 100% 100%, 100% 100%, 100% 100%, 100% 100% !important;
}

/* IDENTIDAD — monograma abstracto / sistema */
.bsx-project-card:nth-child(3)::before,
.bsx-project-card:nth-child(9)::before {
    background:
        radial-gradient(circle at 50% 35%, rgba(255,255,255,.18), transparent 24%),
        conic-gradient(from 180deg at 50% 42%, rgba(255,255,255,.14), transparent 18%, rgba(9,92,182,.22), transparent 48%, rgba(255,255,255,.10), transparent 72%),
        linear-gradient(180deg, #1b1f25 0%, #07090d 100%) !important;
}

/* CONTENIDO — timeline / ondas */
.bsx-project-card:nth-child(4)::before,
.bsx-project-card:nth-child(10)::before {
    background:
        repeating-linear-gradient(
            115deg,
            rgba(255,255,255,.10) 0 1px,
            transparent 1px 18px
        ),
        radial-gradient(circle at 64% 30%, rgba(9,92,182,.25), transparent 28%),
        linear-gradient(180deg, #171b21 0%, #06080c 100%) !important;
}

/* CAMPAÑAS — órbita / estrategia */
.bsx-project-card:nth-child(5)::before {
    background:
        radial-gradient(circle at 50% 42%, rgba(255,255,255,.16), transparent 12%),
        radial-gradient(ellipse at 50% 42%, transparent 0 34%, rgba(255,255,255,.10) 35%, transparent 37%),
        radial-gradient(ellipse at 50% 42%, transparent 0 48%, rgba(9,92,182,.18) 49%, transparent 51%),
        linear-gradient(180deg, #1a1d24 0%, #07090d 100%) !important;
}

/* WEB — grid / interfaz */
.bsx-project-card:nth-child(6)::before {
    background:
        linear-gradient(rgba(255,255,255,.08) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,.08) 1px, transparent 1px),
        radial-gradient(circle at 70% 26%, rgba(9,92,182,.24), transparent 28%),
        linear-gradient(180deg, #171d24 0%, #05070b 100%) !important;
    background-size: 56px 56px, 56px 56px, 100% 100%, 100% 100% !important;
}

/* Nombre fijo, más integrado al centro-bajo */
.bsx-project-card span {
    position: absolute !important;
    z-index: 5 !important;
    left: 28px !important;
    right: 28px !important;
    bottom: 34px !important;
    opacity: 1 !important;
    transform: none !important;
    color: #fff !important;
    font-size: clamp(24px, 2.5vw, 34px) !important;
    line-height: .95 !important;
    font-weight: 700 !important;
    letter-spacing: .12em !important;
    text-align: left !important;
    text-transform: uppercase !important;
}

/* Label superior más fino */
.bsx-project-card span::before {
    content: "BIT & SOUL" !important;
    display: block !important;
    margin-bottom: 12px !important;
    font-size: 10px !important;
    line-height: 1 !important;
    font-weight: 600 !important;
    letter-spacing: .26em !important;
    color: rgba(255,255,255,.48) !important;
}

/* Flechita más sutil */
.bsx-project-card span::after {
    content: "↗" !important;
    position: absolute !important;
    right: 0 !important;
    bottom: -4px !important;
    width: 34px !important;
    height: 34px !important;
    border-radius: 999px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    font-size: 15px !important;
    color: rgba(255,255,255,.84) !important;
    border: 1px solid rgba(255,255,255,.16) !important;
    background: rgba(255,255,255,.045) !important;
    backdrop-filter: blur(8px) !important;
}

/* Hover / click */
.bsx-project-card:hover {
    transform: translateY(-16px) scale(1.018) !important;
    filter: brightness(1.08) !important;
    border-color: rgba(255,255,255,.28) !important;
    box-shadow:
        0 38px 120px rgba(0,0,0,.58),
        0 0 70px rgba(9,92,182,.16),
        inset 0 1px 0 rgba(255,255,255,.18) !important;
}

.bsx-project-card:hover::before {
    transform: scale(1.06) !important;
    filter: brightness(1.12) !important;
}

.bsx-project-card:active {
    transform: translateY(-6px) scale(.992) !important;
}

/* Animación corregida */
@keyframes bsxTickerMoveClean {
    from {
        transform: rotateX(8deg) rotateY(6deg) translateX(0);
    }

    to {
        transform: rotateX(8deg) rotateY(6deg) translateX(-50%);
    }
}

/* Mobile */
@media (max-width: 820px) {
    .bsx-ticker {
        padding-top: 100px !important;
        padding-bottom: 110px !important;
    }

    .bsx-ticker-track {
        gap: 16px !important;
        animation: bsxTickerMoveCleanMobile 38s linear infinite !important;
        transform: rotateX(4deg) rotateY(3deg) !important;
    }

    .bsx-project-card {
        flex-basis: 260px !important;
        height: 360px !important;
        border-radius: 24px !important;
    }

    .bsx-project-card span {
        left: 22px !important;
        right: 22px !important;
        bottom: 26px !important;
        font-size: 24px !important;
        letter-spacing: .09em !important;
    }

    .bsx-project-card span::after {
        width: 30px !important;
        height: 30px !important;
    }

    .bsx-project-card:hover {
        transform: none !important;
    }

    .bsx-project-card:active {
        transform: scale(.98) !important;
        filter: brightness(1.12) !important;
    }
}

@keyframes bsxTickerMoveCleanMobile {
    from {
        transform: rotateX(4deg) rotateY(3deg) translateX(0);
    }

    to {
        transform: rotateX(4deg) rotateY(3deg) translateX(-50%);
    }
}

/* ================================
   FIX TICKER JS MARQUEE
   El movimiento lo maneja JS
================================ */

.bsx-ticker-track {
    animation: none !important;
    transform: rotateX(8deg) rotateY(6deg) translate3d(0, 0, 0);
    will-change: transform;
}

.bsx-ticker-track:hover {
    animation-play-state: running !important;
}

.bsx-project-card::after {
    display: none !important;
}
/* ================================
   FIX DEFINITIVO TICKER MOVIMIENTO
================================ */

.bsx-ticker-track {
    animation: none !important;
    transform: rotateX(8deg) rotateY(6deg) translate3d(0, 0, 0);
    will-change: transform;
}

.bsx-ticker-track:hover {
    animation-play-state: running !important;
}

/* Sacamos cualquier cruz/línea técnica */
.bsx-project-card::after {
    display: none !important;
}

/* ================================
   MOBILE PERFORMANCE TICKER
   Más fluido en teléfono
================================ */

@media (max-width: 820px) {
    .bsx-ticker {
        padding-top: 90px !important;
        padding-bottom: 100px !important;
        perspective: none !important;
        overflow: hidden !important;
    }

    .bsx-ticker-track {
        gap: 14px !important;
        transform: translate3d(0, 0, 0) !important;
        will-change: transform !important;
        backface-visibility: hidden !important;
    }

    .bsx-project-card {
        flex-basis: 245px !important;
        height: 335px !important;
        border-radius: 22px !important;
        box-shadow:
            0 18px 44px rgba(0,0,0,.36),
            inset 0 1px 0 rgba(255,255,255,.10) !important;
        filter: none !important;
        transform: translateZ(0) !important;
        backface-visibility: hidden !important;
    }

    .bsx-project-card::before {
        filter: none !important;
        opacity: .86 !important;
    }

    .bsx-project-card span {
        left: 20px !important;
        right: 20px !important;
        bottom: 24px !important;
        font-size: 22px !important;
        letter-spacing: .08em !important;
    }

    .bsx-project-card span::before {
        font-size: 9px !important;
        letter-spacing: .22em !important;
    }

    .bsx-project-card span::after {
        width: 28px !important;
        height: 28px !important;
        backdrop-filter: none !important;
    }

    .bsx-project-card:hover,
    .bsx-project-card:active {
        transform: translateZ(0) scale(.99) !important;
        filter: none !important;
    }
}

/* ================================
   STATEMENT / NOSOTROS — REFINADO
   Pegar al final del CSS
================================ */

.bsx-statement {
    position: relative;
    min-height: 100vh;
    padding: 150px 24px 150px !important;
    background:
        radial-gradient(circle at 50% 44%, rgba(9,92,182,.12), transparent 34%),
        radial-gradient(circle at 50% 50%, rgba(255,255,255,.045), transparent 22%),
        linear-gradient(180deg, #020304 0%, #05070a 48%, #020304 100%);
    overflow: hidden;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}

/* textura espacial fina */
.bsx-statement::before {
    content: "";
    position: absolute;
    inset: 0;
    background-image:
        radial-gradient(circle at 14% 24%, rgba(255,255,255,.45) 0 1px, transparent 1.4px),
        radial-gradient(circle at 78% 28%, rgba(255,255,255,.28) 0 1px, transparent 1.4px),
        radial-gradient(circle at 62% 76%, rgba(255,255,255,.22) 0 1px, transparent 1.4px),
        linear-gradient(rgba(255,255,255,.018) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,.018) 1px, transparent 1px);
    background-size: 100% 100%, 100% 100%, 100% 100%, 90px 90px, 90px 90px;
    opacity: .55;
    pointer-events: none;
}

/* halo central tipo cápsula editorial */
.bsx-statement::after {
    content: "";
    position: absolute;
    width: min(760px, 82vw);
    height: min(760px, 82vw);
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    border-radius: 50%;
    background:
        radial-gradient(circle, rgba(255,255,255,.055), rgba(9,92,182,.075) 32%, transparent 66%);
    filter: blur(8px);
    pointer-events: none;
}

/* statement central */
.bsx-statement h2 {
    position: relative;
    z-index: 4;
    max-width: 900px !important;
    margin: 0 auto !important;
    padding: clamp(34px, 5vw, 64px) clamp(24px, 5vw, 70px);
    border-radius: 34px;
    border: 1px solid rgba(255,255,255,.11);
    background:
        linear-gradient(145deg, rgba(255,255,255,.075), rgba(255,255,255,.018));
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
    box-shadow:
        0 34px 120px rgba(0,0,0,.38),
        inset 0 1px 0 rgba(255,255,255,.10);
    color: rgba(255,255,255,.92) !important;
    font-size: clamp(30px, 4.4vw, 58px) !important;
    line-height: 1.02 !important;
    font-weight: 500 !important;
    letter-spacing: -0.045em !important;
    text-align: center !important;
    text-transform: uppercase;
}

.bsx-statement h2 span {
    color: #fff;
    font-weight: 800 !important;
    text-shadow: 0 0 34px rgba(9,92,182,.18);
}

/* labels ya no tan dispersos: se sienten como coordenadas */
.bsx-floating-label {
    z-index: 5 !important;
    padding: 10px 14px;
    border: 1px solid rgba(255,255,255,.12);
    border-radius: 999px;
    background: rgba(255,255,255,.045);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    color: rgba(255,255,255,.54) !important;
    font-size: clamp(12px, 1.1vw, 15px) !important;
    line-height: 1 !important;
    font-weight: 600 !important;
    letter-spacing: .16em !important;
    text-transform: uppercase;
    opacity: 1 !important;
    white-space: nowrap;
    animation: bsxSoftFloat 5s ease-in-out infinite alternate;
}

.label-one {
    left: clamp(24px, 7vw, 110px) !important;
    top: 26% !important;
}

.label-two {
    left: clamp(24px, 12vw, 205px) !important;
    top: 34% !important;
    animation-delay: .45s;
}

.label-three {
    right: clamp(24px, 8vw, 130px) !important;
    top: 31% !important;
    animation-delay: .9s;
}

/* botones más finos y menos rústicos */
.bsx-floating-buttons {
    position: absolute !important;
    z-index: 6 !important;
    left: 50% !important;
    bottom: clamp(70px, 10vh, 110px) !important;
    transform: translateX(-50%) !important;
    width: auto !important;
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 10px !important;
    padding: 8px;
    border-radius: 999px;
    border: 1px solid rgba(255,255,255,.10);
    background: rgba(255,255,255,.045);
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
    box-shadow: 0 20px 70px rgba(0,0,0,.28);
}

.bsx-floating-buttons a {
    position: relative !important;
    overflow: hidden;
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    min-height: 42px;
    padding: 0 18px !important;
    border-radius: 999px !important;
    border: 1px solid rgba(255,255,255,.10) !important;
    background: rgba(255,255,255,.035) !important;
    color: rgba(255,255,255,.78) !important;
    font-size: 12px !important;
    line-height: 1 !important;
    font-weight: 600 !important;
    letter-spacing: .08em !important;
    text-transform: uppercase !important;
    white-space: nowrap !important;
    transition:
        color .28s ease,
        background .28s ease,
        border-color .28s ease,
        transform .28s cubic-bezier(.2,.8,.2,1),
        box-shadow .28s ease !important;
}

.bsx-floating-buttons a::before {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(120deg, transparent, rgba(255,255,255,.18), transparent);
    transform: translateX(-120%);
    transition: transform .55s ease;
}

.bsx-floating-buttons a:hover {
    color: #fff !important;
    background: rgba(255,255,255,.095) !important;
    border-color: rgba(255,255,255,.24) !important;
    transform: translateY(-2px) !important;
    box-shadow: 0 0 42px rgba(9,92,182,.18);
}

.bsx-floating-buttons a:hover::before {
    transform: translateX(120%);
}

.bsx-floating-buttons a:active {
    transform: translateY(0) scale(.98) !important;
}

@keyframes bsxSoftFloat {
    from {
        transform: translateY(0);
    }

    to {
        transform: translateY(-10px);
    }
}

/* Mobile */
@media (max-width: 820px) {
    .bsx-statement {
        min-height: 900px;
        padding: 120px 18px 150px !important;
        align-items: center !important;
    }

    .bsx-statement h2 {
        padding: 30px 22px !important;
        border-radius: 26px;
        font-size: clamp(28px, 8vw, 40px) !important;
        line-height: 1.04 !important;
        letter-spacing: -0.045em !important;
        text-align: center !important;
    }

    .bsx-floating-label {
        font-size: 10px !important;
        padding: 9px 11px;
        letter-spacing: .13em !important;
    }

    .label-one {
        left: 18px !important;
        top: 78px !important;
    }

    .label-two {
        left: 18px !important;
        top: 124px !important;
    }

    .label-three {
        right: 18px !important;
        top: 102px !important;
    }

    .bsx-floating-buttons {
        left: 18px !important;
        right: 18px !important;
        bottom: 56px !important;
        transform: none !important;
        flex-direction: column !important;
        align-items: stretch !important;
        gap: 8px !important;
        padding: 8px !important;
        border-radius: 24px;
    }

    .bsx-floating-buttons a {
        width: 100%;
        min-height: 46px;
        font-size: 12px !important;
    }
}

/* =========================================
   STATEMENT SECTION — versión más limpia
========================================= */

.bsx-statement {
    position: relative;
    min-height: 100vh;
    padding: 150px 24px 170px !important;
    background:
        radial-gradient(circle at 50% 42%, rgba(9,92,182,.10), transparent 30%),
        linear-gradient(180deg, #020304 0%, #04070b 52%, #020304 100%);
    overflow: hidden;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}

/* grilla + estrellas suaves */
.bsx-statement::before {
    content: "";
    position: absolute;
    inset: 0;
    background-image:
        linear-gradient(rgba(255,255,255,.025) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,.025) 1px, transparent 1px),
        radial-gradient(circle at 8% 12%, rgba(255,255,255,.85) 0 1px, transparent 1.8px),
        radial-gradient(circle at 18% 30%, rgba(255,255,255,.5) 0 1px, transparent 1.8px),
        radial-gradient(circle at 33% 20%, rgba(255,255,255,.65) 0 1px, transparent 1.8px),
        radial-gradient(circle at 48% 14%, rgba(255,255,255,.8) 0 1px, transparent 1.8px),
        radial-gradient(circle at 60% 28%, rgba(255,255,255,.45) 0 1px, transparent 1.8px),
        radial-gradient(circle at 74% 18%, rgba(255,255,255,.75) 0 1px, transparent 1.8px),
        radial-gradient(circle at 86% 24%, rgba(255,255,255,.55) 0 1px, transparent 1.8px),
        radial-gradient(circle at 14% 62%, rgba(255,255,255,.65) 0 1px, transparent 1.8px),
        radial-gradient(circle at 28% 76%, rgba(255,255,255,.55) 0 1px, transparent 1.8px),
        radial-gradient(circle at 44% 68%, rgba(255,255,255,.8) 0 1px, transparent 1.8px),
        radial-gradient(circle at 58% 82%, rgba(255,255,255,.45) 0 1px, transparent 1.8px),
        radial-gradient(circle at 72% 70%, rgba(255,255,255,.7) 0 1px, transparent 1.8px),
        radial-gradient(circle at 88% 78%, rgba(255,255,255,.55) 0 1px, transparent 1.8px);
    background-size:
        72px 72px,
        72px 72px,
        100% 200%,
        100% 200%,
        100% 200%,
        100% 200%,
        100% 200%,
        100% 200%,
        100% 200%,
        100% 200%,
        100% 200%,
        100% 200%,
        100% 200%,
        100% 200%,
        100% 200%;
    opacity: .55;
    pointer-events: none;
    animation: bsxStarsRain 22s linear infinite;
}

/* halo central */
.bsx-statement::after {
    content: "";
    position: absolute;
    width: min(780px, 84vw);
    height: min(780px, 84vw);
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    border-radius: 50%;
    background:
        radial-gradient(circle, rgba(255,255,255,.05), rgba(9,92,182,.08) 34%, transparent 68%);
    filter: blur(10px);
    pointer-events: none;
}

/* ocultar labels laterales */
.bsx-floating-label,
.label-one,
.label-two,
.label-three {
    display: none !important;
}

/* caja central */
.bsx-statement h2 {
    position: relative;
    z-index: 4;
    max-width: 880px !important;
    margin: 0 auto !important;
    padding: clamp(34px, 5vw, 60px) clamp(24px, 5vw, 70px);
    border-radius: 34px;
    border: 1px solid rgba(255,255,255,.10);
    background:
        linear-gradient(145deg, rgba(255,255,255,.05), rgba(255,255,255,.015));
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
    box-shadow:
        0 30px 120px rgba(0,0,0,.38),
        inset 0 1px 0 rgba(255,255,255,.08);
    color: rgba(255,255,255,.93) !important;
    font-size: clamp(30px, 4.4vw, 58px) !important;
    line-height: 1.02 !important;
    font-weight: 500 !important;
    letter-spacing: -0.045em !important;
    text-align: center !important;
    text-transform: uppercase;
}

.bsx-statement h2 span {
    color: #fff;
    font-weight: 800 !important;
    text-shadow: 0 0 28px rgba(9,92,182,.18);
}

/* contenedor del único botón */
.bsx-floating-buttons {
    position: absolute !important;
    z-index: 6 !important;
    left: 50% !important;
    bottom: clamp(78px, 10vh, 120px) !important;
    transform: translateX(-50%) !important;
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
}

/* botón charlemos más grande */
.bsx-floating-buttons a {
    position: relative !important;
    overflow: hidden;
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    min-height: 58px;
    padding: 0 34px !important;
    border-radius: 999px !important;
    border: 1px solid rgba(255,255,255,.14) !important;
    background:
        linear-gradient(180deg, rgba(255,255,255,.09), rgba(255,255,255,.035)) !important;
    color: #fff !important;
    font-size: 14px !important;
    line-height: 1 !important;
    font-weight: 700 !important;
    letter-spacing: .12em !important;
    text-transform: uppercase !important;
    white-space: nowrap !important;
    box-shadow:
        0 18px 60px rgba(0,0,0,.24),
        0 0 34px rgba(9,92,182,.14);
    transition:
        transform .28s cubic-bezier(.2,.8,.2,1),
        box-shadow .28s ease,
        border-color .28s ease,
        background .28s ease !important;
}

.bsx-floating-buttons a::before {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(120deg, transparent, rgba(255,255,255,.18), transparent);
    transform: translateX(-120%);
    transition: transform .6s ease;
}

.bsx-floating-buttons a:hover {
    transform: translateY(-3px) scale(1.02) !important;
    border-color: rgba(255,255,255,.28) !important;
    background:
        linear-gradient(180deg, rgba(255,255,255,.13), rgba(255,255,255,.05)) !important;
    box-shadow:
        0 24px 70px rgba(0,0,0,.30),
        0 0 42px rgba(9,92,182,.20);
}

.bsx-floating-buttons a:hover::before {
    transform: translateX(120%);
}

.bsx-floating-buttons a:active {
    transform: translateY(0) scale(.98) !important;
}

@keyframes bsxStarsRain {
    from {
        background-position:
            0 0,
            0 0,
            0 0,
            0 0,
            0 0,
            0 0,
            0 0,
            0 0,
            0 0,
            0 0,
            0 0,
            0 0,
            0 0,
            0 0,
            0 0;
    }
    to {
        background-position:
            0 0,
            0 0,
            0 180px,
            0 220px,
            0 200px,
            0 250px,
            0 210px,
            0 230px,
            0 195px,
            0 260px,
            0 240px,
            0 215px,
            0 235px,
            0 205px,
            0 225px;
    }
}

@media (max-width: 820px) {
    .bsx-statement {
        min-height: 880px;
        padding: 120px 18px 150px !important;
    }

    .bsx-statement h2 {
        padding: 30px 22px !important;
        border-radius: 26px;
        font-size: clamp(28px, 8vw, 40px) !important;
        line-height: 1.04 !important;
    }

    .bsx-floating-buttons {
        left: 50% !important;
        right: auto !important;
        width: calc(100% - 36px);
        max-width: 360px;
        transform: translateX(-50%) !important;
        bottom: 56px !important;
    }

    .bsx-floating-buttons a {
        width: 100%;
        min-height: 56px;
        padding: 0 24px !important;
        font-size: 13px !important;
    }
}

/* =========================================
   SECCIÓN MANIFIESTO — FINAL CON CLASES ACTUALES
   Clases: .bsx-manifesto-section / .bsx-manifesto-box
========================================= */

.bsx-manifesto-section {
  position: relative;
  overflow: hidden;
  padding: 150px 20px 170px !important;
  background:
    radial-gradient(circle at 50% 42%, rgba(9,92,182,.10), transparent 32%),
    linear-gradient(180deg, #020304 0%, #04070b 52%, #020304 100%) !important;
}

/* grilla sutil de fondo */
.bsx-manifesto-section::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  background-image:
    linear-gradient(rgba(255,255,255,.022) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.022) 1px, transparent 1px);
  background-size: 72px 72px;
  opacity: .55;
  pointer-events: none;
}

/* halo central */
.bsx-manifesto-section::after {
  content: "";
  position: absolute;
  width: min(780px, 84vw);
  height: min(780px, 84vw);
  left: 50%;
  top: 50%;
  z-index: 0;
  transform: translate(-50%, -50%);
  border-radius: 50%;
  background:
    radial-gradient(circle, rgba(255,255,255,.045), rgba(9,92,182,.08) 34%, transparent 68%);
  filter: blur(10px);
  pointer-events: none;
}

/* lluvia de estrellas */
.bsx-star-rain {
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  overflow: hidden;
}

.bsx-star {
  position: absolute;
  top: -12px;
  width: 2px;
  height: 2px;
  border-radius: 50%;
  background: rgba(255,255,255,.9);
  box-shadow: 0 0 8px rgba(255,255,255,.45);
  opacity: .55;
  animation-name: bsxStarFall;
  animation-timing-function: linear;
  animation-iteration-count: infinite;
}

.bsx-star::after {
  content: "";
  position: absolute;
  top: 50%;
  left: -1px;
  width: 1px;
  height: 46px;
  transform: translateY(-10%);
  background: linear-gradient(to bottom, rgba(255,255,255,.32), rgba(255,255,255,0));
  opacity: .45;
}

@keyframes bsxStarFall {
  0% {
    transform: translate3d(0, -20px, 0);
    opacity: 0;
  }

  8% {
    opacity: .45;
  }

  100% {
    transform: translate3d(-18px, 110vh, 0);
    opacity: 0;
  }
}

/* caja central */
.bsx-manifesto-box {
  position: relative;
  z-index: 3;
  max-width: 880px !important;
  margin: 0 auto !important;
  padding: clamp(34px, 5vw, 60px) clamp(24px, 5vw, 70px) !important;
  border-radius: 34px !important;
  border: 1px solid rgba(255,255,255,.10) !important;
  background:
    linear-gradient(145deg, rgba(255,255,255,.052), rgba(255,255,255,.015)) !important;
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  box-shadow:
    0 30px 120px rgba(0,0,0,.38),
    inset 0 1px 0 rgba(255,255,255,.08) !important;
  text-align: center;
}

.bsx-manifesto-box h2 {
  margin: 0 !important;
  color: rgba(255,255,255,.93) !important;
  font-size: clamp(30px, 4.4vw, 58px) !important;
  line-height: 1.02 !important;
  font-weight: 500 !important;
  letter-spacing: -0.045em !important;
  text-align: center !important;
  text-transform: uppercase;
}

.bsx-manifesto-box h2 strong,
.bsx-manifesto-box h2 span {
  color: #fff !important;
  font-weight: 800 !important;
  text-shadow: 0 0 28px rgba(9,92,182,.18);
}

/* botón limpio, sin cápsula exterior */
.bsx-manifesto-section .bsx-floating-buttons {
  position: relative !important;
  z-index: 4 !important;
  display: flex !important;
  justify-content: center !important;
  align-items: center !important;
  width: auto !important;
  margin: 34px auto 0 !important;
  padding: 0 !important;
  border: none !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  transform: none !important;
  left: auto !important;
  right: auto !important;
  bottom: auto !important;
}

.bsx-manifesto-section .bsx-floating-buttons a {
  position: relative !important;
  overflow: hidden;
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  min-height: 56px;
  padding: 0 34px !important;
  border-radius: 0 !important;
  border: 1px solid rgba(255,255,255,.38) !important;
  background: transparent !important;
  color: #ffffff !important;
  font-size: 14px !important;
  line-height: 1 !important;
  font-weight: 700 !important;
  letter-spacing: .14em !important;
  text-transform: uppercase !important;
  text-decoration: none !important;
  white-space: nowrap !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  transition:
    transform .28s cubic-bezier(.2,.8,.2,1),
    border-color .28s ease,
    background .28s ease,
    color .28s ease !important;
}

.bsx-manifesto-section .bsx-floating-buttons a::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(120deg, transparent, rgba(255,255,255,.16), transparent);
  transform: translateX(-125%);
  transition: transform .65s ease;
  pointer-events: none;
}

.bsx-manifesto-section .bsx-floating-buttons a:hover {
  transform: translateY(-3px) !important;
  border-color: rgba(255,255,255,.82) !important;
  background: rgba(255,255,255,.055) !important;
  color: #fff !important;
}

.bsx-manifesto-section .bsx-floating-buttons a:hover::before {
  transform: translateX(125%);
}

.bsx-manifesto-section .bsx-floating-buttons a:active {
  transform: translateY(0) scale(.985) !important;
}

/* mobile */
@media (max-width: 768px) {
  .bsx-manifesto-section {
    padding: 110px 18px 125px !important;
  }

  .bsx-manifesto-box {
    padding: 34px 24px !important;
    border-radius: 24px !important;
  }

  .bsx-manifesto-box h2 {
    font-size: clamp(28px, 9vw, 46px) !important;
    line-height: 1.02 !important;
  }

  .bsx-manifesto-section .bsx-floating-buttons {
    width: 100% !important;
    max-width: 340px;
    margin-top: 28px !important;
  }

  .bsx-manifesto-section .bsx-floating-buttons a {
    width: 100%;
    min-height: 54px;
    padding: 0 24px !important;
    font-size: 13px !important;
    letter-spacing: .13em !important;
  }

  .bsx-star::after {
    height: 30px;
    opacity: .35;
  }
}