@font-face {
    font-family: 'MonumentExtended';
    src: url('../fonts/MonumentExtended-Ultrabold.ttf') format('truetype');
    font-weight: bold;
    font-style: normal;
}

@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@300..700&display=swap');

body {
    background-color: #000000;
}

header {
    background-color: transparent !important;
    position: static !important;
}

header .bg-menu {
    background-image: none !important;
    position: static !important;
}

.circle-header {
    display: flex;
    justify-content: center;
    align-items:center;
    padding: 20px 25px;
    background-color: #1B1B1B;
    border-radius: 100px;
}

.header-checkout-img {
    width: 100px;
    height: auto;
}
.img-left {
    width: 8px;
}


/* Contêiner da imagem de fundo */
.background-container {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-image: url('https://media.r2.com.vc/uploads/2024/12/Group-3360925.png');
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    filter: blur(60px);
    z-index: -2;
}

/* Sobreposição escura */
.dark-overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    min-height: 150vh; /* Garante que cobre metade da altura do viewport */
    height: auto; /* Adapta-se ao conteúdo, caso seja maior que o viewport */
    background: rgba(0, 0, 0, 0.8); /* Escurece o fundo */
    z-index: 0;
}

section.principal {
    position: relative;
    z-index: 1;
    color: white;
    min-height: 100vh;
    padding: 25px 0 50px 0;
}

html body p,
html body h1,
html body h2,
html body h3,
html body span,
html body label,
html body a {
    font-family: Space Grotesk, sans-serif !important;
    color: #FFFFFF !important;
}

html body .title {
    font-weight: 700;
    font-size: 24px;
}

.extra-lg-title {
    font-family: 'MonumentExtended', sans-serif !important;
    font-size: 32px;
    font-weight: 800;
    line-height: 40px;
    text-align: left;
    margin-bottom: 16px;
    text-transform: uppercase;
}

html body .subtitle {
    font-weight: 700;
    font-size: 18px;
}

html body .description {
    font-weight: 500;
    font-size: 13px;
}

html body .description-small {
    font-weight: 400;
    font-size: 10px;
}

html body p {
    font-weight: 400;
    font-size: 15px;
    margin: 0;
}

html body a {
    font-weight: 700 !important;
}

html body .small-title {
    font-weight: 700;
    font-size: 16px;
}

.checkbox-label {
    font-weight: 400;
    font-size: 14px;
}

html body .font-40 {
    font-size: 40px;
    font-weight: 500;
}

html body .checkout-payment p,
html body .checkout-payment h1,
html body .checkout-payment span,
html body .checkout-payment label {
    color: #000000 !important;
}

html body button {
    border-radius: 2px;
    opacity: 1;
    gap: 10px;
    padding: 10px  15px;
    color: #FFFFFF;
    background-color: #2D2D2D;
    border: none;
    font-family: Space Grotesk;
    font-weight: 500;
    font-size: 15px;
}

html body button.rounded {
    border-radius: 100px !important;
    opacity: 1;
    padding: 17px 40px;
}

.btn-pink {
    background-color: #e3409e;
    color: #FFFFFF;
}

.btn.desactive {
    background-color: #BABABA !important;
    color: #FFFFFF;
    cursor: auto;
}

/*BREADCRUMB*/
.breadcrumb-custom{
    z-index: 9;
}

.breadcrumb-custom p{
    margin: 0;
    display: flex;
    align-items: center;
    gap: 8px;
}

/* chevron-bottom.svg aponta pra baixo -> gira pra direita */
.breadcrumb-custom .chevron-right{
    width: 12px;
    height: 12px;
    transform: rotate(-90deg);
    display: inline-block;
}
/*FIM*/

