/* =====================================================================
   Carrinho / Sacola
   ===================================================================== */

.carrinho-wrap { display: grid; grid-template-columns: 1fr 380px; gap: 40px; padding: 40px 32px 60px; align-items: start; }

/* Itens */
.carrinho-itens { display: flex; flex-direction: column; gap: 16px; }
.carrinho-item {
    display: grid; grid-template-columns: 100px 1fr auto; gap: 20px; align-items: center;
    padding: 16px; border: 1px solid var(--linha); border-radius: var(--raio); background: var(--creme);
}
.carrinho-item__img { width: 100px; aspect-ratio: 4/5; object-fit: cover; border-radius: 2px; background: var(--areia); }
.carrinho-item__nome { font-family: var(--serif); font-size: 18px; margin-bottom: 4px; }
.carrinho-item__nome a:hover { color: var(--bordo); }
.carrinho-item__variacao { font-size: 13px; color: var(--texto-suave); margin-bottom: 12px; }
.carrinho-item__preco { color: var(--bordo); font-weight: 500; }
.carrinho-item__qtd { display: inline-flex; align-items: center; border: 1px solid var(--linha); border-radius: var(--raio); margin-top: 10px; }
.carrinho-item__qtd button { width: 34px; height: 36px; font-size: 18px; color: var(--texto); }
.carrinho-item__qtd span { width: 38px; text-align: center; font-size: 14px; }
.carrinho-item__direita { text-align: right; display: flex; flex-direction: column; align-items: flex-end; gap: 12px; height: 100%; justify-content: space-between; }
.carrinho-item__remover { color: var(--texto-suave); font-size: 12px; letter-spacing: 1px; display: inline-flex; align-items: center; gap: 6px; }
.carrinho-item__remover:hover { color: #b3261e; }
.carrinho-item__subtotal { font-weight: 600; }

/* Resumo */
.carrinho-resumo { border: 1px solid var(--linha); border-radius: var(--raio); padding: 28px; background: var(--creme-escuro); position: sticky; top: calc(var(--header-h) + 20px); }
.carrinho-resumo h3 { font-size: 22px; margin-bottom: 22px; }
.carrinho-cep { padding-bottom: 20px; margin-bottom: 20px; border-bottom: 1px solid var(--linha); }
.carrinho-cep label { display: block; font-size: 12px; letter-spacing: 1px; text-transform: uppercase; margin-bottom: 10px; color: var(--texto-suave); }
.carrinho-cep__campo { display: flex; gap: 8px; }
.carrinho-cep__campo input { flex: 1; border: 1px solid var(--linha); border-radius: var(--raio); padding: 11px 12px; font-family: var(--sans); font-size: 14px; outline: none; }
.carrinho-cep__campo input:focus { border-color: var(--vinho); }
.carrinho-cep__campo .btn { padding: 11px 18px; }
.carrinho-cep__resultado { margin-top: 10px; font-size: 13px; color: var(--texto-suave); }

.carrinho-linha { display: flex; justify-content: space-between; padding: 8px 0; font-size: 14px; color: var(--texto-suave); }
.carrinho-linha--total { border-top: 1px solid var(--linha); margin-top: 8px; padding-top: 16px; font-size: 20px; color: var(--texto); font-weight: 600; }
.carrinho-linha--total span:last-child { color: var(--bordo); }
.carrinho-resumo .btn { margin-top: 20px; }
.carrinho-resumo__obs { font-size: 12px; color: var(--texto-suave); margin-top: 16px; line-height: 1.6; }

@media (max-width: 900px) {
    .carrinho-wrap { grid-template-columns: 1fr; padding: 32px 20px 48px; }
    .carrinho-resumo { position: static; }
    .carrinho-item { grid-template-columns: 80px 1fr; }
    .carrinho-item__img { width: 80px; }
    .carrinho-item__direita { grid-column: 1 / -1; flex-direction: row; align-items: center; justify-content: space-between; }
}
@media (max-width: 480px) {
    .carrinho-wrap { padding: 24px 16px 40px; gap: 28px; }
    .carrinho-item { grid-template-columns: 70px 1fr; gap: 14px; padding: 14px; }
    .carrinho-item__img { width: 70px; }
    .carrinho-item__nome { font-size: 16px; }
    .carrinho-resumo { padding: 22px 18px; }
    .carrinho-cep__campo { flex-wrap: wrap; }
    .carrinho-cep__campo input { min-width: 0; }
}
