:root {
  --glass-bg: rgba(17, 17, 17, .55);
  --glass-border: rgba(255,255,255,.12);
  --text-strong: #fff;              /* títulos, preços */
  --text: rgba(255,255,255,.92);    /* textos principais */
  --text-dim: rgba(255,255,255,.65);/* textos secundários */
  --divider: rgba(255,255,255,.14);
  --btn-bg: #ff3b30;                /* vermelho do botão */
  --btn-text: #fff;
  --btn-shadow: 0 8px 24px rgba(255, 59, 48, .35);
   --field-bg: rgba(255,255,255,.06);
  --field-border: rgba(255,255,255,.18);
  --field-focus: rgba(255,59,48,.28);
  --placeholder: rgba(255,255,255,.45);
  --ok: #2ecc71;
  --warn: #ffb020;
  --err: #ff3b30;
}

.cartModal { position: fixed; inset: 0; display: none; z-index: 10000; }
.cartModal.is-open { display: block; }
.cartOverlay { position: absolute; inset: 0; background: rgba(0,0,0,.45); }

.cartPanel {
  position: absolute;
  right: 1dvw;
  top: 8rem;
  height: 84dvh;
  width: min(420px, 92vw);
  display: flex;
  flex-direction: column;
  animation: slidein .2s ease-out;
  -webkit-backdrop-filter: blur(20px);
  backdrop-filter: blur(20px);
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  border-radius: 16px;
  box-shadow: 0 8px 32px rgba(0,0,0,.35);
}

@keyframes slidein {
  from { transform: translateX(20px); opacity: .6 }
  to { transform: none; opacity: 1 }
}

.cartHeader {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: .9rem 1rem;
  border-bottom: 1px solid var(--divider);
}
.cartHeader h4#cartTitle { color: var(--text-strong); }
.authClose {
  color: var(--text);
  background: transparent;
  border: 0;
  font-size: 1.25rem;
  line-height: 1;
  cursor: pointer;
}
.authClose:hover { color: var(--text-strong); }

.cartContent { padding: 1rem; overflow: auto; flex: 1; color: var(--text); }
.cartEmpty { text-align: center; padding: 2rem 1rem; color: var(--text-dim); }
.cartLoginCTA { display: flex; flex-direction: column; gap: .8rem; align-items: center; }
.cartLoginCTA .btnPrimary { width: 100%; max-width: 260px; }

.cartItem {
  display: flex;
  gap: .8rem;
  align-items: center;
  padding: .6rem 0;
  border-bottom: 1px solid var(--divider);
}
.cartItem img {
  width: 64px;
  height: 64px;
  object-fit: cover;
  border-radius: .5rem;
  box-shadow: 0 2px 10px rgba(0,0,0,.25);
}
.cartItemInfo { flex: 1; }
.cartItemInfo .title { color: var(--text-strong); font-weight: 600; }
.cartItemInfo .muted,
.cartItemInfo small,
.meta, .subtitle { color: var(--text-dim); font-size: .9rem; }
.cartItem .price { color: var(--text-strong); font-weight: 700; }

.cartFooter {
  padding: 1rem;
  border-top: 1px solid var(--divider);
  background: linear-gradient(180deg, transparent, rgba(0,0,0,.15));
}
.cartFooter .row { display: flex; justify-content: space-between; margin: .2rem 0 }
.cartFooter .row strong { color: var(--text-strong); }
.cartFooter .row span { color: var(--text); }
.cartTotals { display: grid; gap: .4rem; margin-bottom: .8rem; }

.btnPrimary {
  background: var(--btn-bg);
  color: var(--btn-text);
  border: 0;
  border-radius: 14px;
  padding: 1rem 1.2rem;
  width: 100%;
  font-weight: 700;
  box-shadow: var(--btn-shadow);
  transition: transform .06s ease, filter .2s ease, box-shadow .2s ease;
}
.btnPrimary:hover { filter: brightness(1.05); box-shadow: 0 10px 28px rgba(255,59,48,.45); }
.btnPrimary:active { transform: translateY(1px) scale(.997); }
.btnText { color: inherit; }

.hr, .divider {
  height: 1px;
  background: var(--divider);
  border: 0;
}

.cartRow{
  display:grid;
  grid-template-columns: 64px minmax(0,1fr) 9.5ch auto;
  gap: 12px;
  align-items: center;
  padding: 10px 6px;
}