.item-content {
    border-radius: 9px;
    border: 1px solid #222222;
    background-color: rgba(0, 0, 0, 0.2);
    padding: 24px;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

html body  input.input-text {
    border-radius: 3px;
    border: 1px solid #A2A2A2;
    opacity: 1;
    gap: 10px;
    padding: 13px 18px;
    background-color: #FFFFFF;
    font-family: Space Grotesk;
    font-weight: 400;
    font-size: 14px;
}

html body  input.input-text::placeholder {
    font-family: Space Grotesk;
    color: #BABABA;
    font-weight: 400;
    font-size: 14px;
}

.opacity-100 {
    opacity: 1 !important;
    background-color: #111111 !important;
}

.timer {
    background-color: #FFFFFF;
    color: #000000 !important;
    padding: 12px 10px;
    border-radius: 4px;
}

.tumb {
    width: 157px;
    height: 110px;
    border-radius: 6px;
    object-fit: cover;
}

.tumb-cart {
    width: 157px;
    height: 110px;
    border-radius: 6px;
    object-fit: cover;
}

.linha {
    width: 100%;
    height: 1px;          /* espessura da linha */
    background: #FFFFFF;      /* cor da linha */
    margin: 11px 0;        /* espaço em cima e embaixo */
}

.ellipsis {
    width: 200px;           /* define uma largura */
    white-space: nowrap;    /* tudo em uma linha só */
    overflow: hidden;       /* esconde o que passa */
    text-overflow: ellipsis;/* coloca os "..." */
}

.ellipsis-cart {
    width: 270px;           /* define uma largura */
    white-space: nowrap;    /* tudo em uma linha só */
    overflow: hidden;       /* esconde o que passa */
    text-overflow: ellipsis;/* coloca os "..." */
}

.fixed-bottom-bar {
    position: fixed;
    left: 0;
    bottom: 0;
    width: 100%;          /* ocupa a largura toda */
    background: #111;     /* cor de fundo */
    color: #fff;
    padding: 10px 16px;
    z-index: 9999;        /* fica por cima do resto */
}

.dark-badge {
    opacity: 1;
    border-radius: 50px;
    border: 1px solid #242424;
    padding: 7px 15px;
    color: #FFFFFF;
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 8px;
    width: fit-content;
}

.white-badge {
    opacity: 1;
    border-radius: 50px;
    border: 1px solid #242424;
    padding: 7px 15px;
    color: #000000;
    background-color: #FFFFFF;
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 8px;
    width: fit-content;
}

.white-badge p {
    color: #000000 !important;
}

.btn-white {
    background-color: #FFFFFF;
    color: #000000;
}

.input-cupom-mobile {
    background-color: transparent !important;
    color: #FFFFFF !important;
    border: 1px solid #474747;
}

.input-cupom-mobile::placeholder {
    color: #FFFFFF !important;
}

.btn-cupom-mobile {
    border-radius: 6px;
}

#seta-detalhes-carrinho.aberto {
    transform: rotate(180deg);
}

.detalhes-carrinho-mobile {
    position: fixed;
    left: 0;
    bottom: 0;
    width: 100%;
    background-color: #000000 !important;
    padding: 20px;
    z-index: 999999;
    border-top: 1px solid #222222;
}

/*footer elementor*/
.elementor.elementor-3362471 {
    z-index: 1 !important;
}

.elementor-element-daf809b,
.elementor-element-5a51e1c {
    display: none !important;
}

.margin-bottom-cart-politicas {
    margin-bottom: 8px;
}

/* abaixo de md */
@media (max-width: 768px) {
    section.principal {
        padding: 17px 0;
    }

    .circle-header {
        padding: 5px 17px;
    }

    .header-checkout-img {
        width: 80px;
    }

    .img-left {
        width: 8px;
    }

    .extra-lg-title {
        font-size: 21px;
        font-weight: 800;
        line-height: 25px;
    }

    .ellipsis {
        width: 120px;
    }

    .ellipsis-cart {
        width: 220px;
    }

    html body .subtitle {
        font-size: 16px;
    }

    html body p {
        font-size: 13px !important;
    }

    html body .small-title {
        font-size: 16px;
    }

    .margin-bottom-cart-politicas {
        margin-bottom: 200px;
    }
}

/*tables para baixo*/
@media (max-width: 991px) {
    .tumb-cart {
        width: 100%;
        height: 110px;
    }
}

/* lg */
@media (min-width: 992px) {
    .min-vh-lg-100 {
        min-height: 100vh;
    }
}


/*ACCORDION*/
.payment-accordion .pm-label{
    color: #898989 !important;
    font-weight: 500 !important;
}
.payment-accordion .accordion-item.pm-selected .pm-label{
    color: #000000 !important;
    font-weight: 500 !important;
}

/* bolinha tipo radio (sem “anel branco”) */
.payment-accordion .pm-dot{
    width: 18px;
    height: 18px;
    border-radius: 50%;
    border: 2px solid #cfcfcf;
    background: #fff;
    flex: 0 0 18px;
}
.payment-accordion .pm-dot.is-selected{
    border-color: #000;
    background: #000;
}

