:root {
    --bg: #100b18;
    --panel: #191121;
    --panel2: #21142c;
    --pink: #ff4fa3;
    --pink2: #ff9dcb;
    --purple: #8b5cff;
    --text: #fff7fb;
    --muted: #bcaebe;
    --line: rgba(255, 255, 255, .1);
    --heading: "Chakra Petch", sans-serif;
    --body: "Inter", sans-serif
}

.portrait img {
    width: 100%;
    height: 100%;
    position: relative;
    z-index: 1;
    object-fit: cover;
    object-position: center top;
    transition: transform .35s, filter .35s;
    filter: saturate(.9) contrast(1.04)
}

.agent-card:hover .portrait img {
    transform: scale(1.035);
    filter: saturate(1.08) contrast(1.04)
}

* {
    box-sizing: border-box
}

html {
    scroll-behavior: smooth
}

body {
    margin: 0;
    color: var(--text);
    font-family: var(--body);
    overflow-x: hidden;
    background: var(--bg);
    /* background: var(--bg) url(background.png) no-repeat 0 0; */
    /* background-size: cover; */
}

.noise {
    position: fixed;
    inset: 0;
    pointer-events: none;
    opacity: .15;
    z-index: 20;
    background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 160 160' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.18'/%3E%3C/svg%3E")
}

.site-header {
    height: 88px;
    padding: 0 5vw;
    display: flex;
    align-items: center;
    gap: 38px;
    border-bottom: 1px solid var(--line);
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    z-index: 10
}

.logo-placeholder {
    width: 124px;
    height: 78px;
    /* border: 1px dashed rgba(255, 255, 255, .35); */
    color: #fff;
    text-decoration: none;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    font-family: var(--heading);
    font-weight: 700;
    letter-spacing: .18em
}

.logo-placeholder img {
    object-fit: contain;
    height: 100%;
}

.logo-placeholder small {
    font-size: 7px;
    color: var(--pink2)
}

nav {
    display: flex;
    gap: 30px;
    margin-left: auto
}

nav a {
    color: #d8cbd8;
    text-decoration: none;
    text-transform: uppercase;
    font-family: var(--heading);
    font-size: 13px;
    letter-spacing: .13em;
    transition: .2s
}

nav a:hover {
    color: var(--pink)
}

button,
.primary-button {
    font: inherit
}

