/* Panier — handoff. Layout partage avec le checkout (.layout 1fr/372px). */
/* padding vertical uniquement : l'horizontal vient du .wrap (alignement du titre sur le contenu). */
.page-head{padding-top:34px;padding-bottom:8px;}
.page-head h1{font-size:clamp(28px,3.2vw,40px);font-weight:800;color:var(--ink);margin:0;}
.page-head .sub{margin-top:8px;font-size:15px;color:var(--ink-soft);}

.layout{display:grid;grid-template-columns:1fr 372px;gap:32px;align-items:start;padding-top:26px;padding-bottom:70px;}

/* Lignes article */
.items{display:flex;flex-direction:column;gap:14px;}
.line{display:grid;grid-template-columns:108px 1fr auto;gap:20px;padding:20px;align-items:start;
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);}
.line .visual{width:108px;height:124px;border-radius:11px;overflow:hidden;background:var(--bg-soft);}
.line .visual img{width:100%;height:100%;object-fit:cover;display:block;}
.l-info{display:flex;flex-direction:column;gap:9px;min-width:0;}
.l-info h3{font-family:"Hanken Grotesk";font-size:16px;font-weight:700;color:var(--ink);margin:0;}
.l-meta{display:flex;flex-wrap:wrap;gap:8px;}
.chip{font-size:12px;font-weight:600;color:var(--ink-soft);background:var(--bg-soft);border:1px solid var(--line);
  border-radius:7px;padding:4px 9px;display:inline-flex;align-items:center;gap:6px;}
.l-perso{font-size:13px;color:var(--petrol);font-weight:600;display:inline-flex;align-items:center;gap:7px;}
.l-perso svg{width:14px;height:14px;}
.l-perso svg *{stroke-width:1.8;}
.l-right{display:flex;flex-direction:column;align-items:flex-end;justify-content:space-between;gap:14px;min-height:124px;}
.l-price{font-family:"Archivo";font-weight:700;font-size:18px;color:var(--ink);text-align:right;}
.l-price small{display:block;font-family:"Hanken Grotesk";font-weight:500;font-size:11.5px;color:var(--ink-soft);}
.l-actions{display:flex;align-items:center;gap:12px;}
.qty{display:flex;align-items:center;border:1px solid var(--line);border-radius:9px;overflow:hidden;background:#fff;}
.qty button{width:34px;height:36px;border:none;background:#fff;font-size:17px;color:var(--ink);cursor:pointer;transition:.15s;font-family:inherit;}
.qty button:hover{background:var(--bg-soft);}
.qty input{width:42px;text-align:center;border:none;font-size:14px;font-weight:700;font-family:"Archivo";color:var(--ink);background:#fff;}
.qty input:focus{outline:none;}
.trash{width:36px;height:36px;border-radius:9px;border:1px solid var(--line);background:#fff;color:var(--ink-soft);
  display:grid;place-items:center;cursor:pointer;transition:.15s;}
.trash:hover{border-color:#c0392b;color:#c0392b;}
.trash svg{width:16px;height:16px;}
.trash svg *{stroke-width:1.7;}

.items-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;}
.items-head .cnt{font-size:14px;color:var(--ink-soft);}
.continue{margin-top:22px;display:inline-flex;align-items:center;gap:9px;font-size:14px;font-weight:600;color:var(--petrol);}
.continue svg{width:17px;height:17px;}

/* Logo du panier */
.cart-logo{margin-bottom:16px;padding:16px 20px;display:flex;gap:14px;align-items:center;background:var(--petrol-tn);
  border:1px solid oklch(85% 0.04 215);border-radius:var(--radius);flex-wrap:wrap;}
.cart-logo img{width:52px;height:52px;object-fit:contain;background:#fff;border-radius:10px;border:1px solid var(--line);}
.cart-logo .txt{font-size:13.5px;color:var(--petrol-dk);flex:1;min-width:160px;}
.cart-logo .txt b{display:block;}
.cart-logo form{display:flex;align-items:center;gap:8px;}
.cart-logo input[type="file"]{font-size:12.5px;max-width:210px;}
.cart-logo button{border:1px solid oklch(85% 0.04 215);background:#fff;border-radius:9px;padding:8px 14px;
  font:inherit;font-size:13px;font-weight:600;color:var(--petrol-dk);cursor:pointer;}

/* Badge pending */
.pending-badge{display:inline-flex;padding:3px 10px;border-radius:999px;background:oklch(96% 0.03 90);
  color:oklch(52% 0.11 75);border:1px solid oklch(88% 0.06 85);font-size:12px;font-weight:600;}
.pending-note{margin-top:14px;font-size:13px;color:var(--ink-soft);}

/* Recapitulatif */
.summary{position:sticky;top:96px;padding:24px;display:flex;flex-direction:column;gap:16px;
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);}
.summary h2{font-size:18px;font-weight:800;color:var(--ink);margin:0;}
.sum-rows{display:flex;flex-direction:column;gap:11px;}
.sum-row{display:flex;align-items:center;justify-content:space-between;font-size:14px;color:var(--ink-soft);}
.sum-row b{color:var(--ink);font-weight:600;}
.sum-row.free b{color:var(--ok);}
.sum-div{height:1px;background:var(--line);}
.sum-total{display:flex;align-items:baseline;justify-content:space-between;}
.sum-total .lbl{font-size:15px;font-weight:700;color:var(--ink);}
.sum-total .val{font-family:"Archivo";font-weight:800;font-size:26px;color:var(--ink);}
.sum-total .val small{display:block;font-family:"Hanken Grotesk";font-weight:500;font-size:11.5px;color:var(--ink-soft);text-align:right;}
.sum-re{display:flex;flex-direction:column;gap:10px;margin-top:2px;}
.sum-re .r{display:flex;align-items:center;gap:10px;font-size:12.5px;color:var(--ink-soft);}
.sum-re .r svg{width:15px;height:15px;color:var(--petrol);flex:none;}
.sum-re .r svg *{stroke-width:1.8;}

.empty{padding-top:70px;padding-bottom:70px;text-align:center;color:var(--ink-soft);}
.empty .btn{margin-top:18px;}

@media(max-width:980px){
  .layout{grid-template-columns:1fr;}
  .summary{position:static;}
}
@media(max-width:560px){
  .line{grid-template-columns:84px 1fr;gap:14px;}
  .line .visual{width:84px;height:96px;}
  .l-right{grid-column:1 / -1;flex-direction:row;align-items:center;min-height:0;justify-content:space-between;}
}
