/* ==================================================
   IZY PARRAINAGE – FINTECH UI (PLUGIN SAFE)
   Version: 1.2 PRO
   Compatible: Tous thèmes WordPress
================================================== */

/* Scope global */
.izy-ref-wrap {
  max-width: 1100px;
  margin: 18px auto;
  padding: 18px;
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Arial;
  background: #f6f8fc;
  border-radius: 22px;
}

/* Sécurité box-model */
.izy-ref-wrap *,
.izy-ref-wrap *::before,
.izy-ref-wrap *::after {
  box-sizing: border-box;
}

/* =====================
   TITRES / HEADER
===================== */
.izy-ref-title {
  margin: 0;
  font-size: 22px;
  font-weight: 900;
}

.izy-ref-sub {
  margin-top: 6px;
  color: #5b616a;
}

.izy-ref-badge {
  display: inline-block;
  padding: 4px 12px;
  border-radius: 999px;
  background: #eef2ff;
  color: #1f2a44;
  font-weight: 800;
  border: 1px solid rgba(79,70,229,.18);
}

/* Header */
.izy-ref-header {
  display: flex;
  gap: 14px;
  justify-content: space-between;
  align-items: flex-start;
  flex-wrap: wrap;
  background: #fff;
  border: 1px solid #e6eaf0;
  border-radius: 18px;
  padding: 16px;
  box-shadow: 0 10px 26px rgba(16,24,40,.05);
}

/* Boutons */
.izy-ref-btn {
  appearance: none;
  border: 0;
  border-radius: 14px;
  padding: 12px 16px;
  font-weight: 900;
  cursor: pointer;
  background: #0b1324;
  color: #fff;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  transition: transform .15s ease, box-shadow .15s ease, opacity .15s ease;
}

.izy-ref-btn:hover {
  transform: translateY(-1px);
  box-shadow: 0 10px 18px rgba(16,24,40,.12);
}

.izy-ref-btn:active{
  transform: translateY(0);
  opacity: .92;
}

.izy-ref-btn-ghost {
  background: #fff;
  border: 1px solid #d6dbe3;
  color: #0b1324;
}

.izy-ref-btn-wa {
  background: #0aa35b;
}

.izy-ref-btn-block {
  width: 100%;
  margin-top: 18px;
}

/* =====================
   ALERTES
===================== */
.izy-ref-alert {
  border-radius: 14px;
  padding: 12px 14px;
  margin: 12px 0;
  font-weight: 700;
  border: 1px solid;
}

.izy-ref-alert-ok {
  background: #ecfdf5;
  border-color: #10b981;
  color: #065f46;
}

.izy-ref-alert-warn {
  background: #fffbeb;
  border-color: #f59e0b;
  color: #92400e;
}

.izy-ref-alert-err {
  background: #fef2f2;
  border-color: #ef4444;
  color: #991b1b;
}

/* =====================
   CARDS / PANELS
===================== */
.izy-ref-panel {
  background: #fff;
  border: 1px solid #e6eaf0;
  border-radius: 18px;
  padding: 16px;
  margin-top: 14px;
  box-shadow: 0 8px 20px rgba(16,24,40,.04);
}

.izy-ref-panel h3 {
  margin: 0 0 10px;
  font-size: 16px;
  font-weight: 900;
}

.izy-ref-muted {
  color: #6b7280;
  font-size: 14px;
}

/* =====================
   GRID SOLDES
===================== */
.izy-ref-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
  margin: 14px 0;
}

.izy-ref-card {
  background: #fff;
  border: 1px solid #e6eaf0;
  border-radius: 18px;
  padding: 16px;
}

.izy-ref-card-label {
  font-size: 12px;
  font-weight: 800;
  color: #6b7280;
  text-transform: uppercase;
}

.izy-ref-card-value {
  margin-top: 8px;
  font-size: 26px;
  font-weight: 900;
  color: #0b1324;
}

/* =====================
   FORM ENGINE (THEME SAFE)
===================== */

/* Neutralise les thèmes */
.izy-ref-wrap input,
.izy-ref-wrap select,
.izy-ref-wrap textarea,
.izy-ref-wrap button {
  all: unset;
  box-sizing: border-box;
  font-family: inherit;
}

