@import url('https://fonts.googleapis.com/css2?family=Anton&family=Inter:wght@400;600;800;900&display=swap');

:root{
    --blue:#00aeef;
    --pink:#ff008c;
    --white:#ffffff;
    --black:#03040a;
}

*{box-sizing:border-box}

html,body{
    margin:0;
    width:100%;
    min-height:100%;
    background:#03040a;
    color:white;
    font-family:Inter, sans-serif;
}

body{
    overflow:hidden;
}

.csl-landing{
    position:relative;
    width:100vw;
    min-height:100vh;
    overflow:hidden;
    display:flex;
    align-items:center;
    justify-content:center;
    background:
        radial-gradient(circle at 14% 24%, rgba(0,174,239,.42), transparent 23%),
        radial-gradient(circle at 86% 24%, rgba(255,0,140,.44), transparent 25%),
        radial-gradient(circle at 14% 86%, rgba(0,174,239,.25), transparent 30%),
        radial-gradient(circle at 86% 86%, rgba(255,0,140,.28), transparent 32%),
        linear-gradient(120deg,#02030a 0%,#061126 45%,#02030a 100%);
}

.csl-landing::before{
    content:"";
    position:absolute;
    inset:-20%;
    background:
      linear-gradient(110deg, transparent 0 42%, rgba(0,174,239,.13) 49%, transparent 56%),
      linear-gradient(70deg, transparent 0 42%, rgba(255,0,140,.12) 50%, transparent 57%);
    animation:lightSweep 7s ease-in-out infinite alternate;
    opacity:.85;
}

@keyframes lightSweep{
    0%{transform:translateX(-6%) rotate(0deg)}
    100%{transform:translateX(6%) rotate(2deg)}
}

.floodlight{
    position:absolute;
    top:4vh;
    width:250px;
    display:grid;
    grid-template-columns:repeat(6, 1fr);
    gap:12px;
    z-index:2;
    filter:drop-shadow(0 0 28px currentColor);
    opacity:.95;
    animation:floodPulse 2.6s ease-in-out infinite alternate;
}

.floodlight i{
    width:24px;
    height:24px;
    border-radius:50%;
    background:white;
    box-shadow:0 0 18px white, 0 0 34px currentColor;
}

.floodlight-left{
    left:3vw;
    color:var(--blue);
    transform:rotate(-16deg);
}

.floodlight-right{
    right:3vw;
    color:var(--pink);
    transform:rotate(16deg);
    animation-delay:.7s;
}

@keyframes floodPulse{
    from{opacity:.68;filter:drop-shadow(0 0 16px currentColor)}
    to{opacity:1;filter:drop-shadow(0 0 42px currentColor)}
}

.beam{
    position:absolute;
    top:0;
    width:52vw;
    height:72vh;
    opacity:.22;
    filter:blur(18px);
    z-index:1;
    pointer-events:none;
}

.beam-left{
    left:-6vw;
    background:linear-gradient(115deg, rgba(0,174,239,.75), transparent 58%);
    clip-path:polygon(0 0, 70% 0, 100% 100%, 0 100%);
}

.beam-right{
    right:-6vw;
    background:linear-gradient(245deg, rgba(255,0,140,.75), transparent 58%);
    clip-path:polygon(30% 0, 100% 0, 100% 100%, 0 100%);
}

.smoke{
    position:absolute;
    width:58vw;
    height:45vh;
    bottom:-17vh;
    border-radius:50%;
    filter:blur(80px);
    opacity:.42;
    animation:smoke 8s ease-in-out infinite alternate;
}

.smoke-left{
    left:-18vw;
    background:var(--blue);
}

.smoke-right{
    right:-18vw;
    background:var(--pink);
    animation-delay:1.1s;
}

@keyframes smoke{
    from{transform:translateY(0) scale(1)}
    to{transform:translateY(-7vh) scale(1.12)}
}

.spark-layer{
    position:absolute;
    inset:0;
    pointer-events:none;
    opacity:.42;
}

.spark-layer::before,
.spark-layer::after{
    content:"";
    position:absolute;
    inset:-20%;
    background-image:
      radial-gradient(circle, rgba(0,174,239,.95) 1px, transparent 2px),
      radial-gradient(circle, rgba(255,0,140,.95) 1px, transparent 2px),
      radial-gradient(circle, rgba(255,255,255,.7) 1px, transparent 2px);
    background-size:130px 130px, 190px 190px, 250px 250px;
    animation:sparks 16s linear infinite;
}

.spark-two::before{
    animation-duration:22s;
    animation-direction:reverse;
    opacity:.45;
}

@keyframes sparks{
    from{transform:translateY(10vh) translateX(0)}
    to{transform:translateY(-18vh) translateX(4vw)}
}

.stage{
    position:relative;
    z-index:5;
    width:min(1280px,94vw);
    text-align:center;
    padding:3vh 24px 5vh;
    animation:stageIn 1.2s ease both;
}

@keyframes stageIn{
    from{opacity:0;transform:translateY(28px) scale(.98)}
    to{opacity:1;transform:none}
}

.brand-logo{
    display:block;
    width:min(300px,54vw);
    max-height:22vh;
    object-fit:contain;
    margin:0 auto 10px;
    filter:
        drop-shadow(0 0 22px rgba(0,174,239,.40))
        drop-shadow(0 0 36px rgba(255,0,140,.25));
    animation:logoFloat 3.8s ease-in-out infinite alternate;
}

@keyframes logoFloat{
    from{transform:translateY(0);filter:drop-shadow(0 0 18px rgba(0,174,239,.35))}
    to{transform:translateY(-10px);filter:drop-shadow(0 0 38px rgba(255,0,140,.48))}
}

.edition{
    margin-top:8px;
    display:flex;
    align-items:center;
    justify-content:center;
    gap:22px;
    font-weight:900;
}

.edition span{
    width:84px;
    height:2px;
    background:linear-gradient(90deg,transparent,var(--blue),var(--pink),transparent);
}

.edition strong{
    color:#fff;
    letter-spacing:.55em;
    font-size:clamp(13px,1.5vw,24px);
}

.coming-title{
    margin:3vh 0 2.2vh;
    display:flex;
    justify-content:center;
    gap:clamp(22px,4vw,70px);
    flex-wrap:wrap;
    font-family:Anton, sans-serif;
    font-weight:400;
    font-size:clamp(74px,12.5vw,198px);
    line-height:.88;
    letter-spacing:.09em;
    text-transform:uppercase;
}

.coming-title span:first-child{
    color:white;
    text-shadow:0 0 35px rgba(255,255,255,.22);
    animation:titleGlowBlue 2.4s ease-in-out infinite alternate;
}

.coming-title span:last-child{
    background:linear-gradient(90deg,var(--blue),#7b61ff,var(--pink));
    -webkit-background-clip:text;
    color:transparent;
    animation:titleGlowPink 2.4s ease-in-out infinite alternate;
}

@keyframes titleGlowBlue{
    from{text-shadow:0 0 14px rgba(0,174,239,.20)}
    to{text-shadow:0 0 34px rgba(0,174,239,.55)}
}

@keyframes titleGlowPink{
    from{filter:drop-shadow(0 0 10px rgba(255,0,140,.15))}
    to{filter:drop-shadow(0 0 30px rgba(255,0,140,.55))}
}

.tagline{
    margin:0;
    font-size:clamp(15px,2vw,28px);
    font-weight:800;
    letter-spacing:.42em;
    color:#fff;
}

.quick-stats{
    width:min(780px,92vw);
    margin:3.8vh auto 3vh;
    display:grid;
    grid-template-columns:repeat(3,1fr);
    border:1px solid rgba(255,255,255,.20);
    border-radius:24px;
    overflow:hidden;
    background:
        linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.015)),
        rgba(0,0,0,.30);
    box-shadow:
        0 0 34px rgba(0,174,239,.18),
        0 0 44px rgba(255,0,140,.12),
        inset 0 0 30px rgba(255,255,255,.045);
    backdrop-filter:blur(12px);
}

