* {
    box-sizing: border-box;
}

#carrito {
    --color-yellow: #ffc107;
    --color-yellow-soft: #ffd54f;
    --color-bg: #050505;
    --color-bg-2: #0b0b0b;
    --color-panel: rgba(14, 14, 14, 0.92);
    --color-panel-2: rgba(8, 8, 8, 0.96);
    --color-border: rgba(255, 193, 7, 0.16);
    --color-border-strong: rgba(255, 193, 7, 0.32);
    --color-text: #ffffff;
    --color-text-soft: #d0d0d0;
    --color-text-muted: #9e9e9e;

    min-height: 75vh;
    color: var(--color-text);
    overflow: hidden;
    background:#0f0f0f;
}

.carrito-wrap {
    width: 1300px;
    max-width: 90%;
    margin: 0px auto;
    position: relative;
    z-index: 2;
}

.carrito-head {
    position: relative;
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 18px;
    align-items: center;
    margin: 30px auto;
    padding: 30px 34px;
    border-radius: 30px;
    background:rgba(15, 15, 15, 0.96);
    border: 1px solid var(--color-border);
    overflow: hidden;
}

.carrito-head h1 {
    margin: 0;
    font-size: clamp(2.2rem, 4vw, 4rem);
    line-height: 0.96;
    font-weight: 900;
    letter-spacing: -1.6px;
    color: #fff;
    position: relative;
    z-index: 1;
}

.btn-principal,
.btn-secundario,
.btn-eliminar {
    padding: 10px;
    height: 34px;
    border-radius: 14px;
    border: none;
    font-family: inherit;
    font-size: 0.98rem;
    font-weight: 900;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: transform 0.24s ease, border-color 0.24s ease, filter 0.24s ease, background 0.24s ease;
}

.btn-principal {
    color: #111;
    background: rgb(255, 196, 0);
}

.btn-principal:hover {
    transform: translateY(-2px);
    filter: brightness(1.03);
}

.btn-secundario {
    color: var(--color-yellow);
    background: rgba(255, 255, 255, 0.02);
    border: 1px solid rgba(255, 193, 7, 0.2);
    padding: 7px;
}

.btn-secundario:hover {
    transform: translateY(-2px);
    border-color: rgba(255, 193, 7, 0.48);
}

.btn-eliminar {
    width: 100%;
    color: #ff9d9d;
    background: rgba(255, 74, 74, 0.08);
    border: 1px solid rgba(255, 84, 84, 0.18);
}

.btn-eliminar:hover {
    transform: translateY(-2px);
    background: rgba(255, 74, 74, 0.12);
    border-color: rgba(255, 84, 84, 0.3);
}

.carrito-vacio {
    position: relative;
    padding: 72px 28px;
    border-radius: 32px;
    text-align: center;
    background: rgba(15, 15, 15, 0.96);
    border: 1px solid var(--color-border);
    overflow: hidden;
}

.carrito-vacio::before,
.carrito-vacio::after {
    content: "";
    position: absolute;
    border-radius: 28px;
    border: 1px solid rgba(255, 193, 7, 0.08);
    pointer-events: none;
}

.carrito-vacio::before {
    inset: 18px;
}

.carrito-vacio::after {
    inset: 36px;
    opacity: 0.5;
}

.carrito-vacio h2 {
    margin: 0 0 12px;
    font-size: clamp(1.9rem, 3vw, 3rem);
    font-weight: 900;
    color: #fff;
    position: relative;
    z-index: 1;
}

.carrito-vacio p {
    margin: 0 0 24px;
    color: var(--color-text-soft);
    font-size: 1.04rem;
    line-height: 1.7;
    position: relative;
    z-index: 1;
}

.carrito-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.55fr) minmax(320px, 430px);
    gap: 30px;
    align-items: start;
}

.carrito-lista {
    display: grid;
    gap: 22px;
}