/* Faz o radio ficar "normal" e bonito */
.payment-accordion input[type="radio"]{
    appearance: auto !important;
    -webkit-appearance: auto !important;

    width: 18px;
    height: 18px;
    margin: 0;

    accent-color: #000000;
}

.payment-accordion .pm-label{
    color: #898989 !important;
}

.payment-accordion .pm-selected .pm-label{
    color: #000000 !important;
}

html body .accordion-body {
    padding: 5px 28px 30px 28px !important;
}

.payment-accordion {
    border: 1px solid #dee2e6;
    border-radius: .5rem;
    overflow: hidden;
}

.payment-accordion .accordion-item {
    border: 0;
}

.payment-accordion .accordion-item + .accordion-item {
    border-top: 1px solid #dee2e6;
}

.payment-accordion .accordion-button {
    background: #fff;
    box-shadow: none;
    padding: 35px 25px;
}

.payment-accordion .accordion-button:focus {
    box-shadow: none;
}

/* remove a setinha padrão do accordion */
.payment-accordion .accordion-button::after {
    display: none;
}

/* deixa o radio alinhadinho e com espaçamento */
.payment-accordion .form-check {
    gap: 12px;
}

.payment-accordion .form-check-input {
    margin-top: 0;
}

/*INPUTS CARTAO*/
.card-input-group {
    border: 1px solid #d9d9d9;
    border-radius: 10px;
    overflow: hidden;
    background: #fff;
}

/* Linhas */
.cig-row {
    display: flex;
    align-items: center;
}

.cig-row-top {
    padding: 14px 16px;
    border-bottom: 1px solid #d9d9d9;
}

.cig-row-bottom {
    display: flex;
}

.cig-col {
    flex: 1;
    padding: 14px 16px;
}

.cig-col-left {
    border-right: 1px solid #d9d9d9;
}

.cig-input {
    border: 0 !important;
    padding: 0 !important;
    box-shadow: none !important;
    outline: none !important;
    font-size: 16px;
    color: #333;
    background: transparent;
}

.cig-input::placeholder {
    color: #9a9a9a;
}

.cig-brands {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-left: 12px;
    flex-shrink: 0;
}

.cig-brands img {
    height: 11px;
    width: auto;
    display: block;
}

/*INPUTS ENDERECO*/
.address-group {
    border: 1px solid #d9d9d9;
    border-radius: 10px;
    overflow: hidden;
    background: #fff;
}

.ag-row {
    padding: 14px 16px;
}

.ag-row-top {
    border-bottom: 1px solid #d9d9d9;
}

/* deixa o select sem “cara de select” pq o select2 vai renderizar */
.ag-select {
    border: 0 !important;
    padding: 0 !important;
    box-shadow: none !important;
    background: transparent !important;
}

/* input sem borda */
.ag-input {
    border: 0 !important;
    padding: 0 !important;
    box-shadow: none !important;
    outline: none !important;
    font-size: 16px;
}

/* ===== Select2: “esconde” a cara do select2 e deixa igual ao print ===== */
.select2-container {
    width: 100% !important;
}

.select2-container .select2-selection--single {
    height: auto !important;
    border: 0 !important;
    border-radius: 0 !important;
    padding: 0 !important;
}

.select2-container .select2-selection__rendered {
    padding: 0 !important;
    line-height: normal !important;
}

.select2-container .select2-selection__arrow {
    height: 100% !important;
    right: 0 !important;
}

.select2-results__option .fi,
.select2-selection__rendered .fi {
    position: relative;
    top: 1px;
    width: 20px;
    height: 18px;
    border-radius: 4px;
}

.select2-results__option {
    padding-top: 10px !important;
    padding-bottom: 10px !important;
}

html body .select2-selection__rendered span,
html body .select2-results__option span {
    color: #000000 !important;
    font-size: 16px;
}

/* Label padrão igual seu cinza do print */
.ag-label {
    color: #adb5bd;
    font-size: 13px;
    margin-bottom: 6px;
    display: block;
}

.ag-row {
    padding: 14px 16px;
    display: flex;
    flex-direction: column;
}

.ag-row-divider {
    border-top: 1px solid #d9d9d9;
}

/* linha com 2 colunas */
.ag-row-split {
    flex-direction: row;
    padding: 0; /* padding vai nas colunas */
}

