/* =========================================================
   CART — Minimal sólido, centralizado (versão compacta)
   Paleta: #FFFFFF #95C93D #212C65 #3D76BB
   ========================================================= */

/* força o comportamento do atributo hidden */
[hidden]{ display:none !important; }

/* ---------------------- Tokens ---------------------- */
:root{
  --bg:#ffffff;
  --surface:#ffffff;

  --ink:#212C65;               /* texto principal */
  --muted-ink:#667189;         /* texto secundário */
  --line:#e6ebf2;              /* linhas/bordas */

  --accent:#3D76BB;            /* acento principal */
  --accent-hover:#345f95;
  --accent-tint: rgba(61,118,187,.10);

  --accent-2:#95C93D;          /* alternativo (OK/Pix) */
  --accent-2-hover:#79a42f;

  --r-lg:12px;
  --r:10px;
  --ring:0 0 0 3px rgba(61,118,187,.22);

  --shadow:0 1px 2px rgba(16,34,64,.04);
  --shadow-md:0 8px 24px rgba(16,34,64,.08);
}

/* ---------------------- Base ---------------------- */
*{ box-sizing:border-box; }
html,body{ height:100%; }
body{
  margin:0;
  font: 400 16px/1.5 system-ui,-apple-system,Segoe UI,Roboto,"Helvetica Neue",Arial;
  color:var(--ink);
  background:var(--bg);
}

/* =========================================================
   LAYOUT (com espaço abaixo da NAV fixa)
   ========================================================= */
#cart,
#cart.section{
  /* espaço extra considerando o header fixo (usa --nav-h=64px se existir) */
  margin-top: calc(var(--nav-h, 64px) + 16px);
  scroll-margin-top: calc(var(--nav-h, 64px) + 16px);
  padding: clamp(28px, 4.5vw, 60px) 0; /* levemente menor que antes */
}

#cart .container{ width:min(1100px,92vw); margin-inline:auto; }
#cart .row{ display:grid; gap: clamp(14px, 2.4vw, 22px); }

@media (min-width:960px){
  #cart .row{ grid-template-columns: 1fr min(420px,38%); align-items:start; }
  #cart .col{ display:block; }
  #cart .cart-summary{ position: sticky; top: 24px; }
}
@media (max-width:959px){
  #cart .cart-summary{ position: sticky; top: calc(var(--nav-h,64px) + 12px); }
}

/* =========================================================
   TIPOGRAFIA (compacta/fluida)
   ========================================================= */
#cart h4,#cart h5,#cart h6{ margin:0; color:var(--ink); letter-spacing:.005em; }
#cart h4{ font-size: clamp(.85rem, 1.1vw, .98rem); }
#cart h5{ font-size: .78rem; color: var(--muted-ink); font-weight: 800; }

/* =========================================================
   CARDS (itens e resumo) — menores
   ========================================================= */
#cart .card{
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:var(--r-lg);
  box-shadow:var(--shadow);
  padding: clamp(14px, 1.8vw, 18px);   /* ↓ padding */
}

#cart .cart-items{ padding: clamp(14px, 1.8vw, 18px); }
#cart .cart-header{ padding-bottom:10px; margin-bottom:12px; position:relative; }
#cart .cart-header::after{
  content:""; display:block; height:1px; width:100%;
  background: var(--line); margin-top: 10px;
}

/* Bloco da direita um pouco mais compacto */
#cart .col--summary .cart-summary{
  padding: clamp(18px, 2.6vw, 26px) !important;
  box-shadow: var(--shadow-md);
}

/* =========================================================
   LISTA DE ITENS (sempre vertical e centralizada)
   ========================================================= */
#cart .cart-item{
  border:1px solid var(--line);
  border-radius:var(--r);
  padding: clamp(12px, 1.6vw, 14px);   /* ↓ padding do card do produto */
  background:#fff;
  transition:border-color .15s ease, background .15s ease, box-shadow .15s ease;
}
#cart .cart-item + .cart-item{ margin-top: 10px; }
#cart .cart-item:hover{ background:#fafbfc; box-shadow:var(--shadow); }

/* Cabeçalho do item: ícone → título → Preço unitário (sempre em coluna) */
#cart .product-info{
  display:flex !important;
  flex-direction:column;
  align-items:center;
  justify-content:flex-start;
  text-align:center;
  gap:6px;                           /* ↓ gap */
  margin-bottom: 8px;
}
#cart .product-image{
  width:56px; height:56px;           /* ↓ ícone */
  border-radius:10px; overflow:hidden;
  background:linear-gradient(180deg,#f7f9ff,#f0f4ff);
  border:1px solid var(--line);
  display:flex; align-items:center; justify-content:center;
  margin: 0 auto;
  box-shadow: 0 6px 16px rgba(16,34,64,.06);
}
#cart .product-image > svg,
#cart .product-image > img{ width:34px; height:34px; display:block; object-fit:contain; }

