@font-face {
    font-family: 'Janeiro';
    src: url('fonts/janeiro/Janeiro-DEMO.otf');
}


.influencer-section {
    background-color: #000;
    padding: 5.556vw 1.389vw 15vw;
    position: relative;
    overflow: hidden;
}

.content-wrapper {
    position: relative;
    min-height: 38.194vw;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
}

.text-container {
    text-align: center;
    z-index: 10;
    margin-bottom: 2.778vw;
}

.find-text {
    font-size: 4.444vw;
    color: #F00101;
    margin-bottom: -1.306vw;
    font-family: Janeiro !important;

}

.collaborate-text {
    font-size: 4vw;
    color: #FFFFFF;
    margin-bottom: 1.389vw;
    font-family: Janeiro !important;
}

.tagline-text {
    font-size: 2.2vw;
    color: #FFFFFF;
    font-family: 'Helvetica Neue', Arial, sans-serif;
    font-weight: 300;
}

.arrow-down {
    width: 1.667vw;
    height: 1.667vw;
    border-right: 0.139vw solid #FFFFFF;
    border-bottom: 0.139vw solid #FFFFFF;
    transform: rotate(45deg);
    margin: 2.083vw auto;
}

/* Character Containers */
.character-wrapper {
    position: absolute;
    width: 15.361vw;
}

.character-container {
    width: 100%;
    height: 100%;
    position: relative;
    border-radius: 0.556vw;
    overflow: visible;
}

.character-bg {
    width: 100%;
    height: 80%;
    position: absolute;
    border-radius: 0.556vw;
    transform: rotate(-5deg);
}

.character-figure {
    position: relative;
    z-index: 2;
    width: 100%;
    height: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
}

.falling-lines {
    position: absolute;
    bottom: -2.569vw;
    left: 50%;
    transform: translateX(-50%);
    display: flex;
    gap: 0.556vw;
    z-index: 3;
    width: 2.986vw;
    height: 6.597vw;
}

.line {
    width: 0.139vw;
    height: 1.389vw;
    background-color: #FFFFFF;
}

/* Top Left Character */
.character-tl {
    top: 0;
    left: 6.472vw;
}