/* Inputs */
.izy-ref-wrap input[type="text"],
.izy-ref-wrap input[type="number"],
.izy-ref-wrap select {
  width: 100%;
  display: block;
  padding: 14px 16px;
  border-radius: 14px;
  border: 1px solid #d6dbe3;
  background: #fff;
  font-size: 16px;
}

/* Focus */
.izy-ref-wrap input:focus,
.izy-ref-wrap select:focus {
  border-color: #4f46e5;
  box-shadow: 0 0 0 4px rgba(79,70,229,.15);
  outline: none;
}

/* Labels */
.izy-ref-wrap label {
  display: block;
  margin-bottom: 6px;
  font-weight: 800;
  font-size: 13px;
  color: #374151;
}

/* Grid formulaire */
.izy-ref-form-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
}

/* Bouton retrait */
.izy-ref-wrap form button {
  display: block;
  width: 100%;
  padding: 16px;
  margin-top: 18px;
  background: #0b1324;
  color: #fff;
  border-radius: 16px;
  font-size: 16px;
  font-weight: 900;
  cursor: pointer;
  text-align: center;
}

/* =====================
   TABLE RESPONSIVE
===================== */
.izy-ref-table {
  margin-top: 12px;
  border: 1px solid #e6eaf0;
  border-radius: 16px;
  overflow: hidden;
}

.izy-ref-tr {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr 1fr;
  border-top: 1px solid #eef2f7;
}

.izy-ref-th {
  background: #f8fafc;
  font-weight: 900;
}

.izy-ref-tr > div {
  padding: 12px;
}

.izy-ref-pill {
  display: inline-block;
  padding: 4px 10px;
  border-radius: 999px;
  background: #eef2ff;
  font-weight: 800;
  font-size: 12px;
}

/* =====================
   RESPONSIVE MOBILE
===================== */
@media (max-width: 768px) {

  .izy-ref-grid {
    grid-template-columns: 1fr;
  }

  .izy-ref-form-grid {
    grid-template-columns: 1fr;
  }

  .izy-ref-header {
    flex-direction: column;
  }

  .izy-ref-wrap input,
  .izy-ref-wrap select {
    min-height: 52px;
    font-size: 16px;
  }

  .izy-ref-wrap form button {
    min-height: 56px;
    font-size: 17px;
  }

  .izy-ref-tr {
    grid-template-columns: 1fr;
    border: 1px solid #e6eaf0;
    border-radius: 14px;
    margin-bottom: 10px;
  }

  .izy-ref-th {
    display: none;
  }
}
/* ==================================================
   IZY PARRAINAGE – FORM ENGINE (THEME SAFE + FIXED)
================================================== */

/* Scope total */
.izy-ref-wrap,
.izy-ref-wrap * {
  box-sizing: border-box;
}

/* Reset safe */
.izy-ref-wrap input,
.izy-ref-wrap select,
.izy-ref-wrap button {
  font-family: inherit;
}

/* GRID DU FORMULAIRE */
.izy-ref-form-grid {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 14px !important;
}

/* CHAQUE COLONNE */
.izy-ref-form-grid > div {
  width: 100% !important;
}

/* INPUTS & SELECTS (FIX WIDTH) */
.izy-ref-wrap input[type="text"],
.izy-ref-wrap input[type="number"],
.izy-ref-wrap select {
  display: block !important;
  width: 100% !important;
  min-width: 100% !important;

  padding: 16px 18px !important;
  min-height: 56px !important;

  border-radius: 14px;
  border: 1px solid #d6dbe3;
  background: #ffffff;

  font-size: 17px;
  font-weight: 600;
  line-height: 1.4;
}

/* Focus propre */
.izy-ref-wrap input:focus,
.izy-ref-wrap select:focus {
  outline: none;
  border-color: #4f46e5;
  box-shadow: 0 0 0 4px rgba(79,70,229,.15);
}

/* BOUTON RETRAIT */
.izy-ref-btn-block,
.izy-ref-wrap form button {
  display: block !important;
  width: 100% !important;

  margin-top: 18px;
  padding: 16px;

  background: #0b1324;
  color: #fff;

  border-radius: 14px;
  font-size: 17px;
  font-weight: 900;

  cursor: pointer;
  text-align: center;
}

