/* =============================================================
   FF CONSULTING — Styles boutique (offres, panier, commande)
   ============================================================= */

/* ---------- Grille des offres ---------- */
.shop-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.offer{position:relative;display:flex;flex-direction:column;background:var(--white);border:1px solid var(--line-soft);border-radius:var(--r);padding:32px 30px;transition:transform .3s,box-shadow .3s,border-color .3s}
.offer:hover{transform:translateY(-5px);box-shadow:var(--shadow);border-color:transparent}
.offer--best{border-color:var(--gold);background:linear-gradient(180deg,#fff, #fdf8ee)}
.offer__flag{position:absolute;top:-12px;left:30px;background:var(--gold);color:#1a1206;font-size:11.5px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;padding:6px 12px;border-radius:100px}
.offer__top{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:14px}
.offer__cat{font-size:12px;text-transform:uppercase;letter-spacing:.12em;color:var(--gold-2);font-weight:600}
.offer__num{font-family:var(--serif);font-size:1.6rem;color:var(--paper-3)}
.offer h3{font-size:1.5rem;margin-bottom:10px}
.offer__tag{font-size:14.5px;color:var(--ink-2);line-height:1.55;flex:1}
.offer__price{margin:22px 0 4px;display:flex;align-items:baseline;gap:8px}
.offer__price b{font-family:var(--serif);font-size:2rem;color:var(--ink)}
.offer__price span{font-size:13px;color:var(--ink-3)}
.offer__unit{font-size:13px;color:var(--ink-3);margin-bottom:20px}
.offer__delai{display:inline-flex;align-items:center;gap:7px;font-size:13px;color:var(--ink-3);margin-bottom:20px}
.offer__delai::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--gold)}
.offer__actions{display:flex;gap:10px;margin-top:auto}
.offer__actions .btn{flex:1;justify-content:center;padding:13px 16px;font-size:14px}

/* ---------- Détail d'une offre ---------- */
.detail{display:grid;grid-template-columns:1.4fr 1fr;gap:clamp(36px,5vw,64px);align-items:start}
.detail__cat{font-size:12.5px;text-transform:uppercase;letter-spacing:.14em;color:var(--gold-2);font-weight:600}
.detail h1{font-size:clamp(2.2rem,4.5vw,3.4rem);margin:14px 0 18px}
.detail__desc{font-size:17px;color:var(--ink-2);line-height:1.7;margin-bottom:30px}
.detail__includes{list-style:none;display:grid;gap:13px;margin-top:10px}
.detail__includes li{position:relative;padding-left:32px;font-size:15.5px;color:var(--ink)}
.detail__includes li::before{content:"";position:absolute;left:0;top:2px;width:20px;height:20px;border-radius:50%;background:var(--paper-2);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23B6883C' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:center}
.buybox{position:sticky;top:96px;background:var(--white);border:1px solid var(--line-soft);border-radius:var(--r);padding:30px;box-shadow:var(--shadow)}
.buybox__price{display:flex;align-items:baseline;gap:8px;margin-bottom:6px}
.buybox__price b{font-family:var(--serif);font-size:2.4rem;color:var(--ink)}
.buybox__price span{font-size:14px;color:var(--ink-3)}
.buybox__unit{font-size:14px;color:var(--ink-3);margin-bottom:22px}
.buybox__meta{display:grid;gap:12px;margin:22px 0;padding:20px 0;border-top:1px solid var(--line-soft);border-bottom:1px solid var(--line-soft)}
.buybox__meta div{display:flex;justify-content:space-between;font-size:14px}
.buybox__meta span:first-child{color:var(--ink-3)}
.buybox__meta span:last-child{color:var(--ink);font-weight:500}
.buybox .btn{width:100%;justify-content:center}
.buybox__fine{font-size:12.5px;color:var(--ink-3);margin-top:16px;line-height:1.5}

/* ---------- Panier ---------- */
.shop-2col{display:grid;grid-template-columns:1.6fr 1fr;gap:clamp(32px,5vw,56px);align-items:start}
.shop-back{display:inline-flex;align-items:center;gap:8px;font-size:14px;color:var(--ink-3);margin-bottom:28px;font-weight:500}
.shop-back:hover{color:var(--gold-2)}
.shop-row{display:grid;grid-template-columns:1fr auto auto auto;gap:24px;align-items:center;padding:24px 0;border-bottom:1px solid var(--line-soft)}
.shop-row:first-child{border-top:1px solid var(--line-soft)}
.shop-row__cat{font-size:11.5px;text-transform:uppercase;letter-spacing:.1em;color:var(--gold-2);font-weight:600;margin-bottom:4px}
.shop-row__name{font-family:var(--serif);font-size:1.25rem}
.shop-row__name a:hover{color:var(--gold-2)}
.shop-row__sub{font-size:13px;color:var(--ink-3);margin-top:4px}
.shop-row__price{font-family:var(--serif);font-size:1.2rem;color:var(--ink);min-width:90px;text-align:right}
.shop-qty{display:inline-flex;align-items:center;border:1.5px solid var(--line);border-radius:100px;overflow:hidden;background:#fff}
.shop-qty button{width:38px;height:40px;background:none;border:none;cursor:pointer;font-size:18px;color:var(--ink);transition:background .2s}
.shop-qty button:hover{background:var(--paper-2)}
.shop-qty input{width:42px;height:40px;border:none;text-align:center;font-family:var(--sans);font-size:15px;font-weight:600;color:var(--ink);background:none}
.shop-qty input:focus{outline:none}
.shop-rm{background:none;border:none;cursor:pointer;font-size:13px;color:var(--ink-3);text-decoration:underline;text-underline-offset:3px;padding:0}
.shop-rm:hover{color:#9a3326}

.shop-sum{position:sticky;top:96px;background:var(--white);border:1px solid var(--line-soft);border-radius:var(--r);padding:30px;box-shadow:var(--shadow)}
.shop-sum h3{font-size:1.3rem;margin-bottom:22px}
.shop-sum__r{display:flex;justify-content:space-between;font-size:15px;color:var(--ink-2);padding:9px 0}
.shop-sum__t{display:flex;justify-content:space-between;align-items:baseline;margin-top:8px;padding-top:16px;border-top:1.5px solid var(--ink)}
.shop-sum__t b{font-family:var(--serif);font-size:1.7rem;color:var(--ink)}
.shop-sum__acompte{display:flex;justify-content:space-between;font-size:13.5px;color:var(--gold-2);font-weight:600;margin-top:12px;padding:12px;background:var(--paper-2);border-radius:10px}
.shop-sum .btn{width:100%;justify-content:center;margin-top:22px}
.shop-fine{font-size:12.5px;color:var(--ink-3);margin-top:16px;line-height:1.55}

.shop-empty{text-align:center;padding:60px 20px;max-width:480px;margin:0 auto}
.shop-empty h3{font-size:1.8rem;margin-bottom:12px}
.shop-empty p{margin-bottom:26px}

/* ---------- Étapes / confirmation ---------- */
.shop-steps{list-style:none;display:grid;gap:14px;margin-top:10px}
.shop-steps li{position:relative;padding-left:30px;font-size:15.5px;color:var(--ink-2)}
.shop-steps li::before{counter-increment:s;content:counter(s);position:absolute;left:0;top:0;width:21px;height:21px;background:var(--ink);color:var(--gold-soft);border-radius:50%;font-size:12px;font-weight:700;display:grid;place-items:center}
.shop-steps{counter-reset:s}
.shop-conf{max-width:640px}

@media(max-width:920px){
  .shop-grid{grid-template-columns:repeat(2,1fr)}
  .detail,.shop-2col{grid-template-columns:1fr}
  .buybox,.shop-sum{position:static}
}
@media(max-width:620px){
  .shop-grid{grid-template-columns:1fr}
  .shop-row{grid-template-columns:1fr auto;gap:14px}
  .shop-row__price{grid-column:2;text-align:right}
}