.trailer-button,
.primary-button {
    border: 0;
    color: white;
    background: linear-gradient(135deg, var(--pink), #bc3dff);
    font-family: var(--heading);
    font-weight: 700;
    letter-spacing: .08em;
    text-transform: uppercase;
    cursor: pointer;
    clip-path: polygon(0 0, 91% 0, 100% 28%, 100% 100%, 9% 100%, 0 72%);
    transition: transform .2s, filter .2s
}

.trailer-button {
    padding: 13px 21px
}

.trailer-button:hover,
.primary-button:hover {
    transform: translateY(-2px);
    filter: brightness(1.15)
}

.play {
    font-size: 10px;
    margin-right: 8px
}

.hero {
    min-height: 760px;
    height: 100vh;
    max-height: 980px;
    position: relative;
    display: flex;
    align-items: center;
    padding: 120px 8vw 70px;
    isolation: isolate;
    overflow: hidden;
    background: radial-gradient(circle at 70% 40%, #56224f 0, transparent 36%), linear-gradient(130deg, #120c19 35%, #28132f 100%);
}

.hero .hero-img {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    width: 80%;
    height: 100%;
    object-fit: cover;
    z-index: -3;
}

.hero:after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(90deg, rgba(16, 11, 24, .96) 5%, rgba(16, 11, 24, .75) 42%, transparent 75%), linear-gradient(0deg, var(--bg), transparent 24%);
    z-index: -1
}

.hero-art {
    position: absolute;
    inset: 88px 0 0 35%;
    overflow: hidden;
    /* background: linear-gradient(135deg, transparent, #4f254d 55%, #1a1221), repeating-linear-gradient(-45deg, transparent 0 70px, rgba(255, 255, 255, .03) 70px 71px); */
    z-index: -2
}

.image-label,
.portrait-label {
    position: absolute;
    font-family: var(--heading);
    font-size: 10px;
    letter-spacing: .24em;
    color: rgba(255, 255, 255, .35)
}

.image-label {
    right: 10%;
    bottom: 25%
}

.crosshair {
    position: absolute;
    width: 300px;
    height: 300px;
    border: 1px solid rgba(255, 123, 183, .25);
    border-radius: 50%;
    left: 50%;
    top: 48%;
    transform: translate(-50%, -50%)
}

.crosshair:before,
.crosshair:after {
    content: "";
    position: absolute;
    background: rgba(255, 123, 183, .25)
}

.crosshair:before {
    height: 1px;
    width: 140%;
    left: -20%;
    top: 50%
}

.crosshair:after {
    width: 1px;
    height: 140%;
    left: 50%;
    top: -20%
}

.crosshair i {
    position: absolute;
    inset: 36%;
    border: 2px solid var(--pink);
    border-radius: 50%;
    box-shadow: 0 0 40px var(--pink)
}

.hero-streak {
    height: 2px;
    background: linear-gradient(90deg, transparent, var(--pink), transparent);
    position: absolute;
    width: 60%;
    transform: rotate(-40deg);
    opacity: .5
}

.streak-one {
    top: 35%;
    right: -5%
}

.streak-two {
    top: 65%;
    left: 10%
}

.hero-copy {
    position: relative;
    max-width: 690px;
    z-index: 2
}

.eyebrow {
    font-family: var(--heading);
    font-size: 12px;
    letter-spacing: .22em;
    text-transform: uppercase;
    color: var(--pink2);
    font-weight: 700
}

.eyebrow span {
    display: inline-block;
    width: 34px;
    height: 2px;
    background: var(--pink);
    vertical-align: middle;
    margin-right: 12px;
    box-shadow: 0 0 12px var(--pink)
}

h1,
h2,
h3 {
    font-family: var(--heading);
    text-transform: uppercase;
    margin: 0
}

h1 {
    font-size: clamp(58px, 8vw, 116px);
    line-height: .84;
    letter-spacing: -.06em;
    max-width: 800px;
    text-shadow: 0 4px 30px rgba(0, 0, 0, .35)
}

h1 em,
h2 em {
    font-style: normal;
    color: var(--pink);
    text-shadow: 0 0 30px rgba(255, 79, 163, .25)
}

.hero-lead {
    max-width: 560px;
    color: #cfbfce;
    font-size: 16px;
    line-height: 1.75;
    margin: 30px 0
}

.hero-actions {
    display: flex;
    align-items: center;
    gap: 22px
}

.primary-button {
    display: inline-flex;
    align-items: center;
    gap: 28px;
    padding: 17px 23px;
    text-decoration: none;
    font-size: 13px
}

.primary-button span {
    font-size: 18px
}

.status-chip {
    font-family: var(--heading);
    font-size: 11px;
    letter-spacing: .1em;
    color: #d5c5d3;
    text-transform: uppercase
}

.pulse {
    display: inline-block;
    width: 8px;
    height: 8px;
    background: #ffc1dd;
    border-radius: 50%;
    margin-right: 8px;
    box-shadow: 0 0 0 0 rgba(255, 107, 172, .8);
    animation: pulse 1.8s infinite
}

.round-card {
    position: absolute;
    right: 6%;
    bottom: 8%;
    width: 170px;
    padding: 18px;
    border: 1px solid var(--line);
    background: rgba(20, 11, 26, .65);
    backdrop-filter: blur(12px);
    font-family: var(--heading)
}

.round-card span {
    font-size: 10px;
    letter-spacing: .15em;
    color: var(--muted)
}

.round-card strong {
    display: block;
    font-size: 32px;
    margin: 4px 0
}

.round-card div,
.skill div {
    height: 3px;
    background: rgba(255, 255, 255, .12)
}

.round-card i,
.skill i {
    display: block;
    height: 100%;
    background: linear-gradient(90deg, var(--pink), var(--purple));
    box-shadow: 0 0 15px var(--pink)
}

.round-card i {
    width: 100%
}

.team-section,
.about-section,
.contact-section {
    padding: 110px 5vw
}
.team-section {
    padding-top: 30px;
}
.section-heading {
    display: flex;
    justify-content: space-between;
    align-items: end;
    gap: 40px;
    max-width: 1400px;
    margin: 0 auto 42px
}

.section-heading h2,
.about-panel h2,
.contact-section h2 {
    font-size: clamp(40px, 5vw, 72px);
    letter-spacing: -.04em;
    line-height: .95
}

.section-heading>p {
    max-width: 430px;
    color: var(--muted);
    line-height: 1.7;
    font-size: 14px
}

.team-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 16px;
    max-width: 1500px;
    margin: auto
}