.ag-col {
    flex: 1;
    padding: 14px 16px;
    display: flex;
    flex-direction: column;
}

.ag-col-left {
    border-right: 1px solid #d9d9d9;
}

/*FIM*/

/*MODAL PIX*/
.pix-modal-dialog {
    max-width: 420px;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
}

/* Logo fora do card, centralizada acima */
.pix-badge-outside {
    position: relative !important;
    top: 0 !important;
    left: auto !important;
    transform: none !important;
    margin-top: 20px;
    margin-bottom: 25px;
    z-index: 10 !important;
    box-shadow: 0 10px 25px rgba(0,0,0,.25);
}

.pix-modal-content {
    border: 0;
    border-radius: 18px;
    background: #fff;
    box-shadow: 0 20px 60px rgba(0,0,0,.35);
    position: relative;
    overflow: hidden; /* impede “vazar” */
}

/* botão X */
.pix-close {
    position: absolute;
    top: 16px;
    right: 16px;
    opacity: .6;
    z-index: 3;
}
.pix-close:hover { opacity: .9; }

/* logo dentro do modal */
.pix-badge {
    position: absolute;
    top: 14px;                 /* dentro */
    left: 50%;
    transform: translateX(-50%);
    width: 38px;
    height: 38px;
    border-radius: 999px;
    background: #F4B400;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 2;
}
.pix-badge img {
    width: 22px;
    height: 22px;
    object-fit: contain;
}

/* corpo com espaço pra badge */
.pix-body {
    padding: 60px 34px 28px; /* top maior pra não colidir */
}

.pix-title {
    font-weight: 700;
    color: #111;
    margin: 0 0 8px 0;
    font-size: 16px;
}

.pix-subtitle {
    font-size: 12.5px;
    color: #666;
    line-height: 1.4;
    margin: 0 0 14px 0;
}

/* timer */
.pix-timer {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 16px;
}

.pix-time-box {
    min-width: 36px;
    height: 32px;
    border-radius: 6px;
    background: #F2F2F2;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    color: #111;
    font-size: 13px;
}

.pix-time-sep {
    color: #999;
    font-weight: 700;
}

/* QR */
.pix-qr-wrapper {
    background: #F6F6F6;
    border-radius: 12px;
    padding: 14px;
    display: inline-flex;
    justify-content: center;
    align-items: center;
    margin-bottom: 14px;
}

.pix-qr {
    width: 210px;
    height: 210px;
    display: block;
}

/* copia e cola */
.pix-copy-input {
    font-size: 11px;
    padding: 10px 12px;
    border-radius: 6px;
    border: 1px solid #8E8E8E;
    background-color: #FFFFFF !important;
    margin-bottom: 14px;
}

/* botão */
.pix-copy-btn {
    margin-top: auto;
    background: #2B2B2B;
    color: #fff;
    border-radius: 999px;
    padding: 14px 18px;
    font-weight: 500;
    font-size: 16px;
}
.pix-copy-btn:hover {
    background: #1f1f1f;
    color: #fff;
}

/* rodapé */
.pix-footer {
    font-size: 11px;
    color: #ffffff;
    line-height: 1.4;
    margin: 14px 0 0 0;
}

.modalCheckout {
    background-color: #000000d6;
    padding-right: 0 !important;
}

/* ====== RESET FORÇADO DO MODAL PIX ====== */
.modalCheckout .pix-modal-content {
    background: #fff !important;
    color: #111 !important;
}

.modalCheckout .pix-modal-content * {
    color: #111 !important; /* força tudo preto */
}

.modalCheckout .pix-footer-outside {
    color: rgb(255, 255, 255) !important;
}

.modalCheckout .pix-subtitle{
    color: #292929 !important;
}

.modalCheckout .pix-footer {
    color: #ffffff !important;
}

.modalCheckout .pix-copy-btn,
.modalCheckout .pix-copy-btn * {
    color: #fff !important; /* texto e ícone do botão */
}

/* garante alinhamento e espaçamento */
.modalCheckout .pix-body {
    text-align: center !important;
    padding: 38px 34px 28px !important; /* mais espaço pro badge */
}

/* badge (logo) não pode empurrar/atrapalhar texto */
.modalCheckout .pix-badge {
    top: 18px !important;
    z-index: 3 !important;
    margin-bottom: 40px;
}

