.rzvp{max-width:980px;margin:10px 0;padding:0}
.rzvp-toggle{
  width:100%;
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 16px;border-radius:14px;border:1px solid rgba(0,0,0,.12);
  background:#fff;font-weight:700;cursor:pointer;
}
.rzvp-caret{opacity:.7}

/* footer */
.rzvp-footer{
  margin-top:10px;
  display:flex;flex-wrap:wrap;align-items:center;gap:10px;
  justify-content:space-between;
}
.rzvp-price{font-weight:900;font-size:18px;display:flex;flex-direction:column;gap:4px}
.rzvp-price-sub{font-weight:600;font-size:13px;opacity:.7}

.rzvp-actions{display:flex;align-items:center;gap:10px}
.rzvp-qty{
  display:flex;align-items:center;gap:0;
  border:1px solid rgba(0,0,0,.12);
  border-radius:999px;overflow:hidden;background:#fff;
}
.rzvp-qtybtn{width:42px;height:42px;border:0;background:transparent;cursor:pointer;font-size:18px}
.rzvp-qtyinput{width:56px;height:42px;border:0;text-align:center;outline:none}
.rzvp-add{
  height:42px;padding:0 16px;border-radius:999px;border:0;
  background:#000;color:#fff;font-weight:900;cursor:pointer;
  opacity:.35;
}
.rzvp-add:enabled{opacity:1}

/* MODAL (toujours au-dessus) */
.rzvp-modal,
.rzvp-confirm{
  position:fixed;
  inset:0;
  z-index:2147483647; /* max safe */
}
.rzvp-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.45)}
.rzvp-dialog,
.rzvp-confirm-dialog{
  position:absolute;left:50%;top:50%;
  transform:translate(-50%,-50%);
  width:min(920px, calc(100vw - 28px));
  max-height:min(560px, calc(100vh - 28px));
  background:#fff;border-radius:18px;overflow:hidden;
  border:1px solid rgba(0,0,0,.12);
  box-shadow:0 30px 90px rgba(0,0,0,.35);
}

/* Head */
.rzvp-head{
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 16px;border-bottom:1px solid rgba(0,0,0,.08);
}
.rzvp-title{font-weight:800;font-size:18px}
.rzvp-close{
  border:0;background:transparent;cursor:pointer;
  width:44px;height:44px;border-radius:999px;
  display:flex;align-items:center;justify-content:center;
  font-size:22px;line-height:1;opacity:.75;
}
.rzvp-close:hover{background:rgba(0,0,0,.06);opacity:1}

/* Table */
.rzvp-tablewrap{max-height:calc(560px - 58px);overflow:auto}
.rzvp-table{width:100%;border-collapse:collapse}
.rzvp-table th,.rzvp-table td{
  padding:12px 14px;border-bottom:1px solid rgba(0,0,0,.06);
  text-align:left;font-size:14px;
}
.rzvp-table thead th{position:sticky;top:0;background:#fff;z-index:1}
.rzvp-row{cursor:pointer}
.rzvp-row:hover{background:rgba(0,0,0,.03)}
.rzvp-row.is-active{background:rgba(0,0,0,.06)}
.rzvp-badge{display:inline-block;padding:4px 10px;border-radius:999px;background:rgba(0,0,0,.06);font-size:12px}

/* confirm */
.rzvp-confirm-dialog{width:min(520px, calc(100vw - 28px)); max-height:none}
.rzvp-confirm-body{padding:14px 16px}
.rzvp-confirm-text{font-size:14px;line-height:1.5;opacity:.9}
.rzvp-confirm-actions{
  display:flex;gap:10px;justify-content:flex-end;
  padding:12px 16px;border-top:1px solid rgba(0,0,0,.08);
}
.rzvp-confirm-continue{
  height:42px;padding:0 14px;border-radius:999px;border:1px solid rgba(0,0,0,.15);
  background:#fff;font-weight:800;cursor:pointer;
}
.rzvp-confirm-cart{
  height:42px;display:inline-flex;align-items:center;justify-content:center;
  padding:0 14px;border-radius:999px;border:0;background:#000;color:#fff;
  font-weight:900;text-decoration:none;
}

body.rzvp-lock{overflow:hidden}

@media (max-width:680px){
  .rzvp-footer{flex-direction:column;align-items:stretch}
  .rzvp-actions{width:100%;justify-content:space-between}
  .rzvp-add{width:100%}
  .rzvp-dialog{width:calc(100vw - 18px)}
}