.carrito-item {

    position: relative;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 10px;
    align-items: start;
    padding: 22px;
    border-radius: 30px;
    overflow: hidden;


    background:rgba(8, 8, 8, 0.98);
    border: 1px solid rgba(255, 193, 7, 0.14);
    overflow: hidden;
    transition: transform 0.28s ease,
        border-color 0.28s ease;
}


.carrito-item:hover {
    transform: translateY(-4px);
    border-color: var(--color-border-strong);
}

.carrito-item-img {
    justify-self: center;
    position: relative;
    border-radius: 24px;
    overflow: hidden;
    background: #090909;
    border: 1px solid rgba(255, 193, 7, 0.12);
    aspect-ratio: 1 / 1;
}


.carrito-item-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform 0.42s ease, opacity 0.32s ease;
}

.carrito-item:hover .carrito-item-img img {
    transform: scale(1.05);
    opacity: 0.96;
}

.carrito-item-info {
    height: 100%;
    display: flex;
    flex-direction: column;
    justify-content: space-around;
    gap: 10px;

}

.marca {
    display: inline-flex;
    align-items: center;
    width: fit-content;
    padding: 8px 14px;
    border-radius: 999px;
    background: rgba(255, 193, 7, 0.08);
    border: 1px solid rgba(255, 193, 7, 0.22);
    color: var(--color-yellow);
    font-size: 0.8rem;
    font-weight: 900;
    letter-spacing: 1px;
    text-transform: uppercase;
}

.carrito-item-info h3 {
    margin: 0;
    font-size: 1.46rem;
    line-height: 1.14;
    font-weight: 900;
    letter-spacing: -0.6px;
    color: #fff;
}

.precio-unitario {
    margin: 0;
    width: fit-content;
    padding: 10px 14px;
    border-radius: 14px;
    color: #f0f0f0;
    background:rgba(255, 193, 7, 0.08);
    border: 1px solid rgba(255, 193, 7, 0.12);
    font-size: 0.94rem;
    font-weight: 800;
}

.carrito-item-acciones {
    display: flex;
    flex-direction: column;
    gap: 14px;
    justify-content: space-between;
    position: relative;
    z-index: 1;
}

.cantidad-form {
    padding: 18px;
    border-radius: 24px;
    background: rgba(12, 12, 12, 0.98);
    border: 1px solid rgba(255, 193, 7, 0.12);
    display: grid;
    gap: 12px;
    position: relative;
    overflow: hidden;
}


.cantidad-form input[type="number"] {
    width: 100%;
    height: 52px;
    border-radius: 16px;
    border: 1px solid rgba(255, 193, 7, 0.18);
    background: #070707;
    color: #fff;
    font-family: inherit;
    font-size: 1rem;
    font-weight: 800;
    padding: 0 14px;
    outline: none;
    transition: border-color 0.25s ease, transform 0.25s ease;
    position: relative;
    z-index: 1;
}

.cantidad-form input[type="number"]:hover {
    border-color: rgba(255, 193, 7, 0.35);
}

.cantidad-form input[type="number"]:focus {
    border-color: var(--color-yellow);
    transform: translateY(-1px);
}

.subtotal {
    position: relative;
    padding: 10px;
    border-radius: 14px;
    background:
        rgba(255, 193, 7, 0.14);
    border: 1px solid rgba(255, 193, 7, 0.18);
    overflow: hidden;
}


.subtotal strong {
    display: block;
    color: var(--color-yellow);
    font-size: 1.9rem;
    line-height: 1;
    font-weight: 900;
}

.carrito-resumen {
    position: sticky;
    top: 110px;
    padding: 28px;
    border-radius: 32px;
    background:rgba(8, 8, 8, 0.98);
    border: 1px solid var(--color-border);
    overflow: hidden;
}