.character-tl .character-bg {
    background: linear-gradient(135deg, #FF6B35 0%, #004E89 100%);
    clip-path: polygon(0 20%, 100% 0%, 100% 80%, 0 100%);
}

.character-tl .head {
    width: 5.556vw;
    height: 5.556vw;
    background-color: #3D2817;
    border-radius: 50%;
    position: relative;
    margin-bottom: 0.694vw;
}

.character-tl .hair {
    width: 6.250vw;
    height: 4.861vw;
    background-color: #000;
    border-radius: 50% 50% 50% 50% / 60% 60% 40% 40%;
    position: absolute;
    top: -2.778vw;
    left: -0.347vw;
}

.character-tl .hair::after {
    content: 'M';
    position: absolute;
    top: 1.042vw;
    left: 1.389vw;
    color: #FFD700;
    font-size: 2.083vw;
    font-weight: bold;
}

.character-tl .earring {
    width: 0.556vw;
    height: 0.556vw;
    background-color: #FFFFFF;
    border-radius: 50%;
    position: absolute;
    left: -0.347vw;
    top: 2.083vw;
}

.character-tl .mouth {
    width: 1.389vw;
    height: 0.139vw;
    background-color: #FFFFFF;
    position: absolute;
    bottom: 1.042vw;
    left: 50%;
    transform: translateX(-50%);
}

/* Top Right Character */
.character-tr {
    top: 0;
    right: 7.472vw;
}

.character-tr .character-bg {
    background-color: #E8D5B7;
}

.character-tr .head {
    width: 5.556vw;
    height: 5.556vw;
    background-color: #3D2817;
    border-radius: 50%;
    position: relative;
    margin-bottom: 0.694vw;
}

.character-tr .halo {
    width: 6.944vw;
    height: 6.944vw;
    border: 0.208vw solid #F00101;
    border-radius: 50%;
    position: absolute;
    top: -1.042vw;
    left: -0.694vw;
}

.character-tr .eye-x {
    position: absolute;
    top: 2.083vw;
    font-size: 1.667vw;
    color: #FFD700;
    font-weight: bold;
}

.character-tr .eye-x.left {
    left: 1.389vw;
}

.character-tr .eye-x.right {
    right: 1.389vw;
}

.character-tr .mouth {
    width: 1.389vw;
    height: 0.139vw;
    background-color: #FFFFFF;
    position: absolute;
    bottom: 1.042vw;
    left: 50%;
    transform: translateX(-50%);
}

/* Bottom Left Character */
.character-bl {
    bottom: 0;
    left: 7.472vw;
}

.character-bl .character-bg {
    background: linear-gradient(90deg, #DC143C 0%, #FF6B35 100%);
}

.character-bl .head {
    width: 5.556vw;
    height: 5.556vw;
    background-color: #3D2817;
    border-radius: 50%;
    position: relative;
    margin-bottom: 0.694vw;
}

.character-bl .hair {
    width: 5.903vw;
    height: 3.472vw;
    background-color: #000;
    border-radius: 50% 50% 50% 50% / 60% 60% 40% 40%;
    position: absolute;
    top: -2.083vw;
    left: -0.139vw;
}

.character-bl .eye-mark {
    position: absolute;
    top: 2.083vw;
    font-size: 1.389vw;
    color: #FFFFFF;
    font-weight: bold;
}

.character-bl .eye-mark.left {
    left: 1.389vw;
}

.character-bl .eye-mark.right {
    right: 1.389vw;
}

.character-bl .mouth-styled {
    position: absolute;
    bottom: 1.042vw;
    left: 50%;
    transform: translateX(-50%);
    display: flex;
    flex-direction: column;
    gap: 0.139vw;
    align-items: center;
}

.character-bl .mouth-styled .line-h {
    width: 1.389vw;
    height: 0.139vw;
    background-color: #FFFFFF;
}

.character-bl .mouth-styled .line-v {
    width: 0.139vw;
    height: 0.556vw;
    background-color: #FFFFFF;
}

.character-bl .chest-stripes {
    position: absolute;
    bottom: -1.389vw;
    left: 50%;
    transform: translateX(-50%);
    display: flex;
    flex-direction: column;
    gap: 0.278vw;
}

.character-bl .stripe {
    width: 4.167vw;
    height: 0.139vw;
    background-color: #FFFFFF;
}

/* Bottom Right Character */
.character-br {
    bottom: 0;
    right: 5.472vw;
}

.character-br .character-bg {
    background: linear-gradient(90deg, #FF6B35 0%, #6A0DAD 100%);
}

.character-br .head {
    width: 5.556vw;
    height: 5.556vw;
    background-color: #3D2817;
    border-radius: 50%;
    position: relative;
    margin-bottom: 0.694vw;
}

.character-br .hair {
    width: 6.250vw;
    height: 4.167vw;
    background-color: #000;
    border-radius: 50% 50% 50% 50% / 60% 60% 40% 40%;
    position: absolute;
    top: -2.431vw;
    left: -0.347vw;
    clip-path: polygon(20% 0%, 80% 0%, 90% 50%, 50% 100%, 10% 50%);
}

.character-br .face-decoration {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

.character-br .decoration-dot {
    position: absolute;
    width: 0.417vw;
    height: 0.417vw;
    border-radius: 50%;
}

.character-br .decoration-dot.yellow {
    background-color: #FFD700;
    top: 1.389vw;
    left: 1.042vw;
}

.character-br .decoration-dot.pink {
    background-color: #FF69B4;
    top: 2.083vw;
    left: 2.431vw;
}

.character-br .decoration-dot.blue {
    background-color: #87CEEB;
    top: 1.736vw;
    right: 1.389vw;
}

.character-br .decoration-dot.green {
    background-color: #90EE90;
    bottom: 2.083vw;
    left: 1.736vw;
}

.character-br .shirt {
    position: absolute;
    bottom: -2.083vw;
    left: 50%;
    transform: translateX(-50%);
    width: 4.861vw;
    height: 2.778vw;
}

.character-br .shirt-body {
    width: 100%;
    height: 80%;
    background: repeating-linear-gradient(0deg,
            #000 0px,
            #000 0.278vw,
            #FFFFFF 0.278vw,
            #FFFFFF 0.556vw);
    border-radius: 0.278vw;
}

.character-br .shirt-collar {
    position: absolute;
    top: -0.556vw;
    left: 50%;
    transform: translateX(-50%);
    width: 4.167vw;
    height: 0.833vw;
    background: linear-gradient(90deg, #6A0DAD 0%, #004E89 100%);
    clip-path: polygon(20% 0%, 80% 0%, 100% 100%, 0% 100%);
}








.profile-section {
    background-color: black;
    padding: 2.778vw 3.125vw;
    margin-bottom: 15vw;
}

.profile-section .profile-wrapper {
    background-color: #ECECEC;
    padding: 2.083vw 4.514vw;
    border-radius: 2.083vw;
}

.profile-section .profile-card {
    border-radius: 2.5vw;
    overflow: hidden;
    box-shadow: 0 0.278vw 0.278vw rgba(0, 0, 0, 0.25);
    height: 100%;
    padding: 2.083vw;
    background-color: #FFFFEA;
}

.profile-section .profile-img {
    width: 100%;
    height: 23.611vw;
    object-fit: cover;
    border-radius: 2.222vw;
}

.profile-section .profile-content {
    padding: 1.736vw 0px 0px 0px;
}

.profile-section .profile-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 1.042vw;
    border-bottom: 0.069vw solid #ECECEC;
}

.profile-section .profile-name {
    display: flex;
    align-items: center;
    gap: 0.556vw;
    font-weight: 600;
    font-size: 1.667vw;
    color: black;
}

.profile-section .verified-badge {
    color: #1DA1F2;
    font-size: 1.25vw;
}

.profile-section .profile-role {
    font-size: 1.181vw;
    color: #B1B1B1;
    margin-top: -0.556vw;
}

.profile-section .follower-count {
    text-align: right;
}

.profile-section .follower-number {
    font-weight: 600;
    font-size: 1.667vw;
    color: black;
}

.profile-section .follower-label {
    font-size: 1.181vw;
    color: #B1B1B1;
    margin-top: -0.556vw;
    margin-bottom: 0.347vw;
}

.profile-section .social-icons {
    display: flex;
    gap: 0.278vw;
}

.profile-section .social-icon {
    width: 1.389vw;
    height: 1.389vw;
    border-radius: 0.278vw;
    background-color: #FFFFEA;
    border: 0.069vw solid black;
    display: flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
    color: black;
    transition: all 0.3s;
    font-size: 0.694vw;
}

.profile-section .price-btn {
    background-color: #F00101;
    color: white;
    border: none;
    border-radius: 0.556vw;
    padding: 0.417vw 0.972vw;
    transition: all 0.3s;
    margin-left: 1.042vw;
    font-size: 1vw;
}

.profile-section .price-btn:hover {
    background-color: #c82333;
    color: white;
}

.profile-section .footer-section {
    display: flex;
    align-items: center;
    justify-content: space-between;
}

/* Desktop Profile Grid - Hidden on Mobile */
.profile-section .desktop-profile-grid {
    display: flex;
}

/* Mobile Profile Carousel - Hidden on Desktop */
.profile-section .mobile-profile-carousel {
    display: none;
}

/* Mobile Carousel Container */
.profile-section .profile-carousel-container {
    display: flex;
    overflow-x: auto;
    gap: 5.333vw;
    padding: 0 4.267vw 5.333vw;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    -ms-overflow-style: none;
}

.profile-section .profile-carousel-container::-webkit-scrollbar {
    display: none;
}

.profile-section .profile-card-wrapper {
    flex: 0 0 calc(100% - 8.533vw);
    scroll-snap-align: start;
    max-width: calc(100vw - 8.533vw);
}

/* Carousel Indicators */
.profile-section .carousel-indicators {
    position: relative;
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 2.133vw;
    display: none;
    margin-bottom: 0px;
}

.profile-section .indicator {
    width: 2.133vw;
    height: 2.133vw;
    border-radius: 50%;
    background-color: #D9D9D9;
    cursor: pointer;
    transition: all 0.3s ease;
}

.profile-section .indicator.active {
    width: 6.400vw;
    height: 2.133vw;
    border-radius: 1.067vw;
    background-color: #B1B1B1;
}

.profile-section .desktop-margin-top {
    margin-top: 3.472vw;
}

/* Mobile Responsive */
@media (max-width: 767.98px) {
    .profile-section .desktop-margin-top {
        margin-top: 0px;
    }

    .profile-section .desktop-profile-grid {
        display: none;
    }

    .profile-section .mobile-profile-carousel {
        display: block;
    }

    .profile-section .profile-wrapper {
        padding: 8.000vw 0;
    }

    .profile-section .profile-card {
        padding: 5.333vw;
    }

    .profile-section .profile-img {
        height: 74.667vw;
        border-radius: 4.800vw;
    }

    .profile-section .profile-name {
        font-size: 5.333vw;
    }

    .profile-section .profile-role {
        font-size: 4.000vw;
    }

    .profile-section .follower-number {
        font-size: 5.333vw;
    }

    .profile-section .follower-label {
        font-size: 4.000vw;
    }

    .profile-section .social-icon {
        width: 4.800vw;
        height: 4.800vw;
        font-size: 2.400vw;
    }

    .profile-section .price-btn {
        padding: 1.333vw 3.200vw;
        font-size: 3.733vw;
    }
}

@media (max-width: 575.98px) {
    .profile-section .profile-img {
        height: 64.000vw;
    }

    .profile-section {
        padding: 0px;
        margin-bottom: 20vw;
    }

    .profile-section .carousel-indicators {
        display: flex;
    }

    .profile-section .profile-name {
        font-size: 4.800vw;
    }

    .profile-section .profile-wrapper {
        border-radius: 0px;
        background-color: black;
    }

    .profile-section .profile-role {
        font-size: 3.733vw;
    }

    .profile-section .follower-number {
        font-size: 4.800vw;
    }

    .profile-section .follower-label {
        font-size: 3.733vw;
    }

    .character-wrapper {
        position: absolute;
        width: 30.361vw;
    }

    .collaborate-text {
        font-size: 6.667vw;
    }

    .find-text {
        font-size: 8.444vw;
    }

    .tagline-text {
        font-size: 3.667vw;
    }

    .content-wrapper {
        min-height: 100.194vw;
    }


    .profile-section .social-icon {
        width: 4.5vw;
        height: 4.5vw;
        font-size: 2.6vw;
    }

    .character-bl {
        left: 0vw;
    }

    .character-tr {
        right: 0vw;
    }

    .influencer-section {
        padding: 10.556vw 1.389vw 20vw;
    }

    .character-br {
        right: 0vw;
    }

    .arrow-down {
        width: 3.667vw;
        height: 3.667vw;
    }

    .falling-lines {
        bottom: -9.569vw;
        width: 4.986vw;
        height: 14.597vw;
    }

    .character-tl {
        left: 0vw;
    }

    .profile-section .social-icons {
        gap: 1.278vw;
    }

    .profile-section .price-btn {
        padding: 1.067vw 2.667vw;
        font-size: 3.467vw;
        margin-left: 2.667vw;
    }

    .profile-section .profile-card-wrapper {
        flex: 0 0 calc(100% - 8.533vw);
    }
}