/* ============================================================================
   Na Brisa — CART + CHECKOUT (clone do fluxo/UX da Brazika, recolorido).
   Estrutura/UX/copy/componentes = idênticos à Brazika; muda só a estética:
     verde-limão #7ED956, accent amarelo PUFF #F5C518, preto FIRE, fundo claro.
   Dono: agente cart/checkout. Carregado por cart/index.html e checkout/index.html.
   Pareia 1:1 com pf-app.js (mesmas classes co-* / ts-* / pf-* da Brazika).
   ============================================================================ */
/* TEMA praiano/roots: areia + erva + brasa + dourado (igual storefront) */
@import url('https://fonts.googleapis.com/css2?family=Fredoka:wght@400;500;600;700&family=Outfit:wght@400;500;600;700&family=Caveat:wght@500;600;700&family=Pacifico&display=swap');
:root{
  --pf-bg:#f7f0e1;            /* areia clara */
  --pf-raised:#fffdf8;        /* cards off-white quentinho */
  --pf-sunken:#efe5d0;        /* badges / inputs (areia 2) */
  --pf-ink:#14361f;          /* verde-mata quase-preto */
  --pf-ink-2:#4a5d49;
  --pf-muted:#7c8a78;
  --pf-line:#e2d6bd;
  --pf-line-2:#d8c9a9;
  --pf-green:#3aa760;         /* verde folha legível */
  --pf-green-deep:#1c6b3a;
  --pf-lime:#3aa760;          /* CTA = verde-erva (não limão) */
  --pf-lime-ink:#ffffff;      /* texto sobre CTA */
  --pf-yellow:#f6c344;        /* dourado sol */
  --pf-sun:#f0902b;           /* brasa */
  --pf-coral:#c4572f;         /* terracota */
  --pf-radius:18px;
  --pf-pill:999px;
  --pf-shadow:0 1px 2px rgba(20,54,31,.05), 0 12px 32px -14px rgba(20,54,31,.22);
  --pf-font:'Outfit',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --pf-font-d:'Fredoka','Outfit',sans-serif;
}

/* mata o loader morto da Yampi (3rd party do clone) */
.yampi-loader,.yampi-loading{display:none!important;visibility:hidden!important;pointer-events:none!important;}

/* badge do carrinho no header — recolorido pro lime */
.pf-cart-badge{
  position:absolute;top:-6px;right:-8px;min-width:18px;height:18px;padding:0 4px;
  background:var(--pf-lime);color:var(--pf-lime-ink);border-radius:999px;font-size:11px;font-weight:800;
  line-height:18px;text-align:center;display:none;align-items:center;justify-content:center;
}

/* toast */
.pf-toast{position:fixed;left:50%;bottom:24px;transform:translate(-50%,20px);
  background:var(--pf-ink);color:#fff;padding:12px 20px;border-radius:var(--pf-pill);font-weight:700;
  font-size:14px;z-index:99999;opacity:0;transition:.3s;box-shadow:var(--pf-shadow);}
.pf-toast--in{opacity:1;transform:translate(-50%,0);}

/* botoes base */
.pf-btn{display:inline-block;text-align:center;padding:14px 22px;border-radius:var(--pf-pill);
  font-weight:800;text-decoration:none;cursor:pointer;border:0;font-size:15px;line-height:1.2;}