.cartInfo{ 
  min-width: 0;
  display: grid;
  gap: 2px;
  align-self: start;
  line-height: 1.15;
}

.cartThumb{ width:62px; height:62px; border-radius:12px; object-fit:cover; }
.cartThumb.skel{ background:#2a2a2e; }

.cartInfo .title{
  max-width: 6rem;
  font-weight: 800;
  font-size: .98rem;
  color: var(--btn-text);
  text-decoration: none;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
  text-overflow: ellipsis;
  overflow-wrap: anywhere;
  hyphens: auto;
}

.cartInfo .meta{
  font-size: .85rem;
  opacity: .8;
  color: var(--text-dim);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.cartLinePrice {
    min-width: 9.5ch;
    font-weight: 800;
    font-feature-settings: "tnum" 1;
    -webkit-font-smoothing: antialiased;
}

/* ações compactas */
.cartLineActions{ justify-self: end; }
.qtyCompact{
  display:flex; align-items:center; gap:8px;
  padding: 4px 8px;
  border-radius: 12px;
  backdrop-filter: blur(20px);
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
}

.qtyCompact .qtyNum{
  min-width: 2ch; text-align:center; font-weight:800; color:var(--btn-text);
  font-feature-settings: "tnum" 1;
}

.qtyCompact button {
    width: 30px;
    height: 30px;
    border-radius: 10px;
    border: 1px solid #eee;
    background: #f8f9fa;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
}

.qtyCompact button:hover{ background:#f1f3f5; }
.qtyCompact .ghost{ background:transparent; border-color:transparent; margin-left:4px; }
.qtyCompact .ghost:hover{ background:#fff0f0; }

.cartThumbLink, .cartTitleLink { cursor: pointer; }
.cartItem { cursor: pointer; }
.cartItem .cartLineActions, .cartItem .cartLineActions * { cursor: default; }

/* ===== Carrinho full-screen <= 600px (idêntico ao menu) ===== */
@media (max-width: 600px){
  /* painel ocupa a tela e desliza de baixo pra cima, como o menu */
  .cartPanel{
    position: absolute;
    inset: 0;
    width: 100vw; height: 100dvh;
    border-radius: 0; box-shadow: none; border: 0;
    background: var(--menu-bg, var(--glass-bg));
    -webkit-backdrop-filter: blur(14px);
    backdrop-filter: blur(14px);
    display: grid; grid-template-rows: auto 1fr auto;
    transform: translateY(100%);
    transition: transform .28s cubic-bezier(.2,.8,.2,1);
  }
  .cartModal.is-open .cartPanel{ transform: translateY(0); }

  /* overlay igual ao do menu */
  .cartOverlay{
    background: rgba(2,6,23,.45);
    backdrop-filter: blur(6px);
  }

  /* HEADER = igual ao .modalMenu__header */
  .cartHeader{
    display:flex; align-items:center; justify-content:space-between;
    gap:10px; padding:16px;
    border-bottom:1px solid var(--menu-border, var(--divider));
    font:700 1rem/1 var(--font-heading, Poppins, system-ui);
    text-transform:uppercase; letter-spacing:.4px;
    color:var(--menu-ink, var(--text));
  }
  .cartHeader #cartTitle{ margin:0; }

  /* Botão fechar = igual ao .modalMenu__close */
  .authClose{
    width:40px; height:40px; border-radius:10px;
    display:inline-grid; place-items:center;
    background:transparent; border:1px solid transparent;
    color:var(--menu-ink, var(--text));
    transition:background .15s ease, border-color .15s ease, transform .1s ease;
    font-size:1.1rem; line-height:1;
  }
  .authClose:hover{
    background:rgba(255,255,255,.06);
    border-color:var(--menu-border, var(--glass-border));
    color:var(--menu-ink, var(--text-strong));
    transform:translateY(-1px);
  }

  /* Ícone Lucide dentro do botão */
  .authClose svg{ width:22px; height:22px; stroke:currentColor; }
}

@media (max-width: 410px){
  .cartRow{
    grid-template-columns: 64px minmax(0,1fr) auto;
    grid-template-areas:
      "thumb info actions"
      "thumb price actions";
  }
  .cartThumb{ grid-area: thumb; }
  .cartInfo{  grid-area: info; }
  .cartLinePrice{ grid-area: price; margin-top: 2px; }
  .cartLineActions{ grid-area: actions; }
}