.agent-card {
    background: linear-gradient(180deg, #22152c, #17101e);
    border: 1px solid var(--line);
    position: relative;
    overflow: hidden;
    transition: transform .3s, border-color .3s;
    transition-delay: var(--delay)
}

.agent-card:hover {
    transform: translateY(-10px);
    border-color: var(--accent)
}

.agent-card:before {
    content: "";
    position: absolute;
    inset: 0;
    background: radial-gradient(circle at 50% 30%, color-mix(in srgb, var(--accent), transparent 70%), transparent 48%);
    opacity: .7
}

.card-topline {
    position: absolute;
    top: 15px;
    left: 15px;
    right: 15px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    z-index: 3;
    font-family: var(--heading);
    font-size: 9px;
    letter-spacing: .16em;
    color: #d4c7d4
}

.live-badge {
    padding: 6px 8px;
    background: #36263b;
    color: #d4c7d4
}

.live-badge i {
    display: inline-block;
    width: 5px;
    height: 5px;
    border-radius: 50%;
    background: #948798;
    margin-right: 4px
}

.live-badge.live {
    background: #d72573;
    color: white;
    box-shadow: 0 0 18px rgba(255, 48, 139, .4)
}

.live-badge.live i {
    background: white;
    animation: pulse 1.5s infinite
}

.portrait {
    height: 310px;
    position: relative;
    display: flex;
    align-items: end;
    justify-content: center;
    background: repeating-linear-gradient(90deg, transparent 0 39px, rgba(255, 255, 255, .025) 40px)
}

.portrait svg {
    width: 96%;
    height: 96%;
    position: relative;
    z-index: 1;
    filter: drop-shadow(0 15px 18px rgba(0, 0, 0, .3));
    transition: transform .3s
}

.agent-card:hover .portrait svg {
    transform: scale(1.035)
}

.portrait-label {
    bottom: 8px;
    left: 12px;
    z-index: 2;
    font-size: 7px
}

.agent-info {
    position: relative;
    padding: 22px;
    border-top: 1px solid var(--line);
    background: rgba(20, 12, 26, .82);
    z-index: 2
}

.role {
    font-family: var(--heading);
    color: var(--accent) !important;
    text-transform: uppercase;
    font-size: 10px !important;
    letter-spacing: .13em;
    margin-top: 0 !important
}

.agent-info h3 {
    font-size: 25px;
    letter-spacing: -.03em;
    overflow-wrap: anywhere
}

.agent-info p {
    color: var(--muted);
    font-size: 12px;
    line-height: 1.65;
    min-height: 40px
}

.skill span {
    display: block;
    font-family: var(--heading);
    text-transform: uppercase;
    letter-spacing: .15em;
    font-size: 8px;
    color: #a697a8;
    margin-bottom: 7px
}

.stream-link {
    margin-top: 20px;
    padding-top: 14px;
    border-top: 1px solid var(--line);
    display: flex;
    gap: 8px;
    color: white;
    text-decoration: none;
    text-transform: uppercase;
    font-family: var(--heading);
    font-size: 11px;
    letter-spacing: .12em
}

.stream-link span {
    color: var(--accent)
}

.about-section {
    background: linear-gradient(135deg, #1b1022, #100b18)
}

.about-section-inner {
    max-width: 1500px;
    margin: auto;
    display: grid;
    grid-template-columns: 1.4fr .8fr;
    gap: 22px;
}

.about-panel,
.loadout {
    border: 1px solid var(--line);
    padding: clamp(28px, 5vw, 70px);
    background: rgba(255, 255, 255, .025)
}

.about-panel>p:not(.eyebrow) {
    max-width: 650px;
    color: var(--muted);
    line-height: 1.8
}

.stats {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 10px;
    margin-top: 50px
}

.stats div {
    border-left: 2px solid var(--pink);
    padding-left: 15px
}

.stats strong {
    display: block;
    font: 700 34px var(--heading)
}

.stats span {
    font-size: 10px;
    color: var(--muted);
    text-transform: uppercase;
    letter-spacing: .08em
}

.loadout-category {
    --category: #ff4fa3;
    margin-top: 12px;
    padding: 15px;
    border: 1px solid var(--line);
    background: linear-gradient(115deg, color-mix(in srgb, var(--category), transparent 88%), rgba(255, 255, 255, .015));
    transition: border-color .2s, transform .2s
}

.loadout-category:hover {
    border-color: color-mix(in srgb, var(--category), transparent 35%);
    transform: translateX(3px)
}

.loadout-category.legendary {
    --category: #ffb44f
}

.loadout-category.unlimited {
    --category: #9b78ff
}

.loadout-category.critical {
    --category: #ff417f
}

.loadout-category-head {
    display: grid;
    grid-template-columns: 28px 1fr;
    gap: 8px;
    align-items: start;
    font-family: var(--heading)
}

.loadout-category-head>span {
    color: var(--category);
    font-size: 10px
}

.loadout-category-head i {
    display: block;
    color: var(--category);
    font-size: 10px;
    font-style: normal;
    letter-spacing: .15em
}

.loadout-category-head small {
    display: block;
    margin-top: 4px;
    color: var(--muted);
    font: 9px var(--body)
}

.loadout-roll {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-top: 13px;
    padding-top: 12px;
    border-top: 1px solid var(--line)
}

.loadout-roll strong {
    font: 700 18px var(--heading);
    text-transform: uppercase
}

.loadout-roll strong.rolled {
    animation: loadout-roll .35s ease
}

.loadout-roll button {
    width: 34px;
    height: 30px;
    border: 1px solid color-mix(in srgb, var(--category), transparent 35%);
    background: transparent;
    color: var(--category);
    font-size: 18px;
    cursor: pointer;
    transition: .2s
}

.loadout-roll button:hover {
    background: var(--category);
    color: #160e1d;
    transform: rotate(90deg)
}

@keyframes loadout-roll {
    0% {
        opacity: 0;
        transform: translateY(-8px);
        filter: blur(3px)
    }

    100% {
        opacity: 1;
        transform: none;
        filter: none
    }
}

.shuffle-button {
    margin-top: 25px;
    width: 100%;
    padding: 14px;
    border: 1px solid var(--pink);
    color: var(--pink2);
    background: transparent;
    text-transform: uppercase;
    font: 700 11px var(--heading);
    letter-spacing: .12em;
    cursor: pointer;
    transition: .2s
}

.shuffle-button:hover {
    background: var(--pink);
    color: white
}

.contact-section {
    display: grid;
    grid-template-columns: 1fr auto auto;
    align-items: center;
    gap: 35px;
    max-width: 1500px;
    margin: auto
}

.contact-section p:not(.eyebrow) {
    color: var(--muted)
}

.social-links {
    display: flex;
    gap: 8px
}

.social-links a {
    display: grid;
    place-items: center;
    width: 44px;
    height: 44px;
    border: 1px solid var(--line);
    color: white;
    text-decoration: none;
    font: 700 11px var(--heading);
    transition: .2s
}

.social-links a:hover {
    border-color: var(--pink);
    color: var(--pink)
}

footer {
    border-top: 1px solid var(--line);
    padding: 25px 5vw;
    display: flex;
    justify-content: space-between;
    color: #827484;
    text-transform: uppercase;
    font: 10px var(--heading);
    letter-spacing: .15em
}

.trailer-modal {
    border: 1px solid rgba(255, 255, 255, .18);
    padding: 0;
    background: #160e1d;
    color: white;
    width: min(800px, 90vw);
    box-shadow: 0 30px 100px #000
}

.trailer-modal::backdrop {
    background: rgba(10, 5, 14, .86);
    backdrop-filter: blur(8px)
}

.trailer-modal>button {
    position: absolute;
    right: 10px;
    top: 6px;
    background: transparent;
    color: white;
    border: 0;
    font-size: 30px;
    cursor: pointer;
    z-index: 2
}

.video-placeholder {
    aspect-ratio: 16/9;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 10px;
    background: radial-gradient(circle, #5d285c, #17101e 65%);
    font-family: var(--heading)
}

.video-placeholder span {
    font-size: 40px;
    color: var(--pink)
}

.video-placeholder strong {
    font-size: clamp(22px, 4vw, 45px)
}

.video-placeholder small {
    color: var(--muted)
}

.reveal {
    opacity: 0;
    transform: translateY(25px);
    transition: opacity .7s, transform .7s
}

.reveal.visible {
    opacity: 1;
    transform: none
}

@keyframes pulse {
    70% {
        box-shadow: 0 0 0 8px rgba(255, 79, 163, 0)
    }

    100% {
        box-shadow: 0 0 0 0 rgba(255, 79, 163, 0)
    }
}

@media(max-width:1100px) {
    .team-grid {
        grid-template-columns: repeat(2, 1fr)
    }

    .about-section {
        grid-template-columns: 1fr
    }

    .contact-section {
        grid-template-columns: 1fr
    }

    .round-card {
        display: none
    }
}

@media(max-width:700px) {
    .site-header {
        height: 70px;
        padding: 0 18px
    }

    .logo-placeholder {
        width: 88px;
        height: 38px;
        font-size: 11px
    }

    nav {
        display: none
    }

    .trailer-button {
        margin-left: auto;
        padding: 11px 14px
    }

    .hero {
        min-height: 720px;
        height: auto;
        padding: 130px 20px 70px
    }

    .hero-art {
        inset: 70px 0 0 0;
        opacity: .5
    }

    .hero:after {
        background: linear-gradient(0deg, var(--bg), rgba(16, 11, 24, .45) 70%, rgba(16, 11, 24, .8))
    }

    .hero-copy {
        margin-top: auto
    }

    h1 {
        font-size: 52px
    }

    .hero-actions {
        align-items: flex-start;
        flex-direction: column
    }

    .team-section,
    .about-section,
    .contact-section {
        padding: 75px 18px
    }

    .section-heading {
        display: block
    }

    .team-grid {
        grid-template-columns: 1fr
    }

    .portrait {
        height: 340px
    }

    .about-panel,
    .loadout {
        padding: 24px
    }

    .stats {
        grid-template-columns: 1fr;
        margin-top: 30px;
        gap: 20px
    }

    .about-section-inner {
        grid-template-columns: 1fr
    }

    .contact-section {
        gap: 20px
    }

    footer {
        padding: 22px 18px;
        display: block
    }

    footer span {
        display: block;
        margin: 6px 0
    }
}