.quick-stats div{
    padding:22px 14px;
    position:relative;
}

.quick-stats div:not(:last-child)::after{
    content:"";
    position:absolute;
    right:0;
    top:22%;
    height:56%;
    width:1px;
    background:linear-gradient(var(--blue),var(--pink));
    opacity:.9;
}

.quick-stats b{
    display:block;
    font-family:Anton, sans-serif;
    font-weight:400;
    font-size:clamp(42px,5vw,76px);
    line-height:1;
}

.quick-stats div:nth-child(1) b{color:var(--blue)}
.quick-stats div:nth-child(3) b{color:var(--pink)}

.quick-stats small{
    display:block;
    margin-top:8px;
    font-size:clamp(10px,1vw,14px);
    letter-spacing:.18em;
    font-weight:900;
}

.launch-pill{
    display:inline-block;
    padding:18px 66px;
    border-radius:999px;
    border:2px solid transparent;
    background:
        linear-gradient(#040814,#040814) padding-box,
        linear-gradient(90deg,var(--blue),var(--pink)) border-box;
    font-weight:900;
    letter-spacing:.35em;
    font-size:clamp(13px,1.4vw,22px);
    box-shadow:
        0 0 22px rgba(0,174,239,.30),
        0 0 34px rgba(255,0,140,.22);
    animation:pillGlow 2.2s ease-in-out infinite alternate;
}

@keyframes pillGlow{
    from{transform:translateY(0);box-shadow:0 0 18px rgba(0,174,239,.25)}
    to{transform:translateY(-3px);box-shadow:0 0 38px rgba(255,0,140,.48)}
}

.csl-footer{
    position:absolute;
    z-index:6;
    bottom:18px;
    left:24px;
    right:24px;
    display:flex;
    justify-content:space-between;
    gap:20px;
    color:rgba(255,255,255,.65);
    font-size:13px;
    letter-spacing:.12em;
}

.csl-footer span:last-child{
    color:#9fb7d9;
}

@media(max-width:760px){
    body{overflow:auto}

    .csl-landing{
        min-height:100svh;
        height:auto;
        align-items:flex-start;
        padding:30px 0 28px;
    }

    .floodlight{
        width:118px;
        gap:6px;
        top:16px;
    }

    .floodlight i{
        width:12px;
        height:12px;
    }

    .floodlight-left{left:10px}
    .floodlight-right{right:10px}

    .beam{
        height:42vh;
        opacity:.20;
    }

    .smoke{
        width:80vw;
        height:36vh;
        bottom:-12vh;
    }

    .stage{
        width:100%;
        padding:44px 18px 0;
        min-height:auto;
    }

    .brand-logo{
        width:min(245px,64vw);
        max-height:none;
        margin-top:18px;
        margin-bottom:8px;
    }

    .edition{
        margin-top:8px;
        gap:14px;
    }

    .edition span{
        width:48px;
    }

    .edition strong{
        letter-spacing:.38em;
        font-size:13px;
    }

    .coming-title{
        display:block;
        margin:28px 0 18px;
        font-size:clamp(64px,20vw,96px);
        letter-spacing:.055em;
        line-height:.95;
    }

    .coming-title span{
        display:block;
    }

    .coming-title span + span{
        margin-top:6px;
    }

    .tagline{
        font-size:13px;
        letter-spacing:.18em;
        line-height:1.7;
        max-width:360px;
        margin:0 auto;
    }

    .quick-stats{
        width:min(340px,88vw);
        grid-template-columns:1fr;
        margin:28px auto 28px;
        border-radius:22px;
    }

    .quick-stats div{
        padding:20px 14px;
        display:grid;
        grid-template-columns:90px 1fr;
        align-items:center;
        text-align:left;
        gap:10px;
    }

    .quick-stats div:not(:last-child)::after{
        width:78%;
        height:1px;
        top:auto;
        bottom:0;
        left:11%;
    }

    .quick-stats b{
        text-align:center;
        font-size:48px;
    }

    .quick-stats small{
        margin:0;
        font-size:13px;
        letter-spacing:.13em;
        line-height:1.35;
    }

    .launch-pill{
        padding:15px 30px;
        letter-spacing:.22em;
        font-size:13px;
        margin-bottom:26px;
    }

    .csl-footer{
        position:relative;
        left:auto;
        right:auto;
        bottom:auto;
        margin:18px auto 0;
        width:min(340px,88vw);
        flex-direction:column;
        text-align:center;
        align-items:center;
        gap:12px;
        font-size:11px;
        line-height:1.5;
        transform:none;
        clear:both;
    }
}

@media(max-width:380px){
    .coming-title{
        font-size:58px;
    }

    .brand-logo{
        width:220px;
    }

    .quick-stats{
        width:90vw;
    }
}