#cart .product-title{
  margin:0;
  font-weight:900;
  font-size: clamp(.88rem, 2vw, .94rem);   /* ↓ título */
  color:var(--ink);
}
#cart .product-meta{
  color:var(--muted-ink);
  font-size: clamp(.76rem, 1.7vw, .82rem);
  white-space:nowrap; margin:0;
}

#cart .item-price, #cart .item-total{ font-weight:900; color:var(--ink); }
#cart .item-total{ color:var(--accent); }

/* Quantidade (stepper) */
#cart .quantity{
  display:inline-flex; align-items:center; gap:2px;
  border:1px solid var(--line); border-radius:10px; background:#fff; overflow:hidden;
  box-shadow: 0 4px 12px rgba(16,34,64,.06) inset;
}
#cart .quantity button{
  appearance:none; border:0; background:#f4f6fb; color:var(--ink);
  width:30px; height:30px; font-size:15px; line-height:1; cursor:pointer;
  transition:background .12s ease, transform .05s ease, color .12s ease;
}
#cart .quantity button:hover{ background:var(--accent-tint); color:var(--accent); }
#cart .quantity button:active{ transform:scale(.98); }
#cart .quantity .qty{
  width:44px; border:0; outline:0; text-align:center; padding:6px 4px;
  font-weight:900; color:var(--ink); background:transparent;
  -moz-appearance:textfield; font-size:.86rem;
}
#cart .quantity .qty::-webkit-outer-spin-button,
#cart .quantity .qty::-webkit-inner-spin-button{ -webkit-appearance:none; margin:0; }

/* Botão Remover */
#cart .remove-item{
  margin-top: 10px;
  border: 1px solid var(--line);
  background: #fff; color: var(--muted-ink);
  border-radius: 12px; padding: 10px 12px;
  cursor:pointer; transition:.15s ease; text-decoration:none;
  width: min(320px, 100%);
  display:inline-flex; align-items:center; justify-content:center;
  box-shadow: 0 2px 10px rgba(16,34,64,.05) inset;
  font-size: .86rem;                 /* ligeiramente menor */
  font-weight: 500;                  /* menos “grosso” */
}
#cart .remove-item:hover{ color:#9b1c1f; border-color:#efd1d3; background:#fff6f7; }

/* Linha de controles do item (SEM GRID) — centralizado */
#cart .row.align-items-center{
  display:flex !important;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:10px;
  text-align:center;
}
#cart .row.align-items-center > [class^="col-"]{ width:100% !important; }
#cart .row.align-items-center [id$="-col-price"]{ display:none !important; } /* preço duplicado oculto */

#cart [id$="-col-total"]{ order:1; text-align:center !important; }
#cart [id$="-col-total"] .item-total{
  display:inline-block; margin: 4px auto 2px;
  font-size: clamp(.84rem, 1.6vw, .98rem);
}
#cart [id$="-col-qty"]{ order:2; }
#cart [id$="-col-remove"]{ order:3; }
#cart .quantity{ margin: 0 auto; }

/* =========================================================
   ESTADO VAZIO — sem emoji
   ========================================================= */
#cart .cart-empty{
  position: relative;
  display:grid; place-items:center; text-align:center;
  min-height: 200px; padding: 20px;
  border: 1px dashed var(--line); border-radius: var(--r);
  background: linear-gradient(180deg,#fbfcff, #f6f8ff);
}
#cart .cart-empty::before{ content:none; } /* remove emoji/carrinho */
#cart .cart-empty p{
  margin:8px 0 16px; font-weight:900; color:var(--ink);
  font-size: clamp(.88rem, 2vw, .98rem);
}
#cart .empty-actions{ display:flex; gap:10px; flex-wrap:wrap; justify-content:center; }
#cart .empty-actions .btn{ min-width: 150px; }

/* =========================================================
   RESUMO (compacto)
   ========================================================= */
#cart .summary-title{ margin-bottom:12px; font-size: clamp(.88rem, 1.4vw, .98rem); }
#cart .summary-item{
  display:flex; align-items:center; justify-content:space-between; gap:10px;
  margin-bottom:10px; font-size: clamp(.78rem, 1.5vw, .88rem); color:var(--muted-ink);
}
#cart .summary-value{ font-weight:800; color:var(--ink); }
#cart .summary-sep{ border:0; height:1px; background:#eef1f6; margin:14px 0; }
#cart .summary-total{
  padding: 10px; border-radius: 12px;
  background:#f3f7ff; border:1px solid #e1e9ff; box-shadow:0 0 0 1px #e7edff inset;
}
#cart .summary-total .summary-value{ color:var(--accent); }