.pf-btn{font-family:var(--pf-font-d);font-weight:600;}
.pf-btn--green{background:linear-gradient(135deg,#3aa760,#2c8a4d);color:#fff;box-shadow:0 10px 22px rgba(28,107,58,.3);}
.pf-btn--green:hover{filter:brightness(1.04);transform:translateY(-1px);}
.pf-btn--ghost{background:transparent;color:var(--pf-ink-2);border:1px solid var(--pf-line-2);}
.pf-btn--ghost:hover{border-color:var(--pf-ink-2);color:var(--pf-ink);}
.pf-btn[disabled]{opacity:.5;pointer-events:none;}

/* ============================================================
   HEADER DEDICADO DO CHECKOUT — logo "na brisa" centralizado
   (esconde o header de navegação da loja; foco total no checkout)
   ============================================================ */
/* no checkout, fora o header de navegação da loja e seu drawer/mega-menu */
html.pf-checkout-page .pf-header{display:none!important;}
html.pf-checkout-page body{padding-top:0!important;}
/* checkout distraction-free: esconde a eyebrow rotativa e o rodapé GIGANTE da
   loja (injetados pelo storefront) — no checkout só existem header enxuto,
   promobar slim, form, resumo e selos. Foco total em FECHAR a compra. */
html.pf-checkout-page .pf-eyebrow{display:none!important;}
/* BUG-5: o checkout AGORA usa o mesmo rodapé do site (não escondemos mais). */
html.pf-checkout-page .pf-footer{display:block!important;margin-top:40px;}

.pf-co-header{position:sticky;top:0;z-index:1000;background:var(--pf-raised);
  border-bottom:1px solid var(--pf-line);box-shadow:0 1px 0 rgba(20,54,31,.03);}
.pf-co-header-bar{max-width:1180px;margin:0 auto;height:66px;padding:0 20px;
  display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:10px;}
/* BUG-4: header enxuto = só wordmark centralizado (não clicável) */
.pf-co-header--min .pf-co-header-bar{display:flex;justify-content:center;height:60px;}
.pf-co-wordmark{font-family:var(--pf-font-groove,'Pacifico',cursive);font-weight:400;
  font-size:30px;line-height:1;letter-spacing:0;display:inline-flex;align-items:baseline;gap:6px;user-select:none;}
.pf-co-wordmark .pf-logo-puff{color:var(--pf-green-deep);}
.pf-co-wordmark .pf-logo-fire{color:var(--pf-sun);text-shadow:0 1px 0 rgba(196,87,47,.18);}
@media(max-width:560px){.pf-co-header--min .pf-co-header-bar{height:54px;}.pf-co-wordmark{font-size:26px;}}
.pf-co-logo-link{justify-self:center;text-decoration:none;line-height:1;}
.pf-co-header .pf-logo{font-family:var(--pf-font-groove,'Pacifico',cursive);font-weight:400;
  font-size:30px;letter-spacing:0;line-height:1;display:inline-flex;align-items:baseline;gap:6px;}
.pf-co-header .pf-logo-puff{color:var(--pf-green-deep);}
.pf-co-header .pf-logo-fire{color:var(--pf-sun);text-shadow:0 1px 0 rgba(196,87,47,.18);}
.pf-co-hd-back,.pf-co-hd-track{display:inline-flex;align-items:center;gap:6px;
  color:var(--pf-ink-2);text-decoration:none;font-weight:700;font-size:13px;cursor:pointer;
  padding:8px 12px;border-radius:var(--pf-pill);transition:background .15s,color .15s;}
.pf-co-hd-back{justify-self:start;}
.pf-co-hd-track{justify-self:end;}
.pf-co-hd-back:hover,.pf-co-hd-track:hover{background:var(--pf-sunken);color:var(--pf-ink);}
.pf-co-hd-back svg,.pf-co-hd-track svg{width:17px;height:17px;flex:none;}
.pf-co-header-secure{background:var(--pf-ink);color:#dce8df;text-align:center;
  font-size:11.5px;font-weight:600;letter-spacing:.02em;padding:7px 16px;
  display:flex;align-items:center;justify-content:center;gap:7px;}
.pf-co-header-secure svg{width:14px;height:14px;flex:none;color:var(--pf-yellow);}
.pf-co-header-secure b{color:#fff;font-weight:800;}

@media(max-width:560px){
  .pf-co-header-bar{height:58px;padding:0 12px;gap:6px;}
  .pf-co-header .pf-logo{font-size:25px;}
  .pf-co-hd-back span,.pf-co-hd-track span{display:none;}
  .pf-co-hd-back,.pf-co-hd-track{padding:9px;}
  .pf-co-header-secure{font-size:10.5px;letter-spacing:0;}
}

/* ============================================================
   EYEBROW rotativo + promobar (igual Brazika, recolorido)
   ============================================================ */
.pf-eyebrow{background:var(--pf-ink);color:#fff;text-align:center;font-size:11px;letter-spacing:.14em;
  text-transform:uppercase;font-weight:600;padding:9px 16px;min-height:38px;position:relative;}
.pf-eyebrow .pf-eslide{display:none;}
.pf-eyebrow .pf-eslide.is-on{display:block;}
.pf-promobar{display:flex;align-items:center;justify-content:center;gap:8px;background:var(--pf-yellow);
  color:var(--pf-ink);font-size:13px;font-weight:700;padding:10px 16px;}
.pf-promobar svg{width:17px;height:17px;flex:none;}
.pf-promobar b{font-weight:800;}
/* checkout: promobar SLIM e discreta (faixa areia-escura, não amarelo berrante) —
   menos ruído, mais foco. */
html.pf-checkout-page .pf-promobar{background:var(--pf-sunken);color:var(--pf-ink-2);
  font-size:12.5px;font-weight:600;padding:8px 16px;border-bottom:1px solid var(--pf-line);
  letter-spacing:.005em;}
html.pf-checkout-page .pf-promobar svg{width:15px;height:15px;color:var(--pf-green);}
html.pf-checkout-page .pf-promobar b{color:var(--pf-ink);font-weight:700;}

/* ============================================================
   CART PAGE — 2 colunas (itens + resumo), idêntico à Brazika
   ============================================================ */
.pf-cart-page,.pf-checkout{max-width:1180px;margin:0 auto;padding:24px 20px 8px;color:var(--pf-ink);font-family:var(--pf-font);}
.pf-page-hero{padding:28px 20px 12px;max-width:1180px;margin:0 auto;}
.pf-page-hero h1{font-family:var(--pf-font-d);font-size:34px;font-weight:600;letter-spacing:-.015em;margin:0 0 4px;}
.pf-page-hero p{color:var(--pf-muted);margin:0;font-size:15px;}

.pf-cart-grid{display:grid;grid-template-columns:1.5fr .9fr;gap:28px;align-items:start;}

.pf-line{display:grid;grid-template-columns:84px 1fr auto;align-items:center;gap:16px;
  padding:16px;border:1px solid var(--pf-line);border-radius:var(--pf-radius);background:var(--pf-raised);
  box-shadow:var(--pf-shadow);margin-bottom:14px;}
.pf-line__img{width:84px;height:84px;object-fit:cover;border-radius:10px;background:#f3f4f6;}
.pf-line .meta h4{font-weight:800;font-size:15.5px;margin:0 0 3px;letter-spacing:-.01em;}
.pf-line .opts{color:var(--pf-muted);font-size:13px;margin-bottom:8px;}
.pf-line .qty{display:inline-flex;align-items:center;gap:8px;}
.pf-line .qty button{width:32px;height:32px;border:1px solid var(--pf-line-2);background:var(--pf-bg);
  color:var(--pf-ink);border-radius:8px;font-size:17px;cursor:pointer;line-height:1;}
.pf-line .qty button:hover{border-color:var(--pf-ink-2);}
.pf-line .qty span{min-width:22px;text-align:center;font-weight:700;}
.pf-line .price-col{text-align:right;}
.pf-line .price{font-weight:800;font-size:16px;}
.pf-line .remove{color:var(--pf-muted);font-size:12.5px;text-decoration:none;display:inline-block;margin-top:6px;}
.pf-line .remove:hover{color:var(--pf-coral);}

.pf-cart-summary{background:var(--pf-raised);border:1px solid var(--pf-line);border-radius:var(--pf-radius);
  box-shadow:var(--pf-shadow);padding:22px;position:sticky;top:16px;}
.pf-cart-summary h3{font-size:18px;font-weight:800;margin:0 0 16px;}
.pf-cart-summary .line{display:flex;justify-content:space-between;font-size:14px;color:var(--pf-ink-2);padding:6px 0;}
.pf-cart-summary .line.discount,.pf-cart-summary .line.total b{color:var(--pf-green);}
.pf-cart-summary .line.total{border-top:1px solid var(--pf-line);margin-top:8px;padding-top:14px;
  font-size:18px;font-weight:800;color:var(--pf-ink);}
.pf-cart-summary .pay-note{font-size:12px;color:var(--pf-muted);margin:2px 0;display:flex;align-items:center;gap:6px;}
.pf-cart-summary .pay-note svg{width:15px;height:15px;flex:none;color:var(--pf-green);}
.pf-cart-summary .pay-note b{color:var(--pf-ink-2);}

/* cupom */
.pf-coupon{display:flex;gap:8px;margin:14px 0 6px;}
.pf-coupon input{flex:1;background:var(--pf-sunken);border:1px solid var(--pf-line);border-radius:12px;
  padding:11px 14px;font-size:14px;color:var(--pf-ink);text-transform:uppercase;}
.pf-coupon input:focus{outline:none;border-color:var(--pf-green);background:#fff;}
.pf-coupon button{background:var(--pf-ink);color:#fff;border:0;border-radius:var(--pf-pill);
  padding:0 18px;font-weight:700;cursor:pointer;transition:.2s;}
.pf-coupon button:hover{background:var(--pf-green);}
.pf-coupon-msg{font-size:12.5px;margin:2px 0 8px;font-weight:600;}
.pf-coupon-msg.ok{color:var(--pf-green);}
.pf-coupon-msg.err{color:var(--pf-coral);}
.pf-coupon-applied{display:flex;align-items:center;justify-content:space-between;gap:8px;margin:12px 0 4px;}
.pf-coupon-applied .tag{display:inline-flex;align-items:center;gap:6px;font-size:12.5px;font-weight:700;color:var(--pf-green);}
.pf-coupon-applied .tag .ic{display:inline-flex;width:14px;height:14px;}
.pf-coupon-applied .tag .ic svg{width:100%;height:100%;}
.pf-coupon-applied button{background:none;border:0;color:var(--pf-muted);text-decoration:underline;cursor:pointer;font-size:12px;}
.pf-coupon-applied button:hover{color:var(--pf-coral);}

.pf-cart-summary .pf-btn--green{width:100%;margin-top:14px;}
.pf-cart-summary .pf-cont{display:block;text-align:center;margin-top:12px;color:var(--pf-ink-2);
  text-decoration:none;font-weight:600;font-size:14px;}
.pf-cart-summary .pf-cont:hover{text-decoration:underline;}

/* trust row do carrinho */
.pf-cart-trust{display:flex;flex-wrap:wrap;align-items:center;gap:8px 14px;margin-top:16px;padding-top:14px;
  border-top:1px solid var(--pf-line);font-size:12px;color:var(--pf-muted);}
.pf-cart-trust .secure{color:var(--pf-green);font-weight:800;display:inline-flex;align-items:center;gap:5px;}
.pf-cart-trust .secure svg{width:15px;height:15px;}
.pf-paybadge{background:var(--pf-sunken);color:var(--pf-ink-2);border-radius:6px;padding:3px 7px;font-weight:700;font-size:11px;}

/* empty state */
.pf-empty{text-align:center;padding:50px 20px;}
.pf-empty .big{font-size:22px;font-weight:800;margin:0 0 18px;}

/* ============================================================
   CHECKOUT — layout 2 colunas (form + resumo sticky)
   ============================================================ */
.pf-checkout{max-width:1080px;padding:28px 20px 40px;}
.pf-co-layout{display:grid;grid-template-columns:minmax(0,1.5fr) minmax(320px,.95fr);gap:36px;align-items:start;}

/* stepper 3 passos */
.pf-co-steps{display:flex;gap:8px;margin:0 0 18px;}
.pf-co-steps .st{flex:1;display:flex;align-items:center;gap:8px;justify-content:center;
  padding:10px 8px;border:1px solid var(--pf-line);border-radius:12px;background:var(--pf-raised);
  font-size:13px;font-weight:700;color:var(--pf-muted);}
.pf-co-steps .st b{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;
  border-radius:50%;background:var(--pf-sunken);color:var(--pf-muted);font-size:12px;}
.pf-co-steps .st.active{border-color:var(--pf-green);color:var(--pf-ink);}
.pf-co-steps .st.active b{background:var(--pf-lime);color:var(--pf-lime-ink);}
.pf-co-steps .st.done b{background:var(--pf-green);color:#fff;}

/* cards de cada passo */
.pf-co-card{background:var(--pf-raised);border:1px solid var(--pf-line);border-radius:var(--pf-radius);
  box-shadow:var(--pf-shadow);padding:22px;margin-bottom:16px;}
.pf-co-card h2{font-size:18px;font-weight:800;margin:0 0 16px;}

/* form */
.pf-co-form label{display:block;font-size:13px;font-weight:600;color:var(--pf-ink-2);margin-bottom:13px;}
.pf-co-form input{display:block;width:100%;margin-top:5px;padding:12px 14px;border:1px solid var(--pf-line-2);
  border-radius:10px;font-size:15px;box-sizing:border-box;background:#fff;color:var(--pf-ink);}
.pf-co-form input:focus{outline:none;border-color:var(--pf-green);box-shadow:0 0 0 3px rgba(47,174,74,.15);}
.pf-co-form input.err{border-color:var(--pf-coral);}
.pf-co-row{display:grid;gap:12px;}
.pf-co-row.two{grid-template-columns:1fr 1fr;}
.pf-co-row.cep{grid-template-columns:.6fr 1fr;}
.pf-co-row.numcomp{grid-template-columns:.5fr 1fr;}
.pf-field-msg{color:var(--pf-coral);font-size:12px;margin-top:-8px;margin-bottom:10px;min-height:0;}

.pf-co-actions{display:flex;gap:12px;margin-top:6px;}
.pf-co-actions .pf-btn{flex:1;}
.pf-co-actions .pf-btn--green{flex:1.6;}

.pf-err-banner{display:none;background:#fdeceb;border:1px solid #f5c2bd;color:#b3271a;
  border-radius:10px;padding:10px 14px;font-size:13px;font-weight:600;margin-bottom:14px;}

/* nota CPF + badge pix (igual Brazika) */
.pf-field-note{display:flex;gap:8px;align-items:flex-start;font-size:12px;color:var(--pf-muted);margin:2px 0 14px;}
.pf-field-note svg{width:15px;height:15px;flex:none;margin-top:1px;color:var(--pf-green);}
.pf-pix-badge{display:flex;gap:8px;align-items:center;background:var(--pf-sunken);border:1px solid var(--pf-line);
  border-radius:12px;padding:11px 14px;font-size:13px;margin:0 0 16px;}
.pf-pix-badge svg{width:18px;height:18px;flex:none;color:var(--pf-green);}
.pf-pix-badge b{color:var(--pf-green);}

/* ============================================================
   FRETE inline (Correios PAC grátis + SEDEX upgrade) — clone
   ============================================================ */
.pf-frete-head{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:700;margin:14px 0 10px;color:var(--pf-ink-2);}
.pf-frete-head svg{width:18px;height:18px;flex:none;color:var(--pf-green);}
.pf-frete-head .badge{background:var(--pf-yellow);color:#002F87;font-weight:800;font-size:11px;padding:2px 8px;border-radius:5px;}
.pf-ship{display:flex;flex-direction:column;gap:10px;}
.pf-ship-opt{display:flex;align-items:center;justify-content:space-between;gap:12px;cursor:pointer;
  border:1px solid var(--pf-line-2);border-radius:12px;padding:13px 14px;background:#fff;transition:.15s;}
.pf-ship-opt:hover{border-color:var(--pf-green);}
.pf-ship-opt.sel{border-color:var(--pf-green);box-shadow:0 0 0 2px rgba(47,174,74,.18);}
.pf-ship-opt .t{display:flex;flex-direction:column;gap:2px;}
.pf-ship-opt .t b{font-size:14px;font-weight:800;}
.pf-ship-opt .t span{font-size:12px;color:var(--pf-muted);}
.pf-ship-tag{display:inline-block;background:var(--pf-sunken);color:var(--pf-green);font-size:10.5px;
  font-weight:800;padding:1px 6px;border-radius:5px;margin-left:6px;vertical-align:middle;}
.pf-ship-cost{font-size:14px;font-weight:800;white-space:nowrap;}
.pf-ship-cost .free{color:var(--pf-green);}
.pf-ship-cost s{color:var(--pf-muted);font-weight:500;font-size:12px;margin-right:4px;}
.pf-frete-loading{display:inline-flex;align-items:center;gap:8px;font-size:12.5px;color:var(--pf-muted);margin-top:4px;}

/* ============================================================
   PAGAMENTO — seletor pix / cartão / boleto (clone Brazika)
   ============================================================ */
.pf-pix-best{display:flex;gap:8px;align-items:center;background:var(--pf-sunken);border:1px solid var(--pf-line);
  border-radius:12px;padding:11px 14px;font-size:13px;margin-bottom:14px;}
.pf-pix-best svg{width:18px;height:18px;flex:none;color:var(--pf-green);}
.pf-pix-best b{color:var(--pf-green);}
.pf-pay-methods{display:flex;flex-direction:column;gap:10px;margin-bottom:14px;}
.pf-pay-opt{display:flex;align-items:center;gap:12px;cursor:pointer;border:1px solid var(--pf-line-2);
  border-radius:12px;padding:14px;background:#fff;transition:.15s;}
.pf-pay-opt:hover{border-color:var(--pf-green);}
.pf-pay-opt.sel{border-color:var(--pf-green);box-shadow:0 0 0 2px rgba(47,174,74,.18);}
.pf-pay-opt .ic{width:26px;height:26px;flex:none;color:var(--pf-ink);}
.pf-pay-opt .ic svg{width:100%;height:100%;}
.pf-pay-opt .t{flex:1;display:flex;flex-direction:column;gap:2px;}
.pf-pay-opt .t b{font-size:14.5px;font-weight:800;}
.pf-pay-opt .t span{font-size:12.5px;color:var(--pf-muted);}
.pf-pay-opt .badge{background:var(--pf-lime);color:var(--pf-lime-ink);font-size:10.5px;font-weight:800;
  padding:3px 9px;border-radius:999px;text-transform:uppercase;letter-spacing:.03em;}
.pf-pay-hint{font-size:13px;color:var(--pf-muted);background:var(--pf-sunken);border-radius:10px;
  padding:11px 13px;margin:0 0 14px;line-height:1.5;}

/* form do cartão inline */
.pf-card-pane{margin-bottom:14px;}
.pf-card-sec{display:flex;gap:9px;align-items:flex-start;background:var(--pf-sunken);border-radius:10px;
  padding:11px 13px;font-size:12px;color:var(--pf-ink-2);margin-bottom:14px;}
.pf-card-sec svg{width:18px;height:18px;flex:none;color:var(--pf-green);margin-top:1px;}
.pf-card-sec b{color:var(--pf-ink);}
.pf-card-pane select{display:block;width:100%;margin-top:5px;padding:12px 14px;border:1px solid var(--pf-line-2);
  border-radius:10px;font-size:14px;background:#fff;}

/* selo de segurança + bandeiras (rodapé do passo de pagamento) */
.pf-pay-seals{margin-top:16px;padding-top:14px;border-top:1px solid var(--pf-line);
  display:flex;flex-direction:column;align-items:center;gap:10px;text-align:center;}
.pf-pay-seals-secure{display:inline-flex;align-items:center;gap:8px;font-size:13px;color:var(--pf-ink-2);}
.pf-pay-seals-secure svg{width:18px;height:18px;flex:none;color:var(--pf-green);}
.pf-pay-seals-secure b{color:var(--pf-ink);font-weight:800;}
.pf-pay-seals-badges{display:flex;flex-wrap:wrap;justify-content:center;gap:6px;}

/* ============================================================
   PIX result — QR + copia-e-cola + contador + aguardando
   ============================================================ */
.pf-pix{text-align:center;}
.pf-pix .qrbox{display:flex;justify-content:center;margin:6px 0 14px;}
.pf-pix .qrbox img,.pf-pix .qrbox canvas{width:208px;height:208px;border:1px solid var(--pf-line);
  border-radius:12px;padding:8px;background:#fff;}
.pf-pix .emv{display:flex;gap:8px;max-width:420px;margin:0 auto 12px;}
.pf-pix .emv input{flex:1;border:1px solid var(--pf-line-2);border-radius:10px;padding:11px 12px;
  font-size:12px;color:var(--pf-ink-2);background:var(--pf-sunken);}
.pf-pix .copybtn{background:var(--pf-ink);color:#fff;border:0;border-radius:var(--pf-pill);
  padding:0 18px;font-weight:700;cursor:pointer;}
.pf-pix .copybtn:hover{background:var(--pf-green);}
.pf-timer{font-size:22px;font-weight:800;color:var(--pf-green);margin:8px 0 4px;font-variant-numeric:tabular-nums;}
.pf-waiting{display:inline-flex;align-items:center;gap:9px;font-size:13px;color:var(--pf-muted);font-weight:600;margin:6px 0;}
.pf-spin{width:15px;height:15px;border:2.5px solid var(--pf-line-2);border-top-color:var(--pf-green);
  border-radius:50%;display:inline-block;animation:pfspin .8s linear infinite;}
@keyframes pfspin{to{transform:rotate(360deg);}}

/* boleto result */
.pf-boleto{text-align:center;}
.pf-boleto .line{font-size:14px;font-weight:700;background:var(--pf-sunken);border-radius:10px;
  padding:14px;letter-spacing:.5px;margin:10px 0;word-break:break-all;}

/* obrigado/thanks */
.pf-thanks{text-align:center;padding:46px 20px;max-width:560px;margin:0 auto;}
.pf-thanks h1{font-size:28px;font-weight:800;margin:0 0 12px;}
.pf-thanks p{color:var(--pf-ink-2);line-height:1.6;}
.pf-thanks .note{color:var(--pf-muted);font-size:13px;margin:14px 0 22px;}

/* ============================================================
   COLUNA DIREITA — resumo do pedido (clone do co-topsummary)
   ============================================================ */
.pf-co-side{position:sticky;top:16px;}
.pf-ts-card{background:var(--pf-raised);border:1px solid var(--pf-line);border-radius:var(--pf-radius);
  box-shadow:var(--pf-shadow);padding:18px;}
.pf-ts-toggle{display:flex;width:100%;align-items:center;justify-content:space-between;background:none;border:0;
  cursor:pointer;font-size:15px;font-weight:800;color:var(--pf-ink);padding:0 0 4px;}
.pf-ts-toggle .caret{display:inline-flex;width:16px;transition:transform .2s;vertical-align:middle;margin-right:6px;}
.pf-ts-toggle .caret svg{width:100%;}
.pf-ts-card.collapsed .pf-ts-body{display:none;}
.pf-ts-card.collapsed .pf-ts-toggle .caret{transform:rotate(-90deg);}
.pf-ts-mini{font-size:13px;color:var(--pf-muted);font-weight:600;}
.pf-ts-body{margin-top:12px;}
.pf-ts-item{display:flex;align-items:center;gap:10px;padding:9px 0;border-bottom:1px solid var(--pf-line);}
.pf-ts-item img{width:48px;height:48px;object-fit:cover;border-radius:8px;background:#eee;}
.pf-ts-meta{flex:1;display:flex;flex-direction:column;gap:1px;}
.pf-ts-meta b{font-size:13.5px;font-weight:700;}
.pf-ts-meta span{font-size:11.5px;color:var(--pf-muted);}
.pf-ts-price{font-size:13.5px;font-weight:800;}
.pf-ts-lines{margin-top:12px;}
.pf-ts-line{display:flex;justify-content:space-between;font-size:13.5px;color:var(--pf-ink-2);padding:4px 0;}
.pf-ts-line.disc{color:var(--pf-green);font-weight:600;}
.pf-ts-line.total{border-top:1px solid var(--pf-line);margin-top:6px;padding-top:12px;font-size:17px;
  font-weight:800;color:var(--pf-ink);flex-wrap:wrap;}
.pf-ts-pix{flex-basis:100%;font-size:12px;font-weight:600;color:var(--pf-muted);margin-top:4px;}
.pf-ts-pix.on{color:var(--pf-green);}
.pf-ts-pix b{color:var(--pf-green);}

/* selo de confiança ABAIXO do resumo (substitui as reviews que poluíam o
   checkout): faixa enxuta "compra 100% segura" + bandeiras aceitas. */
.pf-co-side-trust{background:var(--pf-raised);border:1px solid var(--pf-line);border-radius:var(--pf-radius);
  box-shadow:var(--pf-shadow);padding:14px 16px;margin-top:14px;}
.pf-co-side-trust .secure{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:700;color:var(--pf-ink);}
.pf-co-side-trust .secure svg{width:17px;height:17px;flex:none;color:var(--pf-green);}
.pf-co-side-trust .badges{display:flex;flex-wrap:wrap;gap:6px;margin-top:11px;padding-top:11px;border-top:1px solid var(--pf-line);}

/* ============================================================
   MOBILE
   ============================================================ */
@media(max-width:880px){
  .pf-cart-grid,.pf-co-layout{grid-template-columns:1fr;}
  .pf-cart-summary,.pf-co-side{position:static;}
  /* no mobile o resumo vai pro TOPO (order), como na Brazika */
  .pf-co-layout .pf-co-side{order:-1;margin-bottom:16px;}
  .pf-page-hero h1{font-size:26px;}
}
@media(max-width:560px){
  .pf-line{grid-template-columns:64px 1fr;grid-template-areas:"img info" "img price";gap:10px 12px;}
  .pf-line__img{width:64px;height:64px;grid-area:img;}
  .pf-line .meta{grid-area:info;}
  .pf-line .price-col{grid-area:price;text-align:left;}
  .pf-co-row.two,.pf-co-row.cep,.pf-co-row.numcomp{grid-template-columns:1fr;}
  .pf-co-actions{flex-direction:column-reverse;}
}