/* =====================
   MOBILE – FULL STACK
===================== */
@media (max-width: 768px) {

  .izy-ref-form-grid {
    grid-template-columns: 1fr !important;
  }

  .izy-ref-wrap input,
  .izy-ref-wrap select {
    min-height: 58px !important;
    font-size: 18px !important;
  }

  .izy-ref-wrap form button {
    min-height: 60px;
    font-size: 18px;
  }
}


/* =====================
   BANK UPGRADE (v1.8.0)
===================== */

.izy-ref-header{
  background: linear-gradient(135deg, #0b2b6b, #0a7d57);
  color:#fff;
  border-radius:18px;
  padding:18px 18px 16px;
  box-shadow: 0 18px 40px rgba(11,43,107,.18);
  position: relative;
  overflow:hidden;
}
.izy-ref-header:before{
  content:"";
  position:absolute; inset:-40px -60px auto auto;
  width:220px; height:220px;
  background: radial-gradient(circle at 30% 30%, rgba(255,255,255,.22), rgba(255,255,255,0) 60%);
  transform: rotate(12deg);
}
.izy-ref-header h2{ font-weight:900; letter-spacing:.2px; }
.izy-ref-header .izy-ref-badge{
  display:inline-flex; align-items:center; gap:8px;
  padding:8px 12px;
  background: rgba(255,255,255,.14);
  border:1px solid rgba(255,255,255,.18);
  border-radius:999px;
  font-weight:700;
}
.izy-ref-cards .izy-ref-card{
  border:1px solid rgba(10,40,120,.08);
  box-shadow: 0 14px 28px rgba(0,0,0,.05);
}
.izy-ref-card .izy-ref-card-title{
  display:flex; align-items:center; gap:10px;
}
.izy-ref-card .izy-ref-dot{
  width:10px; height:10px; border-radius:50%;
  background: linear-gradient(135deg,#0d6efd,#0a7d57);
  box-shadow: 0 0 0 4px rgba(13,110,253,.12);
}
.izy-ref-table thead th{
  background: #0b2b6b;
  color:#fff;
}
.izy-ref-btn{
  border-radius: 12px !important;
  font-weight: 800 !important;
}
.izy-ref-input, .izy-ref-select{
  border-radius: 12px !important;
}
.izy-ref-alert-ip{
  border-left-width: 6px;
}

/* Bank card polish for existing markup */
.izy-ref-grid{
  gap:14px !important;
}
.izy-ref-grid .izy-ref-card{
  border-radius: 18px !important;
  border: 1px solid rgba(11,43,107,.10) !important;
  box-shadow: 0 14px 30px rgba(0,0,0,.06) !important;
  position: relative;
  overflow:hidden;
}
.izy-ref-grid .izy-ref-card:before{
  content:"";
  position:absolute; inset:auto -60px -60px auto;
  width:160px; height:160px;
  background: radial-gradient(circle at 30% 30%, rgba(13,110,253,.14), rgba(10,125,87,0) 65%);
}
.izy-ref-card-label{
  display:flex; align-items:center; gap:10px;
  font-weight:800 !important;
}
.izy-ref-card-label:before{
  content:"";
  width:10px; height:10px; border-radius:50%;
  background: linear-gradient(135deg,#0d6efd,#0a7d57);
  box-shadow: 0 0 0 4px rgba(13,110,253,.10);
}


/* =====================
   CHART + SELECT
===================== */
.izy-ref-row{
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
  margin-top: 8px;
}
.izy-ref-label{
  font-weight: 700;
}
.izy-ref-select{
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px solid rgba(0,0,0,.12);
  background: #fff;
  font-weight: 600;
}
.izy-ref-chart-wrap{
  position: relative;
  height: 320px;
  margin-top: 12px;
  background:#fff;
  border:1px solid rgba(0,0,0,.08);
  border-radius: 16px;
  padding: 12px;
}
.izy-ref-note{
  margin-top: 10px;
  color:#5b616a;
  font-size: 13px;
}

/* =====================
   TOAST
===================== */
.izy-ref-toast{
  position: fixed;
  left: 50%;
  bottom: 22px;
  transform: translateX(-50%);
  padding: 10px 14px;
  border-radius: 999px;
  background: rgba(20, 20, 20, .92);
  color: #fff;
  font-size: 14px;
  font-weight: 700;
  opacity: 0;
  pointer-events:none;
  transition: opacity .18s ease, transform .18s ease;
  z-index: 999999;
}
.izy-ref-toast.show{
  opacity: 1;
  transform: translateX(-50%) translateY(-4px);
}

/* Facebook button */
.izy-ref-btn-fb{
  text-decoration:none;
}


/* ===== 2026 dashboard refresh ===== */
.izy-ref-wrap{background:linear-gradient(180deg,#f5f7ff 0%,#eef4ff 100%);border:1px solid rgba(148,163,184,.16);box-shadow:0 24px 60px rgba(15,23,42,.06)}
.izy-ref-hero{display:grid;grid-template-columns:minmax(0,1.4fr) minmax(280px,.9fr);gap:18px;align-items:stretch;background:linear-gradient(135deg,#0f172a 0%,#1d4ed8 55%,#2563eb 100%);border-radius:24px;padding:22px;color:#fff;box-shadow:0 18px 44px rgba(37,99,235,.22)}
.izy-ref-kicker{display:inline-block;padding:7px 12px;border-radius:999px;background:rgba(255,255,255,.14);font-size:12px;font-weight:800;letter-spacing:.02em;text-transform:uppercase}
.izy-ref-hero .izy-ref-title{margin-top:12px;color:#fff;font-size:30px;line-height:1.05}
.izy-ref-hero .izy-ref-sub{margin-top:10px;color:rgba(255,255,255,.82);max-width:680px}
.izy-ref-hero-meta{display:flex;flex-wrap:wrap;gap:10px;margin-top:16px}
.izy-ref-hero-chip{display:inline-flex;align-items:center;gap:8px;padding:10px 14px;border-radius:999px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.16);font-weight:700;color:#fff}
.izy-ref-hero-chip-soft{background:rgba(15,23,42,.28)}
.izy-ref-actions-hero{display:grid;grid-template-columns:1fr 1fr;gap:10px;align-content:start}
.izy-ref-actions-hero .izy-ref-btn{min-height:48px}
.izy-ref-actions-hero .izy-ref-btn-ghost{background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.16);color:#fff}
.izy-ref-actions-hero .izy-ref-btn-ghost:hover{background:rgba(255,255,255,.18)}
.izy-ref-grid-top{margin-top:18px}
.izy-ref-stat-card{position:relative;overflow:hidden;background:linear-gradient(180deg,#fff 0%,#f8fbff 100%);border-color:#dbe6f5;box-shadow:0 12px 28px rgba(15,23,42,.05)}
.izy-ref-stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#2563eb 0%,#7c3aed 100%)}
.izy-ref-panel{backdrop-filter:blur(6px)}
.izy-ref-panel-accent{border-color:#c7d7fe;background:linear-gradient(180deg,#ffffff 0%,#f7faff 100%)}
.izy-ref-deadline{display:inline-flex;align-items:center;gap:8px;margin:6px 0 14px;padding:10px 14px;border-radius:14px;background:#eff6ff;border:1px solid #bfdbfe;color:#1d4ed8;font-weight:800}
.izy-ref-row-stack-mobile{align-items:end}
.izy-ref-chart-wrap{background:linear-gradient(180deg,#fff 0%,#f8fbff 100%);border:1px solid #dbe6f5;border-radius:18px;padding:16px;min-height:320px}
.izy-ref-note{margin-top:12px;color:#64748b;font-size:13px}
@media (max-width: 900px){.izy-ref-hero{grid-template-columns:1fr}.izy-ref-actions-hero{grid-template-columns:1fr 1fr}.izy-ref-hero .izy-ref-title{font-size:26px}}
@media (max-width: 640px){.izy-ref-wrap{padding:14px;border-radius:18px}.izy-ref-actions-hero,.izy-ref-grid{grid-template-columns:1fr}.izy-ref-row-stack-mobile{display:grid;grid-template-columns:1fr;gap:10px}.izy-ref-card-value{font-size:22px}}


/* ===== 1.9.2 premium polish ===== */
.izy-ref-section-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:10px;flex-wrap:wrap}
.izy-ref-eyebrow{font-size:12px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:#64748b;margin-bottom:6px}
.izy-ref-mini-badge{display:inline-flex;align-items:center;justify-content:center;padding:8px 12px;border-radius:999px;background:linear-gradient(135deg,#dbeafe 0%,#ede9fe 100%);border:1px solid #c7d2fe;color:#1e3a8a;font-weight:800;font-size:12px}
.izy-ref-referrer-card{position:relative;overflow:hidden}
.izy-ref-referrer-card:before{content:"";position:absolute;right:-55px;top:-55px;width:160px;height:160px;border-radius:50%;background:radial-gradient(circle,rgba(59,130,246,.14) 0%,rgba(124,58,237,0) 72%)}
.izy-ref-referrer-box{display:flex;align-items:center;gap:14px;padding:14px;border-radius:18px;background:linear-gradient(180deg,#ffffff 0%,#f8fbff 100%);border:1px solid #dbe6f5;box-shadow:0 12px 28px rgba(37,99,235,.07)}
.izy-ref-avatar{width:52px;height:52px;border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:22px;font-weight:900;color:#fff;background:linear-gradient(135deg,#2563eb 0%,#7c3aed 100%);box-shadow:0 12px 24px rgba(37,99,235,.24)}
.izy-ref-referrer-name{font-size:18px;font-weight:900;color:#0f172a;margin-bottom:4px}
.izy-ref-label-icon{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:10px;background:#eef4ff;margin-right:2px;font-size:14px;box-shadow:inset 0 0 0 1px rgba(37,99,235,.08)}
.izy-ref-grid .izy-ref-card:hover,.izy-ref-panel:hover{transform:translateY(-2px);transition:transform .18s ease, box-shadow .18s ease;box-shadow:0 18px 36px rgba(15,23,42,.08)!important}
.izy-ref-actions-hero .izy-ref-btn,.izy-ref-btn-block,.izy-ref-row-stack-mobile .izy-ref-btn{position:relative;overflow:hidden}
.izy-ref-actions-hero .izy-ref-btn:after,.izy-ref-btn-block:after,.izy-ref-row-stack-mobile .izy-ref-btn:after{content:"";position:absolute;inset:0;background:linear-gradient(120deg,rgba(255,255,255,0) 20%,rgba(255,255,255,.16) 50%,rgba(255,255,255,0) 80%);transform:translateX(-120%)}
.izy-ref-actions-hero .izy-ref-btn:hover:after,.izy-ref-btn-block:hover:after,.izy-ref-row-stack-mobile .izy-ref-btn:hover:after{animation:izyShine .95s ease}
@keyframes izyShine{from{transform:translateX(-120%)}to{transform:translateX(120%)}}
@media (max-width:640px){.izy-ref-section-head{align-items:stretch}.izy-ref-mini-badge{width:100%;justify-content:center}.izy-ref-referrer-box{align-items:flex-start}.izy-ref-avatar{width:46px;height:46px;border-radius:14px;font-size:20px}}


/* =====================
   HERO REFINEMENT v1.9.3
===================== */
.izy-ref-sub-strong{font-size:14px;font-weight:900;letter-spacing:.08em;text-transform:uppercase;color:rgba(255,255,255,.88)!important}
.izy-ref-promo-box{margin-top:18px;display:inline-flex;flex-direction:column;gap:10px;padding:16px 18px;border-radius:20px;background:rgba(255,255,255,.11);border:1px solid rgba(255,255,255,.18);backdrop-filter:blur(6px);max-width:100%}
.izy-ref-promo-label{font-size:12px;font-weight:900;letter-spacing:.08em;text-transform:uppercase;color:rgba(255,255,255,.76)}
.izy-ref-promo-code-wrap{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.izy-ref-promo-eq{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:999px;background:rgba(255,255,255,.14);font-size:24px;font-weight:900;color:#fff}
.izy-ref-promo-code{display:inline-flex;align-items:center;min-height:46px;padding:10px 14px;border-radius:16px;background:#fff;color:#0f172a;font-size:clamp(16px,2.5vw,22px);font-weight:800;line-height:1.05;border:1px solid rgba(255,255,255,.32);box-shadow:inset 0 1px 0 rgba(255,255,255,.65),0 10px 28px rgba(15,23,42,.14);word-break:break-word}
.izy-ref-actions-hero-single{grid-template-columns:1fr!important;align-content:center}
.izy-ref-btn-share{min-height:64px;border-radius:18px!important;background:linear-gradient(135deg,#ffffff 0%,#eef4ff 100%);color:#12306b!important;border:1px solid rgba(255,255,255,.34);box-shadow:0 18px 32px rgba(15,23,42,.18);font-size:17px;font-weight:900!important;display:inline-flex;align-items:center;justify-content:flex-start;gap:12px;padding:14px 18px}
.izy-ref-btn-share:hover{box-shadow:0 20px 36px rgba(15,23,42,.22)}
.izy-ref-btn-icon{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:999px;background:linear-gradient(135deg,#1d4ed8,#2563eb);color:#fff;font-size:18px;font-weight:900;box-shadow:0 10px 20px rgba(37,99,235,.28)}
@media (max-width:900px){.izy-ref-actions-hero-single{grid-template-columns:1fr!important}.izy-ref-promo-box{width:100%}.izy-ref-btn-share{width:100%}}
@media (max-width:640px){.izy-ref-promo-code{width:100%;justify-content:center;font-size:clamp(17px,6vw,24px)}.izy-ref-promo-code-wrap{align-items:stretch}.izy-ref-promo-eq{display:none}.izy-ref-btn-share{min-height:58px}}

.izy-ref-share-mini{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:999px;font-size:11px;font-weight:900;letter-spacing:.02em;margin-left:2px;box-shadow:0 8px 18px rgba(15,23,42,.14)}
.izy-ref-share-mini-wa{background:#25D366;color:#fff;margin-left:auto}
.izy-ref-share-mini-fb{background:#1877F2;color:#fff;font-size:15px;font-family:Arial,sans-serif}
@media (max-width:640px){.izy-ref-share-mini{width:26px;height:26px;font-size:10px}}


/* ===== Guest referral login box ===== */
.bp-ref-guest-wrap{display:flex;justify-content:center;padding:10px 0 4px}
.bp-ref-guest-card{position:relative;overflow:hidden;width:min(100%,780px);padding:30px;border-radius:28px;background:linear-gradient(135deg,#0f172a 0%,#111827 30%,#16c7b6 100%);box-shadow:0 24px 60px rgba(15,23,42,.18);color:#fff;border:1px solid rgba(255,255,255,.12)}
.bp-ref-guest-card:before{content:"";position:absolute;right:-80px;top:-80px;width:240px;height:240px;border-radius:50%;background:radial-gradient(circle,rgba(123,47,247,.42) 0%,rgba(123,47,247,0) 70%)}
.bp-ref-guest-card:after{content:"";position:absolute;left:-90px;bottom:-110px;width:260px;height:260px;border-radius:50%;background:radial-gradient(circle,rgba(22,199,182,.30) 0%,rgba(22,199,182,0) 72%)}
.bp-ref-guest-badge,.bp-ref-guest-title,.bp-ref-guest-text,.bp-ref-guest-grid,.bp-ref-guest-note{position:relative;z-index:1}
.bp-ref-guest-badge{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;border-radius:999px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.16);font-size:12px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;margin-bottom:16px;backdrop-filter:blur(6px)}
.bp-ref-guest-title{margin:0 0 10px;font-size:clamp(26px,4vw,38px);line-height:1.05;font-weight:900;color:#fff}
.bp-ref-guest-text{margin:0 0 20px;max-width:650px;font-size:15px;line-height:1.7;color:rgba(255,255,255,.9)}
.bp-ref-guest-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;margin:22px 0}
.bp-ref-guest-item{display:flex;align-items:flex-start;gap:12px;padding:16px;border-radius:20px;background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.12);backdrop-filter:blur(8px)}
.bp-ref-guest-icon{display:inline-flex;align-items:center;justify-content:center;flex:0 0 46px;width:46px;height:46px;border-radius:14px;background:linear-gradient(135deg,#16c7b6 0%,#7b2ff7 100%);box-shadow:0 12px 24px rgba(0,0,0,.18);font-size:22px}
.bp-ref-guest-item strong{display:block;font-size:15px;font-weight:800;color:#fff;margin-bottom:4px}
.bp-ref-guest-item small{display:block;font-size:13px;line-height:1.55;color:rgba(255,255,255,.82)}
.bp-ref-guest-note{margin:0 0 20px;font-size:14px;color:rgba(255,255,255,.92)}
@media (max-width:820px){.bp-ref-guest-grid{grid-template-columns:1fr}.bp-ref-guest-card{padding:24px;border-radius:24px}}
@media (max-width:560px){.bp-ref-guest-card{padding:20px}.bp-ref-guest-title{font-size:28px}}