/* Ações do resumo */
#cart .cart-actions{
  display:flex; gap:10px; align-items:center; justify-content:space-between;
  margin-top:16px; padding-top:10px; border-top:1px solid var(--line);
}
#cart .cart-actions .btn-accent{ width:100%; }

/* =========================================================
   FORM / INPUTS
   ========================================================= */
#cart .form-label{ display:block; font-size:.78rem; color:var(--muted-ink); margin:0 0 6px; }
#cart .input-group{ display:flex; gap: 8px; }
#cart .form-control{
  flex:1 1 auto; border:1px solid var(--line); border-radius: 10px;
  padding: 10px 12px; font: inherit; color:var(--ink); background:#fff;
  transition: box-shadow .15s ease, border-color .15s ease;
}
#cart .form-control:focus{ outline:none; border-color:#c6d7ff; box-shadow:var(--ring); }

/* =========================================================
   BOTÕES (10% menores e 40% menos “grossos”)
   ========================================================= */
#cart .btn{
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  padding: 9px 12px;                      /* ↓ 10% */
  border-radius:999px;
  font-weight: 540;                        /* ~40% menos que 900 */
  letter-spacing:.01em; line-height:1.1;
  border:1px solid transparent; cursor:pointer; text-decoration:none;
  background:transparent; color:var(--ink);
  transition: background .15s ease, border-color .15s ease, color .15s ease, transform .05s ease, box-shadow .15s ease;
  font-size: clamp(.78rem, 1.6vw, .86rem); /* ↓ 10% */
}
#cart .btn:active{ transform: translateY(1px); }
#cart .btn-accent{ background:var(--ink); color:#fff; border-color:var(--ink); }
#cart .btn-accent:hover{ background:#1a244f; border-color:#1a244f; color:#fff; }
#cart .btn-outline{ background:#fff; border-color: var(--line); color: var(--ink); }
#cart .btn-outline:hover{ border-color:#cfe0ff; background:var(--accent-tint); color:var(--accent); }
#cart .btn-link{ color:var(--accent); border:1px solid transparent; padding-left:0; padding-right:0; background:transparent; text-decoration:none; }
#cart .btn-link:hover{ color:var(--accent-hover); background:transparent; text-decoration:none; }
#cart .btn-success{ background:var(--accent-2); border-color:var(--accent-2); color:#0b1a00; }
#cart .btn-success:hover{ background:var(--accent-2-hover); border-color:var(--accent-2-hover); }
#cart .w-100{ width:100%; }

/* =========================================================
   ACESSIBILIDADE / ANIMAÇÕES
   ========================================================= */
#cart .btn:focus-visible,
#cart .remove-item:focus-visible,
#cart .form-control:focus-visible,
#cart .quantity button:focus-visible{ outline:none; box-shadow:var(--ring); }

@media (prefers-reduced-motion:no-preference){
  #cart .cart-item{ animation: fadeIn .18s ease both; }
  @keyframes fadeIn{
    from{ opacity:0; transform: translateY(2px); }
    to{ opacity:1; transform: translateY(0); }
  }
}

/* =========================================================
   RESPONSIVO — ajustes finos
   ========================================================= */
@media (max-width:560px){
  #cart .cart-actions{ flex-direction: column; align-items: stretch; }
  #cart .cart-actions .btn-link{ align-self:center; }
}

@media (max-width:400px){
  #cart .card{ padding: 12px; }
  #cart .product-image{ width:50px; height:50px; }
  #cart .product-image > svg,
  #cart .product-image > img{ width:30px; height:30px; }
  #cart .product-title{ font-size: clamp(.84rem, 3.8vw, .9rem); }
  #cart .product-meta{ font-size: clamp(.72rem, 3.4vw, .8rem); }
  #cart .quantity button{ width:28px; height:28px; font-size:14px; }
  #cart .quantity .qty{ width:40px; font-size:.82rem; }
  #cart .remove-item{ width:100%; font-size:.82rem; }
  #cart .summary-item{ font-size: clamp(.74rem, 3.4vw, .84rem); }
}

@media (max-width:340px){
  #cart .card{ padding: 10px; }
  #cart .product-image{ width:42px; height:42px; }
  #cart .product-image > svg,
  #cart .product-image > img{ width:26px; height:26px; }
  #cart .product-title{ font-size:.86rem; }
  #cart .product-meta{ font-size:.78rem; }
  #cart .quantity button{ width:26px; height:26px; font-size:13px; }
  #cart .quantity .qty{ width:36px; font-size:.8rem; }
  #cart .item-total{ font-size:.92rem; }
  #cart .remove-item{ font-size:.8rem; padding:9px 10px; }
}