.carrito-resumen h2 {
    margin: 0 0 22px;
    font-size: 1.85rem;
    line-height: 1;
    font-weight: 900;
    letter-spacing: -0.8px;
    color: #fff;
    position: relative;
    z-index: 1;
}

.resumen-lista {
    display: grid;
    gap: 14px;
    margin-bottom: 22px;
    position: relative;
    z-index: 1;
}

.resumen-item {
    padding: 16px;
    border-radius: 20px;
    background: rgba(12, 12, 12, 0.98);
    border: 1px solid rgba(255, 193, 7, 0.1);
    position: relative;
    overflow: hidden;
}

.resumen-item::before {
    content: "";
    position: absolute;
    inset: 0 auto 0 0;
    width: 3px;
    background: linear-gradient(180deg, var(--color-yellow) 0%, transparent 100%);
    border-radius: 999px;
    opacity: 0.9;
}

.resumen-item-top {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 12px;
    margin-bottom: 10px;
}

.resumen-nombre {
    color: #fff;
    font-size: 0.98rem;
    font-weight: 800;
    line-height: 1.4;
}

.resumen-subtotal {
    color: var(--color-yellow);
    font-size: 1rem;
    font-weight: 900;
    white-space: nowrap;
}

.resumen-item-detalles {
    display: flex;
    flex-direction: column;
    gap: 4px;
    color: #bdbdbd;
    font-size: 0.88rem;
    line-height: 1.5;
}

.resumen-totales {
    position: relative;
    padding: 18px;
    border-radius: 24px;
    background: rgba(255, 193, 7, 0.12);
    border: 1px solid rgba(255, 193, 7, 0.16);
    margin-bottom: 18px;
    overflow: hidden;
    z-index: 1;
}


.resumen-linea {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 12px;
    color: #e0e0e0;
    font-size: 0.97rem;
    font-weight: 700;
}

.resumen-linea+.resumen-linea {
    margin-top: 12px;
    padding-top: 12px;
    border-top: 1px solid rgba(255, 193, 7, 0.12);
}

.resumen-linea.total {
    color: #fff;
}

.resumen-linea.total strong {
    color: var(--color-yellow);
    font-size: 1.85rem;
    line-height: 1;
    font-weight: 900;
}

.btn-full {
    width: 100%;
}

@media (max-width: 1150px) {
    .carrito-grid {
        grid-template-columns: 1fr;
    }

    .carrito-resumen {
        position: static;
    }
}

@media (max-width: 920px) {
    .carrito-item {
        grid-template-columns: 130px 1fr;
    }

    .carrito-item-acciones {
        grid-column: 1 / -1;
    }
}

@media (max-width: 768px) {
    #carrito {
        padding: 0px !important;
    }

    .carrito-head,
    .carrito-vacio,
    .carrito-item,
    .carrito-resumen {
        padding: 20px;
        border-radius: 24px;
    }

    .carrito-head {
        grid-template-columns: 1fr;
    }

    .btn-principal,
    .btn-secundario,
    .btn-eliminar {
        width: 100%;
    }
}

@media (max-width: 620px) {
    .carrito-item {
        grid-template-columns: 1fr;
    }

    .carrito-item-img {
        width: 100%;
        max-width: 230px;
    }

    .carrito-item-info h3 {
        font-size: 1.24rem;
    }

    .subtotal strong {
        font-size: 1.6rem;
    }

    .resumen-item-top {
        flex-direction: column;
    }
    h1,h2{
        font-size:20px !important;
    }
}

@media (max-width: 540px) {
    .carrito-head h1 {
        font-size: 2rem;
    }

    .carrito-resumen h2 {
        font-size: 1.55rem;
    }

    .marca {
        font-size: 0.76rem;
    }

    .descripcion {
        font-size: 0.92rem;
    }

    .precio-unitario {
        font-size: 0.9rem;
    }

    .cantidad-form,
    .subtotal,
    .resumen-totales,
    .resumen-item {
        border-radius: 18px;
    }
}