.cfp-cb{font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;color:#0f172a}
.cfp-cb *{box-sizing:border-box}
.cfp-cb-banner{width:100%;margin:0 0 18px 0}
.cfp-banner-inner{border-radius:16px;overflow:hidden;position:relative;border:1px solid rgba(15,23,42,.12)}
.cfp-banner-inner img{display:block;width:100%;height:auto}
.cfp-banner-overlay{position:absolute;inset:0;display:flex;align-items:flex-end;padding:20px;background:linear-gradient(180deg, rgba(0,0,0,0) 40%, rgba(0,0,0,.65) 100%)}
.cfp-banner-text{color:#fff;max-width:900px}
.cfp-banner-badge{display:inline-block;background:rgba(255,255,255,.2);border:1px solid rgba(255,255,255,.35);padding:4px 10px;border-radius:999px;font-weight:700;font-size:12px;letter-spacing:.5px}
.cfp-banner-text h1{margin:8px 0 6px 0;font-size:34px;line-height:1.1}
.cfp-banner-text p{margin:0;font-size:16px;opacity:.95}
.cfp-cb-main{display:flex;gap:18px;align-items:flex-start}
.cfp-cb-left{flex:1;min-width:320px}
.cfp-cb-right{width:360px;min-width:320px;position:sticky;top:18px}
@media (max-width: 980px){
  .cfp-cb-main{flex-direction:column}
  .cfp-cb-right{width:100%;position:static}
}
.cfp-cb-toolbar{display:flex;justify-content:space-between;gap:12px;align-items:flex-end;margin-bottom:12px}
.cfp-cb-title{margin:0;font-size:22px}
.cfp-cb-pickup{display:grid;grid-template-columns:auto 160px auto 160px;gap:8px;align-items:center}
.cfp-cb-pickup label{font-size:12px;color:#475569}
.cfp-cb-pickup input,.cfp-cb-pickup select{padding:8px 10px;border-radius:10px;border:1px solid rgba(15,23,42,.18);background:#fff}
@media (max-width: 720px){
  .cfp-cb-pickup{grid-template-columns:1fr;align-items:stretch}
}
.cfp-cb-menu{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
@media (max-width: 720px){ .cfp-cb-menu{grid-template-columns:1fr} }
.cfp-item{border:1px solid rgba(15,23,42,.12);border-radius:16px;overflow:hidden;background:#fff;box-shadow:0 6px 20px rgba(2,6,23,.05)}
.cfp-item img{width:100%;height:160px;object-fit:cover;display:block;background:#f1f5f9}
.cfp-item-body{padding:12px}
.cfp-item-top{display:flex;justify-content:space-between;gap:8px;align-items:flex-start}
.cfp-item-name{font-weight:800}
.cfp-item-price{font-weight:800}
.cfp-item-variant{margin-top:8px}
.cfp-item-variant select{width:100%;padding:8px 10px;border-radius:12px;border:1px solid rgba(15,23,42,.18)}
.cfp-item-actions{margin-top:10px;display:flex;gap:10px;align-items:center}
.cfp-qty{display:flex;gap:8px;align-items:center}
.cfp-qty button{width:34px;height:34px;border-radius:10px;border:1px solid rgba(15,23,42,.18);background:#fff;font-weight:900;cursor:pointer}
.cfp-add{flex:1;padding:10px 12px;border-radius:12px;border:1px solid rgba(15,23,42,.18);background:#0f172a;color:#fff;font-weight:800;cursor:pointer}
.cfp-cb-card{border:1px solid rgba(15,23,42,.12);border-radius:16px;background:#fff;box-shadow:0 6px 20px rgba(2,6,23,.05);padding:14px;margin-bottom:12px}
.cfp-cb-card h3{margin:0 0 10px 0;font-size:16px}
.cfp-field{margin-bottom:10px}
.cfp-field label{display:block;font-size:12px;color:#475569;margin-bottom:4px}
.cfp-field input{width:100%;padding:10px 12px;border-radius:12px;border:1px solid rgba(15,23,42,.18)}
.cfp-cart-row{display:flex;justify-content:space-between;gap:10px;padding:8px 0;border-bottom:1px solid rgba(15,23,42,.08)}
.cfp-cart-row:last-child{border-bottom:none}
.cfp-cart-row small{display:block;color:#64748b;margin-top:2px}
.cfp-cart-actions{display:flex;gap:8px;align-items:center}
.cfp-cart-actions button{border:1px solid rgba(15,23,42,.18);background:#fff;border-radius:10px;padding:6px 10px;cursor:pointer}
.cfp-cb-totals{display:flex;justify-content:space-between;align-items:center;margin-top:8px;padding-top:8px;border-top:1px solid rgba(15,23,42,.08)}
.cfp-pay-btn{width:100%;padding:12px 14px;border-radius:14px;border:0;background:#16a34a;color:#fff;font-weight:900;cursor:pointer}
.cfp-pay-btn[disabled]{opacity:.6;cursor:not-allowed}
.cfp-status{margin-top:10px;font-size:13px;color:#334155;min-height:18px}
.cfp-status.error{color:#b91c1c}
.cfp-status.ok{color:#166534}
.cfp-card-container{padding:10px;border:1px solid rgba(15,23,42,.18);border-radius:14px}


/* QR block (generated pages) */
.cfp-cb-qr{
  margin-top:16px;
  padding:16px;
  border:1px solid rgba(0,0,0,.08);
  border-radius:14px;
  background:#fff;
}
.cfp-cb-qr__head{
  display:flex;
  gap:10px;
  align-items:baseline;
  justify-content:space-between;
  margin-bottom:12px;
}
.cfp-cb-qr__head span{ color:#555; font-size:13px; }
.cfp-cb-qr__grid{
  display:flex;
  gap:14px;
  flex-wrap:wrap;
}
.cfp-cb-qr__card{
  display:block;
  width:220px;
  text-decoration:none;
  color:inherit;
  border:1px solid rgba(0,0,0,.10);
  border-radius:14px;
  padding:10px;
  background:#fafafa;
}
.cfp-cb-qr__img{
  width:100%;
  height:auto;
  border-radius:10px;
  display:block;
}
.cfp-cb-qr__label{ font-weight:700; margin-top:8px; }
.cfp-cb-qr__hint{ font-size:12px; color:#555; margin-top:2px; }
@media (max-width: 640px){
  .cfp-cb-qr__card{ width:100%; }
}

.cfp-cb-thankyou{
  max-width:720px;
  margin:0 auto;
  padding:18px 16px;
}
.cfp-cb-thankyou__logo img{
  max-width:240px;
  height:auto;
}
.cfp-cb-thankyou__event{
  margin-top:-6px;
  color:#555;
}
.cfp-cb-thankyou__meta{
  margin-top:14px;
  padding-top:12px;
  border-top:1px solid rgba(0,0,0,.08);
  display:grid;
  gap:8px;
}