/* Footer fora do card: texto branco/cinza em cima do backdrop */
.pix-footer-outside {
    margin-top: 12px !important;
    text-align: center !important;
    font-size: 11px !important;
    line-height: 1.4 !important;
    color: rgba(255, 255, 255, 0.75) !important;
}

/* título e subtítulo aparecem SEMPRE */
.modalCheckout .pix-title {
    font-weight: 700 !important;
    font-size: 20px !important;
    margin: 0 0 8px 0 !important;
    color: #111 !important;
}

.modalCheckout .pix-subtitle {
    display: block !important;
    margin: 0 0 14px 0 !important;
}

/* timer centralizado */
.modalCheckout .pix-timer {
    display: inline-flex !important;
    justify-content: center !important;
    margin: 0 0 16px 0 !important;
}

/* evita modal gigante com "área vazia" */
.modalCheckout .pix-modal-content,
.modalCheckout .modal-body {
    display: flex;
    flex-direction: column;
    height: auto !important;
}

.modal-body.min-height {
    min-height: 620px;
}

.summary-table {
    border: 1px solid #d9d9d9;
    border-radius: 12px;
    overflow: hidden;
    background: #fff;
}

.st-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 14px 12px;
    border-top: 1px solid #d9d9d9;
}

.st-row:first-child {
    border-top: 0;
}

.st-label {
    font-size: 22px;
    color: #7a7a7a;
    font-weight: 500;
}

.st-value {
    max-width: 65%;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

/*FIM*/

/*DETALHES CHECKOUT MOBILE*/
.stack-cards{
    position: relative;
    width: 196px;
    height: 130px;
}

/* card base */
.stack-card{
    position: absolute;
    inset: 0;
    border-radius: 14px;
    overflow: hidden;
    box-shadow: 0 12px 30px rgba(0,0,0,.35);

    /* controla empilhamento */
    z-index: calc(100 - var(--i));

    /* efeito “álbum”: cada um vai pra trás (offset) e fica menor (scale) */
    transform:
            translate(calc(var(--i) * -29px), calc(var(--i) * -22px))
            scale(calc(1 - (var(--i) * 0.05)));

    opacity: 1;
}

.stack-card img{
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.details-btn{
    width: 165px;                 /* ajuste */
    height: 44px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;

    padding: 0 16px;
    border: 1px solid rgba(255,255,255,.08);
    border-radius: 10px;

    background: rgba(34,34,34,.85);
    color: #fff;
    font-weight: 600;
    font-size: 14px;

    box-shadow: 0 10px 30px rgba(0,0,0,.35);
    cursor: pointer;
}

.details-btn:hover{
    background: rgba(40,40,40,.92);
}

.details-btn:active{
    transform: translateY(1px);
}

.details-btn-icon{
    opacity: .9;
    transition: transform .2s ease;
}

/* aberto -> seta pra cima */
.details-btn.is-open .details-btn-icon{
    transform: rotate(180deg);
}

#paymentSuccessAnim {
    display: flex;
    justify-content: center;
}

html body .gifModalCheckout svg {
    width: 230px !important;
    height: auto;
}

/* abaixo de md */
@media (max-width: 768px) {
    html body .gifModalCheckout svg {
        width: 192px !important;
    }
}

/*MODAL ARTISTAS*/
.check-artist-button {
    border-radius: 100px;
    border: 1px solid #E9E9E9;
    padding: 15px;
    gap: 10px;
    background-color: #FFFFFF;
    color: #000000;
    text-transform: uppercase;
    font-family: Space Grotesk, sans-serif !important;
    font-weight: 700;
    font-size: 15px;
}

.check-artist-button.checked {
    background-color: #000000;
    color: #FFFFFF !important;
}

/*ORDER BUMP*/
.checkout-ob-card {
    min-width: 259px;
    max-width: 259px;
    border-radius: 16px;
    padding: 12px;
    background-color: #141414CC;
}

.checkout-ob-card-title {
    font-size: 15px !important;
    font-weight: 600;
}

.checkout-ob-card-image {
    width: auto;
    height: 140px;
    background-color: #E2E2E2;
    border-radius: 8px;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
}

.checkout-ob-card-button {
    border-radius: 66px;
    border: 1px solid #FFFFFF;
    padding: 10px 40px;
    font-weight: 700;
    font-size: 13px;
}