
:root{
  --bbvcp-bg:#f4f1fb;
  --bbvcp-bg-2:#efe7ff;
  --bbvcp-panel:#ffffff;
  --bbvcp-panel-soft:#f7f2ff;
  --bbvcp-card:#ffffff;
  --bbvcp-text:#2b1f52;
  --bbvcp-soft:#7d6f9d;
  --bbvcp-line:#e6dbff;
  --bbvcp-line-strong:#d8c8ff;
  --bbvcp-accent:#7a4dff;
  --bbvcp-accent-2:#9f7aea;
  --bbvcp-accent-soft:#f0e9ff;
  --bbvcp-danger:#d6456f;
  --bbvcp-success:#22a06b;
  --bbvcp-radius:24px;
  --bbvcp-shadow:0 18px 60px rgba(90,55,172,.12);
  --bbvcp-safe-bottom:max(18px, env(safe-area-inset-bottom));
}
html,body{
  margin:0;
  min-height:100%;
  background:
    radial-gradient(circle at top left,rgba(146,105,255,.15),transparent 34%),
    radial-gradient(circle at bottom right,rgba(122,77,255,.12),transparent 28%),
    linear-gradient(180deg,#f7f3ff 0%,#f1eaff 100%);
  color:var(--bbvcp-text);
  font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
}
body.bbvcp-app-body{
  overscroll-behavior-y:none;
  -webkit-font-smoothing:antialiased;
}
#bbvcp-app{color:var(--bbvcp-text);font-family:inherit}
#bbvcp-app *,#bbvcp-app *::before,#bbvcp-app *::after{box-sizing:border-box}
#bbvcp-app input,#bbvcp-app select,#bbvcp-app textarea,#bbvcp-app button{
  font:inherit;
}
#bbvcp-app button{
  -webkit-tap-highlight-color:transparent;
}
.bbvcp-app{
  min-height:100vh;
  background:
    radial-gradient(circle at top left,rgba(146,105,255,.18),transparent 34%),
    radial-gradient(circle at top right,rgba(122,77,255,.10),transparent 25%),
    linear-gradient(180deg,#f8f5ff 0%,#efe7ff 100%);
}
.bbvcp-shell{
  width:min(100%,1080px);
  margin:0 auto;
  padding:18px 14px calc(108px + var(--bbvcp-safe-bottom));
}
.bbvcp-auth{
  min-height:100vh;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:18px;
}
.bbvcp-auth__card,.bbvcp-panel,.bbvcp-editor-tray{
  background:rgba(255,255,255,.92);
  border:1px solid var(--bbvcp-line);
  border-radius:28px;
  box-shadow:var(--bbvcp-shadow);
  backdrop-filter:blur(18px);
}
.bbvcp-auth__card{
  width:min(100%,430px);
  padding:24px 20px;
}
.bbvcp-auth__card--minimal{
  width:min(100%,380px);
  padding:24px 18px 18px;
  display:grid;
  gap:18px;
}
.bbvcp-auth__stack{
  display:grid;
  gap:12px;
}
.bbvcp-field--auth{
  margin:0;
}
.bbvcp-input--auth{
  min-height:54px;
  border-radius:18px;
  font-size:1rem;
}
.bbvcp-auth__micro{
  margin:2px 0 0;
  text-align:center;
  font-size:.82rem;
  font-weight:700;
  color:#7a4dff;
}
.bbvcp-inline--center{
  justify-content:center;
}

.bbvcp-kicker{
  margin:0 0 10px;
  color:#7b69a7;
  font-size:.82rem;
  letter-spacing:.14em;
  text-transform:uppercase;
  font-weight:700;
}
.bbvcp-auth h1,.bbvcp-header__title h1{
  margin:0;
  line-height:1.02;
  font-size:clamp(1.9rem,5vw,2.7rem);
}
.bbvcp-auth p,.bbvcp-muted{color:var(--bbvcp-soft)}
.bbvcp-auth__hint{
  margin:0 0 14px;
  font-size:.9rem;
  color:#6d5b94;
}
.bbvcp-auth__lead{
  margin:0 0 12px;
  color:#4a3978;
}
.bbvcp-auth__beta{
  margin:0 0 14px;
  padding:14px 14px 12px;
  border-radius:22px;
  border:1px solid var(--bbvcp-line);
  background:linear-gradient(180deg,#fcfaff,#f5efff);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.9);
}
.bbvcp-auth__beta strong{
  display:block;
  margin-bottom:8px;
}
.bbvcp-list--compact{
  margin:0;
}
.bbvcp-list--compact li{
  padding:10px 12px;
}
.bbvcp-list{
  list-style:none;
  padding:0;
  margin:18px 0 22px;
  display:grid;
  gap:10px;
}
.bbvcp-list li{
  padding:13px 14px;
  border-radius:18px;
  background:#faf7ff;
  border:1px solid var(--bbvcp-line);
}
.bbvcp-field{
  display:grid;
  gap:8px;
  margin:12px 0;
}
.bbvcp-field label{
  font-size:.92rem;
  font-weight:700;
  color:#5f4f89;
}
.bbvcp-input,.bbvcp-select,.bbvcp-textarea,.bbvcp-range{
  width:100%;
  border-radius:18px;
  border:1px solid var(--bbvcp-line-strong);
  background:#fff;
  color:var(--bbvcp-text);
  padding:14px 15px;
  appearance:none;
}
.bbvcp-input:focus,.bbvcp-select:focus,.bbvcp-textarea:focus{
  outline:2px solid rgba(122,77,255,.18);
  border-color:rgba(122,77,255,.42);
}
.bbvcp-code{
  letter-spacing:.45em;
  text-align:center;
  font-size:1.2rem;
}
.bbvcp-textarea{
  min-height:86px;
  resize:vertical;
}
.bbvcp-range{
  padding:0;
  height:24px;
  border:0;
  background:transparent;
}
.bbvcp-button,.bbvcp-ghost,.bbvcp-chip,.bbvcp-icon-button{
  border:0;
  border-radius:20px;
  cursor:pointer;
  font-weight:800;
  transition:transform .16s ease, box-shadow .16s ease, background .16s ease;
}
.bbvcp-button:hover,.bbvcp-ghost:hover,.bbvcp-chip:hover,.bbvcp-icon-button:hover{
  transform:translateY(-1px);
}
.bbvcp-button{
  background:linear-gradient(135deg,#7a4dff 0%,#8f63ff 65%,#a783ff 100%);
  color:#fff;
  padding:14px 18px;
  box-shadow:0 12px 30px rgba(122,77,255,.24);
}
.bbvcp-ghost{
  background:#fff;
  color:var(--bbvcp-text);
  border:1px solid var(--bbvcp-line-strong);
  padding:12px 15px;
}
.bbvcp-chip{
  background:#f6f0ff;
  color:#6541db;
  border:1px solid #e1d4ff;
  padding:11px 14px;
}
.bbvcp-icon-button{
  width:44px;
  height:44px;
  border-radius:16px;
  display:grid;
  place-items:center;
  background:#fff;
  border:1px solid var(--bbvcp-line);
  color:#6b4ce8;
}
.bbvcp-button:disabled,.bbvcp-ghost:disabled,.bbvcp-chip:disabled{
  opacity:.55;
  cursor:not-allowed;
  transform:none;
}
.bbvcp-error,.bbvcp-note{
  margin-top:12px;
  padding:12px 14px;
  border-radius:16px;
  font-size:.92rem;
}
.bbvcp-error{
  background:#fff0f4;
  border:1px solid #ffc8d6;
  color:#9a1f47;
}
.bbvcp-note{
  background:#f6f1ff;
  border:1px solid #e1d5ff;
  color:#6649d8;
}
.bbvcp-header{
  display:grid;
  gap:16px;
  margin-bottom:20px;
}
.bbvcp-header__top{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:12px;
}
.bbvcp-header__title p{
  margin:8px 0 0;
}
.bbvcp-pill{
  display:inline-flex;
  align-items:center;
  gap:8px;
  border-radius:999px;
  padding:10px 13px;
  background:#fff;
  border:1px solid var(--bbvcp-line);
  color:#5f4f89;
  font-size:.9rem;
  font-weight:700;
  white-space:nowrap;
}
.bbvcp-grid{display:grid;gap:16px}
.bbvcp-summary{
  padding:18px;
}
.bbvcp-summary__meta{
  display:flex;
  justify-content:space-between;
  gap:12px;
  align-items:center;
  margin-bottom:16px;
}
.bbvcp-summary strong{
  display:block;
  font-size:1.04rem;
}
.bbvcp-summary p{
  margin:4px 0 0;
}
.bbvcp-top-actions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}
.bbvcp-gallery{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:12px;
}
.bbvcp-card-tile{
  position:relative;
  padding:12px;
  border-radius:26px;
  background:rgba(255,255,255,.88);
  border:1px solid var(--bbvcp-line);
  box-shadow:0 10px 28px rgba(98,61,176,.08);
}
.bbvcp-card-tile__badge{
  position:absolute;
  top:14px;
  right:14px;
  left:auto;
  z-index:3;
  padding:7px 10px;
  border-radius:999px;
  background:#efe7ff;
  color:#6541db;
  font-size:.78rem;
  font-weight:800;
  box-shadow:0 8px 20px rgba(122,77,255,.12);
}
.bbvcp-create-tile{
  display:grid;
  place-items:center;
  min-height:218px;
  border:1.5px dashed #ceb9ff;
  background:linear-gradient(180deg,#faf7ff,#f3ebff);
  color:#6b49e6;
}
.bbvcp-create-tile__plus{
  width:64px;
  height:64px;
  border-radius:24px;
  display:grid;
  place-items:center;
  font-size:2rem;
  line-height:1;
  background:linear-gradient(135deg,#7a4dff,#9d79ff);
  color:#fff;
  box-shadow:0 16px 32px rgba(122,77,255,.22);
}
.bbvcp-card-mini{
  display:grid;
  place-items:center;
  min-height:156px;
  padding:24px 10px 10px;
  border-radius:22px;
  background:linear-gradient(180deg,#fbf8ff,#f4ecff);
}
.bbvcp-card-mini .bbvcp-card-editor{
  width:min(100%,122px);
  box-shadow:0 14px 34px rgba(94,65,172,.14);
}
.bbvcp-card-tile h3{
  margin:12px 0 4px;
  font-size:1rem;
}
.bbvcp-card-tile p{
  margin:0;
  color:var(--bbvcp-soft);
  font-size:.9rem;
}
.bbvcp-actions{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:8px;
  margin-top:12px;
}
.bbvcp-actions .bbvcp-ghost{
  min-height:42px;
  padding:10px 12px;
  font-size:.9rem;
}
.bbvcp-editor{
  display:grid;
  gap:14px;
}
.bbvcp-editor__top{
  position:sticky;
  top:0;
  z-index:12;
  display:grid;
  gap:12px;
  padding-top:6px;
}
.bbvcp-editor__bar{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:10px;
}
.bbvcp-editor__bar-main{
  display:flex;
  align-items:center;
  gap:10px;
  min-width:0;
}
.bbvcp-editor__title{
  min-width:0;
}
.bbvcp-editor__title strong{
  display:block;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.bbvcp-save-status{
  color:#7e6aa7;
  font-size:.84rem;
  margin-top:4px;
}
.bbvcp-tabs{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:8px;
}
.bbvcp-tab{
  min-height:48px;
  border-radius:18px;
  border:1px solid var(--bbvcp-line-strong);
  background:rgba(255,255,255,.86);
  color:#6348d8;
  font-weight:800;
  cursor:pointer;
}
.bbvcp-tab.is-active{
  background:linear-gradient(180deg,#f6f0ff,#ece2ff);
  border-color:#ccb4ff;
  box-shadow:0 10px 22px rgba(122,77,255,.12);
}
.bbvcp-canvas-wrap{
  position:relative;
  overflow:hidden;
  padding:14px;
}
.bbvcp-canvas-stage{
  display:grid;
  place-items:center;
  min-height:58vh;
  border-radius:34px;
  padding:18px 10px 22px;
  background:
    radial-gradient(circle at top,rgba(122,77,255,.12),transparent 42%),
    linear-gradient(180deg,#f8f4ff,#efe6ff);
  border:1px solid #e3d7ff;
}
.bbvcp-editor-phone{
  width:min(100%,390px);
  border-radius:40px;
  padding:11px 11px 18px;
  background:linear-gradient(180deg,#fff,#f5efff);
  border:1px solid #e0d3ff;
  box-shadow:0 22px 64px rgba(92,59,174,.16);
}
.bbvcp-editor-phone__top{
  display:flex;
  justify-content:center;
  margin-bottom:12px;
}
.bbvcp-editor-phone__notch{
  width:34%;
  height:20px;
  border-radius:999px;
  background:#e7dcff;
}
.bbvcp-card-editor{
  position:relative;
  width:min(100%,100%);
  aspect-ratio:4 / 7;
  border-radius:var(--card-radius,18px);
  overflow:hidden;
  border:1px solid rgba(123,95,185,.18);
  box-shadow:0 28px 80px rgba(95,62,174,.16);
  background:var(--card-bg,linear-gradient(180deg,#fff,#f5f0ff));
}
.bbvcp-card-editor__surface{
  position:absolute;
  inset:0;
}
.bbvcp-card-editor__surface::after{
  content:"";
  position:absolute;
  inset:12px;
  border:1px dashed rgba(122,77,255,.16);
  border-radius:16px;
  pointer-events:none;
}
.bbvcp-editor-el,.bbvcp-el{
  position:absolute;
  left:var(--bbvcp-x);
  top:var(--bbvcp-y);
  width:var(--bbvcp-w);
  height:var(--bbvcp-h);
  min-height:0;
  z-index:var(--bbvcp-z);
  color:var(--bbvcp-color);
  opacity:var(--bbvcp-opacity);
  font-weight:var(--bbvcp-weight);
  text-align:var(--bbvcp-align);
  font-family:var(--bbvcp-font);
  font-size:var(--bbvcp-font-size);
  letter-spacing:var(--bbvcp-letter-spacing,0em);
  display:flex;
  align-items:flex-start;
  justify-content:var(--bbvcp-justify,flex-start);
  line-height:1.08;
  word-break:break-word;
  transform:translate3d(0,0,0);
}
.bbvcp-editor-el{
  touch-action:none;
  user-select:none;
  cursor:grab;
}
.bbvcp-editor-el--selected{
  outline:2px solid rgba(122,77,255,.88);
  outline-offset:4px;
  border-radius:12px;
  box-shadow:0 0 0 8px rgba(122,77,255,.08);
}
.bbvcp-editor-el--link,.bbvcp-el--link{
  color:var(--bbvcp-color);
  text-decoration:none;
  border-bottom:1px solid currentColor;
  padding-bottom:2px;
}
.bbvcp-editor-el--image img,.bbvcp-el--image img{
  width:100%;
  height:100%;
  object-fit:cover;
  border-radius:14px;
  display:block;
}
.bbvcp-editor-el__handle{
  position:absolute;
  right:-11px;
  bottom:-11px;
  width:24px;
  height:24px;
  border-radius:999px;
  background:#fff;
  border:2px solid #7a4dff;
  box-shadow:0 8px 18px rgba(122,77,255,.24);
}
.bbvcp-editor-meta{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:10px;
  margin-top:12px;
  color:#705ca1;
  font-size:.9rem;
}
.bbvcp-editor-tray{
  position:sticky;
  bottom:calc(82px + var(--bbvcp-safe-bottom));
  z-index:14;
  padding:16px 14px;
}
.bbvcp-editor-tray__head{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:12px;
  margin-bottom:12px;
}
.bbvcp-editor-tray__head h3{
  margin:0;
  font-size:1rem;
}
.bbvcp-editor-tray__head p{
  margin:4px 0 0;
  color:var(--bbvcp-soft);
  font-size:.9rem;
}
.bbvcp-editor-tray__grid{
  display:grid;
  gap:12px;
}
.bbvcp-editor-tray__grid .bbvcp-inline{
  margin-top:0;
}
.bbvcp-tray-actions{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:8px;
}
.bbvcp-inline{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:10px;
}
.bbvcp-inline--3{
  grid-template-columns:repeat(3,minmax(0,1fr));
}
.bbvcp-swatches{
  display:grid;
  gap:10px;
  grid-template-columns:repeat(2,minmax(0,1fr));
}
.bbvcp-swatch{
  text-align:left;
  border-radius:20px;
  border:1px solid var(--bbvcp-line);
  background:#fff;
  color:var(--bbvcp-text);
  padding:12px;
}
.bbvcp-swatch.is-active{
  border-color:#c5aeff;
  box-shadow:0 0 0 2px rgba(122,77,255,.18);
  background:#faf6ff;
}
.bbvcp-sheet{
  width:min(100%,560px);
  max-height:min(78vh,680px);
  overflow:auto;
  border-radius:28px 28px 22px 22px;
  padding:18px 16px calc(18px + var(--bbvcp-safe-bottom));
  background:rgba(255,255,255,.96);
  border:1px solid var(--bbvcp-line);
  box-shadow:0 24px 72px rgba(90,56,171,.18);
}
.bbvcp-sheet__head{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:12px;
  margin-bottom:14px;
}
.bbvcp-sheet h2{
  margin:0;
  font-size:1.12rem;
}
.bbvcp-sheet__grid{
  display:grid;
  gap:10px;
}
.bbvcp-sheet__grid--menu{
  grid-template-columns:repeat(2,minmax(0,1fr));
}
.bbvcp-sheet__menu-item{
  padding:16px;
  border-radius:22px;
  border:1px solid var(--bbvcp-line);
  background:#fbf8ff;
  color:var(--bbvcp-text);
  text-align:left;
}
.bbvcp-sheet__menu-item strong{
  display:block;
  margin-bottom:6px;
}
.bbvcp-bottom-bar{
  position:sticky;
  bottom:calc(10px + var(--bbvcp-safe-bottom));
  z-index:15;
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:10px;
  padding:12px;
  border-radius:26px;
  background:rgba(255,255,255,.94);
  border:1px solid var(--bbvcp-line);
  box-shadow:0 16px 38px rgba(95,60,175,.14);
  backdrop-filter:blur(16px);
}
.bbvcp-bottom-bar .bbvcp-button,
.bbvcp-bottom-bar .bbvcp-ghost,
.bbvcp-bottom-bar .bbvcp-chip{
  width:100%;
  min-height:52px;
}
.bbvcp-bottom-bar .bbvcp-button{
  font-size:1.1rem;
}
.bbvcp-overlay{
  position:fixed;
  inset:0;
  z-index:99999;
  display:flex;
  align-items:flex-end;
  justify-content:center;
  padding:14px;
  background:rgba(101,79,168,.18);
  backdrop-filter:blur(8px);
}
.bbvcp-preview-stage{
  min-height:68vh;
  display:grid;
  place-items:center;
  padding:20px;
  border-radius:28px;
  overflow:hidden;
  background:
    radial-gradient(circle at top,rgba(122,77,255,.12),transparent 35%),
    linear-gradient(180deg,#f8f4ff,#efe6ff);
}
.bbvcp-qr{
  display:grid;
  gap:16px;
  justify-items:center;
  text-align:center;
}
.bbvcp-qr img{
  width:min(280px,72vw);
  height:auto;
  border-radius:24px;
  background:#fff;
  padding:16px;
  border:1px solid var(--bbvcp-line);
}
.bbvcp-plan-grid{
  display:grid;
  gap:12px;
}
.bbvcp-plan{
  padding:16px;
  border-radius:24px;
  border:1px solid var(--bbvcp-line);
  background:#fbf8ff;
}
.bbvcp-plan h3{margin:0 0 4px}
.bbvcp-plan p{margin:0 0 12px;color:var(--bbvcp-soft)}
.bbvcp-plan ul{margin:0 0 12px;padding-left:18px}
.bbvcp-link{color:#6748df}
.bbvcp-hidden{display:none !important}
.bbvcp-loading{
  display:grid;
  place-items:center;
  min-height:100vh;
  font-size:1rem;
  color:#6d5b99;
}
@media (min-width:900px){
  .bbvcp-shell{padding-top:28px}
  .bbvcp-grid--dashboard{grid-template-columns:1.08fr .92fr}
  .bbvcp-gallery{grid-template-columns:repeat(3,minmax(0,1fr))}
  .bbvcp-sheet__grid--menu{grid-template-columns:repeat(3,minmax(0,1fr))}
}
@media (max-width:720px){
  .bbvcp-shell{padding:14px 12px calc(108px + var(--bbvcp-safe-bottom))}
  .bbvcp-header__top,
  .bbvcp-summary__meta,
  .bbvcp-editor__bar{
    align-items:flex-start;
  }
  .bbvcp-editor__bar{
    flex-wrap:wrap;
  }
  .bbvcp-inline,.bbvcp-inline--3,
  .bbvcp-tool-fields--grid{
    grid-template-columns:1fr;
  }
  .bbvcp-app--editor .bbvcp-shell--editor{
    padding:10px 10px calc(10px + var(--bbvcp-safe-bottom));
  }
  .bbvcp-app--editor .bbvcp-editor{
    gap:10px;
  }
  .bbvcp-app--editor .bbvcp-canvas-stage{
    padding:10px 6px;
  }
  .bbvcp-app--editor .bbvcp-editor-phone{
    width:100%;
    max-width:100%;
    border-radius:28px;
  }
  .bbvcp-app--editor .bbvcp-card-editor{
    width:min(100%,calc((100svh - 274px) * 4 / 7));
  }
  .bbvcp-sheet--preview .bbvcp-card{
    width:min(80vw,calc((100svh - 244px) * 4 / 7));
  }
}
@media (prefers-reduced-motion:reduce){
  .bbvcp-button,.bbvcp-ghost,.bbvcp-chip,.bbvcp-icon-button,
  .bbvcp-card,.bbvcp-editor-el{
    transition:none !important;
    animation:none !important;
  }
}


.bbvcp-app--editor{
  min-height:100svh;
  height:100svh;
  overflow:hidden;
}
.bbvcp-shell--editor{
  height:100%;
  padding:12px 12px calc(12px + var(--bbvcp-safe-bottom));
  display:flex;
  flex-direction:column;
  overflow:hidden;
}
.bbvcp-app--editor .bbvcp-editor{
  flex:1;
  min-height:0;
  display:grid;
  grid-template-rows:auto minmax(0,1fr) auto;
  gap:12px;
}
.bbvcp-app--editor .bbvcp-editor__top{
  position:relative;
  top:auto;
  padding-top:0;
}
.bbvcp-app--editor .bbvcp-canvas-wrap{
  padding:10px;
  min-height:0;
  display:flex;
}
.bbvcp-app--editor .bbvcp-canvas-stage{
  width:100%;
  min-height:0;
  height:100%;
  padding:12px;
  display:flex;
  align-items:center;
  justify-content:center;
}
.bbvcp-app--editor .bbvcp-editor-phone{
  width:min(100%,400px);
  max-width:100%;
  padding:10px 10px 14px;
  display:flex;
  flex-direction:column;
}
.bbvcp-app--editor .bbvcp-editor-phone__top{
  margin-bottom:10px;
}
.bbvcp-app--editor .bbvcp-card-editor{
  width:min(100%,340px,calc((100svh - 292px) * 4 / 7));
  margin:0 auto;
}
.bbvcp-app--editor #bbvcp-editor-canvas{
  display:flex;
  align-items:center;
  justify-content:center;
}
.bbvcp-app--editor .bbvcp-editor-meta{
  margin-top:10px;
}
.bbvcp-app--editor .bbvcp-bottom-bar{
  position:relative;
  bottom:auto;
}
.bbvcp-bottom-bar--tools{
  display:block;
  grid-template-columns:1fr;
}
.bbvcp-bottom-bar--tools > *{
  width:100%;
}
.bbvcp-tool-scroll--compact{
  align-items:center;
}
.bbvcp-tool-mini{
  display:inline-flex;
  align-items:center;
  gap:8px;
  min-height:48px;
  border:1px solid var(--bbvcp-line-strong);
  background:#fff;
  color:var(--bbvcp-text);
  border-radius:999px;
  padding:11px 14px;
  font-weight:800;
  white-space:nowrap;
}
.bbvcp-tool-mini__icon{
  font-size:1rem;
  line-height:1;
}
.bbvcp-tool-mini__label{
  font-size:.86rem;
}
.bbvcp-tool-mini--danger{
  color:#b2355b;
}
.bbvcp-tool-mini--confirm{
  background:linear-gradient(135deg,#7a4dff 0%,#8f63ff 65%,#a783ff 100%);
  color:#fff;
  border-color:transparent;
}
.bbvcp-tool-panel--slider{
  gap:10px;
}
.bbvcp-tool-slider{
  display:flex;
  gap:10px;
  overflow-x:auto;
  padding-bottom:2px;
  scrollbar-width:none;
}
.bbvcp-tool-slider::-webkit-scrollbar{
  display:none;
}
.bbvcp-tool-card{
  min-width:160px;
  display:grid;
  gap:8px;
  padding:12px 14px;
  border-radius:20px;
  border:1px solid var(--bbvcp-line);
  background:#fbf8ff;
}
.bbvcp-tool-card--wide{
  min-width:220px;
}
.bbvcp-tool-card--range{
  min-width:190px;
}
.bbvcp-tool-card--action{
  text-align:left;
  align-content:space-between;
  min-width:170px;
}
.bbvcp-tool-card span{
  font-size:.76rem;
  font-weight:700;
  color:#6f5b9c;
}
.bbvcp-tool-card strong{
  font-size:.96rem;
  color:var(--bbvcp-text);
}
.bbvcp-toolbar-input{
  width:100%;
  border-radius:14px;
  border:1px solid var(--bbvcp-line-strong);
  background:#fff;
  color:var(--bbvcp-text);
  padding:11px 12px;
  min-height:44px;
}
.bbvcp-toolbar-color{
  width:100%;
  height:46px;
  border-radius:14px;
  border:1px solid var(--bbvcp-line-strong);
  background:#fff;
  padding:6px;
}
.bbvcp-tool-scroll{
  display:flex;
  gap:8px;
  overflow-x:auto;
  padding-bottom:2px;
  scrollbar-width:none;
}
.bbvcp-tool-scroll::-webkit-scrollbar{
  display:none;
}
.bbvcp-tool-pill,
.bbvcp-tool-icon{
  border:1px solid var(--bbvcp-line-strong);
  background:#fff;
  color:var(--bbvcp-text);
  border-radius:999px;
  padding:12px 14px;
  font-weight:800;
  white-space:nowrap;
}
.bbvcp-tool-pill.is-current{
  background:#f5efff;
  color:#6541db;
}
.bbvcp-tool-pill--confirm,
.bbvcp-tool-icon--confirm{
  background:linear-gradient(135deg,#7a4dff 0%,#8f63ff 65%,#a783ff 100%);
  color:#fff;
  border-color:transparent;
}
.bbvcp-tool-pill--danger,
.bbvcp-ghost--danger{
  color:#b2355b;
}
.bbvcp-tool-panel{
  display:grid;
  gap:12px;
}
.bbvcp-tool-panel__nav{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
}
.bbvcp-tool-panel__nav strong{
  flex:1;
  text-align:center;
}
.bbvcp-tool-fields{
  display:grid;
  gap:10px;
}
.bbvcp-tool-fields--grid{
  grid-template-columns:repeat(2,minmax(0,1fr));
}
.bbvcp-tool-field{
  display:grid;
  gap:6px;
}
.bbvcp-tool-field span{
  font-size:.86rem;
  font-weight:700;
  color:#5f4f89;
}
.bbvcp-tool-hint{
  margin:0;
  font-size:.84rem;
  color:var(--bbvcp-soft);
  grid-column:1 / -1;
}
.bbvcp-input--color{
  padding:6px;
  min-height:48px;
}
.bbvcp-overlay--preview{
  align-items:center;
  padding:10px;
}
.bbvcp-sheet--preview{
  width:min(100%,640px);
  max-height:calc(100svh - 20px);
  display:flex;
  flex-direction:column;
  overflow:hidden;
}
.bbvcp-sheet--preview .bbvcp-sheet__head{
  margin-bottom:8px;
}
.bbvcp-sheet--preview .bbvcp-preview-stage{
  flex:1;
  min-height:0;
  padding:12px;
}
.bbvcp-sheet--preview .bbvcp-card{
  width:min(76vw,320px,calc((100svh - 260px) * 4 / 7));
}
.bbvcp-sheet--preview .bbvcp-inline{
  margin-top:10px !important;
}


body.bbvcp-app-body,
#bbvcp-app,
.bbvcp-app,
.bbvcp-shell,
.bbvcp-shell--editor,
.bbvcp-editor,
.bbvcp-canvas-wrap,
.bbvcp-canvas-stage{
  overflow-x:hidden;
}
.bbvcp-shell,
.bbvcp-shell--editor,
.bbvcp-editor,
.bbvcp-canvas-wrap,
.bbvcp-editor__top,
.bbvcp-editor__bar,
.bbvcp-card-editor{
  min-width:0;
}
.bbvcp-bottom-bar--tools{
  display:block;
  grid-template-columns:none;
  padding:12px 14px;
  overflow:hidden;
}
.bbvcp-bottom-bar--tools .bbvcp-tool-scroll,
.bbvcp-bottom-bar--tools .bbvcp-tool-panel{
  width:100%;
  min-width:0;
}
.bbvcp-bottom-bar--tools .bbvcp-tool-scroll{
  align-items:center;
  padding-right:8px;
}
.bbvcp-tool-scroll--menu{
  display:flex;
  gap:10px;
  overflow-x:auto;
  scrollbar-width:none;
  -webkit-overflow-scrolling:touch;
  scroll-snap-type:x proximity;
}
.bbvcp-tool-scroll--menu::-webkit-scrollbar{
  display:none;
}
.bbvcp-tool-scroll--menu > *{
  flex:0 0 auto;
  scroll-snap-align:start;
}
.bbvcp-tool-pill{
  min-height:46px;
  padding:12px 16px;
  background:#fff;
  border:1px solid var(--bbvcp-line-strong);
  color:var(--bbvcp-text);
  box-shadow:0 6px 16px rgba(95,60,175,.06);
}
.bbvcp-tool-pill:hover{
  transform:none;
}
.bbvcp-tool-pill--icon{
  width:46px;
  min-width:46px;
  padding:0;
  display:grid;
  place-items:center;
}
.bbvcp-tool-pill--danger{
  background:#fff4f7;
  border-color:#f0c3d0;
  color:#c54a69;
}
.bbvcp-tool-pill--danger:hover{
  background:#fff0f4;
}
.bbvcp-tool-pill__trash{
  display:grid;
  place-items:center;
}
.bbvcp-tool-pill__trash svg{
  width:18px;
  height:18px;
  display:block;
}
.bbvcp-tool-panel__nav{
  align-items:center;
}
.bbvcp-tool-panel__nav strong{
  min-width:0;
  font-size:.95rem;
  color:#5f4f89;
}
.bbvcp-tool-panel--slider .bbvcp-tool-slider{
  width:100%;
}
.bbvcp-tool-panel--slider .bbvcp-tool-card{
  box-shadow:none;
}


/* v2.3.0 app refinements */
.bbvcp-header--dashboard .bbvcp-header__row{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:12px;
}
.bbvcp-header__actions{
  display:flex;
  align-items:center;
  gap:10px;
}
.bbvcp-summary__actions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin-top:14px;
}
.bbvcp-promo{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  padding:18px;
}
.bbvcp-promo p{
  margin:6px 0 0;
}
.bbvcp-inline-icon{
  width:18px;
  height:18px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
}
.bbvcp-inline-icon svg,
.bbvcp-icon-button svg,
.bbvcp-action-btn svg,
.bbvcp-tool-action svg,
.bbvcp-bottom-main__icon svg{
  width:18px;
  height:18px;
  display:block;
}
.bbvcp-card-actions{
  display:grid;
  grid-template-columns:44px 44px minmax(0,1fr) 44px;
  gap:8px;
  margin-top:12px;
  align-items:center;
}
.bbvcp-action-btn{
  width:44px;
  height:44px;
  border:0;
  border-radius:14px;
  display:grid;
  place-items:center;
  cursor:pointer;
}
.bbvcp-action-btn--purple{
  background:linear-gradient(135deg,#7a4dff 0%,#8f63ff 65%,#a783ff 100%);
  color:#fff;
  box-shadow:0 12px 30px rgba(122,77,255,.22);
}
.bbvcp-action-btn--light{
  background:#f6f0ff;
  color:#6c48e5;
  border:1px solid #e1d4ff;
}
.bbvcp-action-btn--danger{
  background:#fff3f7;
  color:#c44169;
  border:1px solid #ffc3d3;
}
.bbvcp-card-tile__badge{
  top:10px;
  right:10px;
}
.bbvcp-card-mini{
  padding-top:38px;
}
.bbvcp-app--editor{
  min-height:100svh;
  height:100svh;
  overflow:hidden;
}
.bbvcp-shell--editor{
  height:100%;
  padding:10px 10px calc(10px + var(--bbvcp-safe-bottom));
  display:flex;
  flex-direction:column;
  overflow:hidden;
}
.bbvcp-editor{
  flex:1;
  min-height:0;
  display:grid;
  grid-template-rows:auto minmax(0,1fr) 94px;
  gap:10px;
  overflow:hidden;
}
.bbvcp-editor__top{
  position:relative;
  top:auto;
  z-index:4;
  padding:0;
}
.bbvcp-editor__nav{
  display:flex;
  align-items:center;
  gap:10px;
}
.bbvcp-tabs--inline{
  flex:1;
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:8px;
}
.bbvcp-tab{
  min-height:44px;
}
.bbvcp-canvas-wrap{
  padding:10px;
  min-height:0;
  overflow:hidden;
}
.bbvcp-editor-stage{
  width:100%;
  height:100%;
  min-height:0;
  border-radius:34px;
  overflow:hidden;
  padding:0;
  display:grid;
  place-items:center;
  background:
    radial-gradient(circle at top,rgba(122,77,255,.12),transparent 42%),
    linear-gradient(180deg,#f8f4ff,#efe6ff);
  border:1px solid #e3d7ff;
}
#bbvcp-editor-canvas{
  width:100%;
  height:100%;
  display:grid;
  place-items:center;
  min-height:0;
}
.bbvcp-editor-stage__inner{
  width:100%;
  height:100%;
  display:grid;
  place-items:center;
  padding:10px;
}
.bbvcp-card-shell--editor{
  width:min(100%,340px,calc((100svh - 210px) * 4 / 7));
  max-width:100%;
  animation:none !important;
}
.bbvcp-card-shell--editor .bbvcp-card-editor{
  width:100%;
  aspect-ratio:4 / 7;
}
.bbvcp-card-shell--editor .bbvcp-face{
  border-radius:var(--bbvcp-radius);
}
.bbvcp-card-editor{
  position:relative;
  width:100%;
  aspect-ratio:4 / 7;
  border-radius:var(--card-radius,18px);
  overflow:hidden;
  border:1px solid rgba(123,95,185,.18);
  box-shadow:0 28px 80px rgba(95,62,174,.16);
  background:var(--card-bg,linear-gradient(180deg,#fff,#f5f0ff));
}
.bbvcp-card-editor__surface{
  position:absolute;
  inset:0;
  overflow:hidden;
}
.bbvcp-card-editor__surface::after{
  content:"";
  position:absolute;
  inset:12px;
  border:1px dashed rgba(122,77,255,.16);
  border-radius:16px;
  pointer-events:none;
}
.bbvcp-editor-el,
.bbvcp-el{
  position:absolute;
  left:var(--bbvcp-x);
  top:var(--bbvcp-y);
  width:var(--bbvcp-w);
  height:var(--bbvcp-h);
  min-height:0;
  z-index:var(--bbvcp-z);
  color:var(--bbvcp-color);
  opacity:var(--bbvcp-opacity);
  font-weight:var(--bbvcp-weight);
  text-align:var(--bbvcp-align);
  font-family:var(--bbvcp-font);
  font-size:var(--bbvcp-font-size);
  letter-spacing:var(--bbvcp-letter-spacing,0em);
  display:flex;
  align-items:flex-start;
  justify-content:var(--bbvcp-justify,flex-start);
  line-height:1.08;
  word-break:break-word;
  transform:none;
}
.bbvcp-editor-el{
  touch-action:none;
  user-select:none;
  cursor:grab;
}
.bbvcp-editor-el--selected{
  outline:2px solid rgba(122,77,255,.88);
  outline-offset:2px;
  border-radius:12px;
  box-shadow:0 0 0 6px rgba(122,77,255,.08);
}
.bbvcp-editor-el--image img,.bbvcp-el--image img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  border-radius:14px;
}
.bbvcp-editor-el__handle{
  position:absolute;
  right:-10px;
  bottom:-10px;
  width:22px;
  height:22px;
  border-radius:50%;
  background:linear-gradient(135deg,#7a4dff,#9d79ff);
  border:2px solid #fff;
  box-shadow:0 6px 16px rgba(122,77,255,.25);
}
.bbvcp-bottom-bar{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:8px;
  min-height:94px;
  height:94px;
  padding:8px;
  border-radius:30px;
  background:rgba(255,255,255,.92);
  border:1px solid var(--bbvcp-line);
  box-shadow:0 16px 34px rgba(97,66,179,.08);
  overflow:hidden;
}
.bbvcp-bottom-main{
  min-height:76px;
  border:0;
  border-radius:22px;
  background:#fff;
  color:var(--bbvcp-text);
  border:1px solid var(--bbvcp-line);
  display:grid;
  gap:6px;
  align-content:center;
  justify-items:center;
  font-weight:800;
}
.bbvcp-bottom-main--accent{
  background:linear-gradient(135deg,#7a4dff 0%,#8f63ff 65%,#a783ff 100%);
  color:#fff;
  box-shadow:0 12px 24px rgba(122,77,255,.22);
}
.bbvcp-bottom-main--chip{
  background:#f6f0ff;
  color:#6446d8;
  border-color:#e1d4ff;
}
.bbvcp-bottom-main:disabled{
  opacity:.5;
}
.bbvcp-bottom-main__icon{
  width:18px;
  height:18px;
  display:flex;
  align-items:center;
  justify-content:center;
}
.bbvcp-bottom-bar--selected{
  grid-template-columns:1fr;
  padding:8px 10px;
}
.bbvcp-tool-strip{
  width:100%;
  height:100%;
  display:flex;
  align-items:center;
  gap:8px;
  overflow:hidden;
}
.bbvcp-tool-strip--menu{
  overflow-x:auto;
  overflow-y:hidden;
  scrollbar-width:none;
}
.bbvcp-tool-strip--menu::-webkit-scrollbar,
.bbvcp-tool-strip__scroll::-webkit-scrollbar{
  display:none;
}
.bbvcp-tool-strip__scroll{
  flex:1;
  min-width:0;
  display:flex;
  align-items:center;
  gap:8px;
  overflow-x:auto;
  overflow-y:hidden;
  scrollbar-width:none;
  padding-bottom:2px;
}
.bbvcp-tool-action{
  min-width:76px;
  min-height:76px;
  padding:10px 12px;
  border-radius:20px;
  border:1px solid var(--bbvcp-line-strong);
  background:#fff;
  color:var(--bbvcp-text);
  display:grid;
  gap:6px;
  align-content:center;
  justify-items:center;
  font-weight:800;
  white-space:nowrap;
}
.bbvcp-tool-action__icon{
  width:18px;
  height:18px;
  display:flex;
  align-items:center;
  justify-content:center;
}
.bbvcp-tool-action.is-danger{
  background:#fff3f7;
  color:#c44169;
  border-color:#ffc3d3;
}
.bbvcp-tool-action.is-confirm{
  background:linear-gradient(135deg,#7a4dff 0%,#8f63ff 65%,#a783ff 100%);
  color:#fff;
  border-color:transparent;
}
.bbvcp-tool-control{
  min-width:150px;
  min-height:76px;
  padding:10px 12px;
  border-radius:20px;
  border:1px solid var(--bbvcp-line);
  background:#fbf8ff;
  display:grid;
  gap:6px;
  align-content:center;
}
.bbvcp-tool-control--wide{
  min-width:220px;
}
.bbvcp-tool-control--action{
  text-align:left;
  cursor:pointer;
}
.bbvcp-tool-control span{
  font-size:.75rem;
  font-weight:800;
  color:#6f5b9c;
}
.bbvcp-tool-control strong{
  font-size:.95rem;
  color:var(--bbvcp-text);
}
.bbvcp-tool-control em{
  font-style:normal;
  font-size:.78rem;
  color:#6f5b9c;
}
.bbvcp-toolbar-input{
  width:100%;
  min-height:40px;
  border-radius:14px;
  border:1px solid var(--bbvcp-line-strong);
  background:#fff;
  color:var(--bbvcp-text);
  padding:10px 12px;
}
.bbvcp-toolbar-color{
  width:100%;
  height:40px;
  border-radius:14px;
  border:1px solid var(--bbvcp-line-strong);
  background:#fff;
  padding:4px;
}
.bbvcp-range{
  padding:0;
  height:24px;
  border:0;
  background:transparent;
  -webkit-appearance:none;
  appearance:none;
}
.bbvcp-range::-webkit-slider-runnable-track{
  height:6px;
  border-radius:999px;
  background:linear-gradient(90deg,#d8c8ff,#7a4dff);
}
.bbvcp-range::-moz-range-track{
  height:6px;
  border-radius:999px;
  background:linear-gradient(90deg,#d8c8ff,#7a4dff);
}
.bbvcp-range::-webkit-slider-thumb{
  -webkit-appearance:none;
  appearance:none;
  width:18px;
  height:18px;
  border-radius:50%;
  margin-top:-6px;
  background:#fff;
  border:2px solid #7a4dff;
  box-shadow:0 4px 12px rgba(122,77,255,.22);
}
.bbvcp-range::-moz-range-thumb{
  width:18px;
  height:18px;
  border-radius:50%;
  background:#fff;
  border:2px solid #7a4dff;
  box-shadow:0 4px 12px rgba(122,77,255,.22);
}
.bbvcp-overlay--preview .bbvcp-sheet--preview{
  width:min(100vw,720px);
  max-width:100vw;
  min-height:100svh;
  height:100svh;
  border-radius:0;
  padding:14px 14px calc(14px + var(--bbvcp-safe-bottom));
  display:grid;
  grid-template-rows:auto minmax(0,1fr) auto;
  gap:12px;
}
.bbvcp-sheet__close{
  width:44px;
  height:44px;
  border-radius:16px;
  border:1px solid var(--bbvcp-line);
  background:#fff;
  color:#6b4ce8;
  display:grid;
  place-items:center;
}
.bbvcp-preview-stage{
  min-height:0;
  border-radius:30px;
  display:grid;
  place-items:center;
  padding:14px;
  overflow:hidden;
}
.bbvcp-preview-stage .bbvcp-card{
  width:min(82vw,360px,calc((100svh - 180px) * 4 / 7));
}
.bbvcp-preview-actions{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:8px;
}
.bbvcp-overlay--name{
  background:rgba(25,17,46,.34);
}
.bbvcp-sheet--name{
  width:min(92vw,420px);
}
@media (max-width:720px){
  .bbvcp-header--dashboard .bbvcp-header__row,
  .bbvcp-promo{
    flex-direction:column;
    align-items:stretch;
  }
  .bbvcp-card-actions{
    grid-template-columns:44px 44px 1fr 44px;
  }
  .bbvcp-preview-actions{
    grid-template-columns:1fr;
  }
  .bbvcp-bottom-main,
  .bbvcp-tool-action{
    min-height:72px;
  }
  .bbvcp-bottom-bar{
    min-height:90px;
    height:90px;
  }
}
@media (prefers-reduced-motion:reduce){
  .bbvcp-tool-action,
  .bbvcp-bottom-main,
  .bbvcp-action-btn{
    transition:none !important;
  }
}


/* v2.4.0 app polish */
.bbvcp-brand{
  display:flex;
  align-items:center;
  gap:12px;
  min-width:0;
}
.bbvcp-brand__brush{
  display:block;
  width:auto;
  height:44px;
  object-fit:contain;
}
.bbvcp-brand.is-compact .bbvcp-brand__brush{
  height:32px;
}
.bbvcp-brand-copy{
  display:grid;
  gap:2px;
  line-height:1;
}
.bbvcp-brand-copy strong{
  font-size:1rem;
  letter-spacing:-0.02em;
}
.bbvcp-brand-copy span{
  font-size:.78rem;
  color:var(--bbvcp-soft);
}
.bbvcp-header__row--brand{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  margin-bottom:10px;
}
.bbvcp-header__brand-wrap{
  min-width:0;
}
.bbvcp-header__intro{
  display:grid;
  gap:4px;
}
.bbvcp-header__intro h1{
  margin:0;
  font-size:clamp(1.55rem,5vw,2.25rem);
}
.bbvcp-header__intro .bbvcp-kicker{
  margin-bottom:2px;
}
.bbvcp-header__actions{
  display:flex;
  align-items:center;
  gap:8px;
}
.bbvcp-pill{
  min-height:34px;
  padding:0 12px;
  border-radius:999px;
}
.bbvcp-dashboard-message{
  margin-top:14px;
}
.bbvcp-summary--compact{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  padding:16px 18px;
}
.bbvcp-summary--compact .bbvcp-summary__meta p{
  margin:4px 0 0;
}
.bbvcp-summary__actions{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}
.bbvcp-gallery{
  margin-top:18px;
}
.bbvcp-card-tile{
  position:relative;
  padding:14px 14px 16px;
}
.bbvcp-card-tile__topline{
  position:absolute;
  top:12px;
  right:12px;
  z-index:3;
}
.bbvcp-card-tile__toggle{
  width:26px;
  height:26px;
  border-radius:999px;
  border:2px solid #cdb9ff;
  background:rgba(255,255,255,.85);
  box-shadow:0 8px 20px rgba(122,77,255,.12);
}
.bbvcp-card-tile__badge{
  position:static;
  display:inline-flex;
  align-items:center;
  min-height:26px;
  padding:0 10px;
  border-radius:999px;
  font-size:.76rem;
  font-weight:800;
}
.bbvcp-card-mini{
  min-height:182px;
  padding:18px 12px 12px;
  border-radius:22px;
  overflow:hidden;
  border:1px solid var(--bbvcp-line);
}
.bbvcp-card-mini .bbvcp-card-editor{
  width:min(100%,136px);
  box-shadow:0 18px 40px rgba(94,65,172,.16);
}
.bbvcp-card-tile h3{
  margin:12px 0 0;
}
.bbvcp-card-actions{
  grid-template-columns:repeat(3,44px);
  justify-content:start;
}
.bbvcp-create-tile{
  min-height:250px;
}
.bbvcp-create-tile strong{
  margin-top:6px;
}
.bbvcp-app--editor{
  min-height:100svh;
  height:100svh;
  overflow:hidden;
}
.bbvcp-shell--editor{
  padding:10px 10px calc(10px + var(--bbvcp-safe-bottom));
}
.bbvcp-app--editor .bbvcp-editor{
  grid-template-rows:52px minmax(0,1fr) 96px;
  gap:8px;
}
.bbvcp-editor__nav--compact{
  display:flex;
  align-items:center;
  gap:10px;
}
.bbvcp-tabs--tight{
  flex:1;
}
.bbvcp-tabs--tight .bbvcp-tab{
  min-height:42px;
  border-radius:16px;
}
.bbvcp-canvas-wrap{
  position:relative;
  padding:0;
  overflow:hidden;
  border-radius:34px;
  background:transparent;
  border:0;
  box-shadow:none;
}
.bbvcp-editor-stage{
  border-radius:34px;
  border:0;
}
#bbvcp-editor-canvas,
.bbvcp-editor-stage__inner{
  width:100%;
  height:100%;
  min-height:0;
  padding:0;
}
.bbvcp-card-shell--editor{
  width:min(100%,360px,calc((100svh - 188px) * 4 / 7));
  max-width:100%;
  animation-duration:1.2s;
  animation-fill-mode:both;
}
.bbvcp-card-editor{
  border-width:var(--bbvcp-frame-thickness,1px);
}
.bbvcp-card-editor__surface,
.bbvcp-face{
  container-type:inline-size;
}
.bbvcp-editor-el,
.bbvcp-el{
  font-size:calc(var(--bbvcp-font-scale, 6) * 1cqw);
  line-height:1.08;
}
.bbvcp-card-editor__surface::after{
  inset:10px;
}
.bbvcp-bottom-bar{
  position:relative;
  bottom:auto;
  min-height:96px;
  height:96px;
  padding:8px;
}
.bbvcp-bottom-main{
  min-height:80px;
}
.bbvcp-bottom-bar--selected{
  display:block;
  overflow:hidden;
}
.bbvcp-tool-strip,
.bbvcp-tool-strip--menu,
.bbvcp-tool-strip__scroll{
  height:100%;
}
.bbvcp-tool-strip--menu{
  display:flex;
  align-items:center;
  gap:8px;
  overflow-x:auto;
  overflow-y:hidden;
  padding-bottom:0;
}
.bbvcp-tool-action{
  min-width:72px;
  min-height:78px;
  padding:10px 10px;
  flex:0 0 auto;
}
.bbvcp-tool-action span:last-child{
  font-size:.78rem;
}
.bbvcp-tool-control{
  min-width:172px;
  min-height:78px;
  flex:0 0 auto;
}
.bbvcp-tool-control--wide{
  min-width:220px;
}
.bbvcp-tool-panel,
.bbvcp-tool-panel--slider{
  height:100%;
}
.bbvcp-tool-panel--slider{
  display:flex;
  align-items:center;
  gap:8px;
}
.bbvcp-range,
.bbvcp-toolbar-color{
  touch-action:none;
}
.bbvcp-range{
  width:100%;
}
.bbvcp-range::-webkit-slider-runnable-track,
.bbvcp-range::-moz-range-track{
  height:8px;
}
.bbvcp-range::-webkit-slider-thumb{
  margin-top:-5px;
}
.bbvcp-preview-stage--portal{
  min-height:0;
  padding:0;
  display:grid;
  place-items:center;
  overflow:hidden;
}
.bbvcp-preview-stage--portal .bbvcp-card-shell{
  transform:scale(.82);
  transition:transform .6s cubic-bezier(.2,.8,.2,1), opacity .6s ease;
  opacity:.94;
}
.bbvcp-preview-stage--portal.is-entered .bbvcp-card-shell{
  transform:scale(1);
  opacity:1;
}
.bbvcp-preview-stage--portal .bbvcp-card{
  width:min(88vw,390px,calc((100svh - 154px) * 4 / 7));
}
.bbvcp-sheet--preview.is-cta-visible .bbvcp-preview-actions{
  opacity:1;
  transform:translateY(0);
}
.bbvcp-preview-actions{
  opacity:0;
  transform:translateY(14px);
  transition:opacity .4s ease, transform .4s ease;
}
@media (max-width:720px){
  .bbvcp-summary--compact{
    flex-direction:column;
    align-items:stretch;
  }
  .bbvcp-header__row--brand{
    margin-bottom:6px;
  }
  .bbvcp-brand.is-compact .bbvcp-brand__brush{
    height:28px;
  }
  .bbvcp-app--editor .bbvcp-editor{
    grid-template-rows:50px minmax(0,1fr) 96px;
  }
  .bbvcp-card-shell--editor{
    width:min(100%,clamp(250px,75vw,356px),calc((100svh - 196px) * 4 / 7));
  }
  .bbvcp-card-mini{
    min-height:174px;
  }
}


/* v2.4.1 polish */
.bbvcp-brand{
  display:flex;
  flex-direction:column;
  gap:6px;
  align-items:flex-start;
}
.bbvcp-brand.is-compact{
  gap:4px;
}
.bbvcp-brand__brush img,
.bbvcp-brand__studio img{
  display:block;
  max-width:100%;
  height:auto;
}
.bbvcp-brand__brush img{
  width:min(220px,58vw);
}
.bbvcp-brand.is-compact .bbvcp-brand__brush img{
  width:min(138px,34vw);
}
.bbvcp-brand__studio img{
  width:min(132px,36vw);
  opacity:.88;
}
.bbvcp-brand.is-compact .bbvcp-brand__studio img{
  width:min(92px,24vw);
}
.bbvcp-header__row--tight{
  align-items:flex-start;
}
.bbvcp-header__actions--topright{
  gap:8px;
}
.bbvcp-pill--small{
  min-height:34px;
  padding:0 12px;
  font-size:.78rem;
}
.bbvcp-icon-button--small{
  width:38px;
  height:38px;
  border-radius:14px;
}
.bbvcp-header__intro--compact{
  gap:6px;
}
.bbvcp-dashboard-message{
  margin-bottom:6px;
}
.bbvcp-gallery--spaced{
  margin-top:18px;
}
.bbvcp-summary--compact{
  padding:16px 18px;
}
.bbvcp-summary__meta--compact{
  margin-bottom:12px;
}
.bbvcp-card-tile{
  overflow:hidden;
}
.bbvcp-card-mini{
  min-height:176px;
  padding:12px 8px 8px;
  background:linear-gradient(180deg,#f6efff,#efe4ff);
}
.bbvcp-card-mini .bbvcp-card-editor{
  width:min(100%,152px);
  box-shadow:0 18px 44px rgba(94,65,172,.18);
}
.bbvcp-card-actions{
  grid-template-columns:repeat(3,44px);
  justify-content:start;
}
.bbvcp-card-tile__topline{
  position:absolute;
  top:10px;
  right:10px;
  z-index:5;
}
.bbvcp-card-tile__toggle,
.bbvcp-card-tile__badge{
  backdrop-filter:blur(8px);
}
.bbvcp-app--editor .bbvcp-editor{
  grid-template-rows:52px minmax(0,1fr) 88px !important;
  gap:8px !important;
}
.bbvcp-app--editor .bbvcp-canvas-wrap{
  padding:0 !important;
  min-height:0;
}
.bbvcp-app--editor .bbvcp-editor-stage,
.bbvcp-app--editor .bbvcp-editor-stage__inner,
.bbvcp-app--editor #bbvcp-editor-canvas{
  min-height:0;
  height:100%;
}
.bbvcp-app--editor .bbvcp-editor-stage{
  background:transparent !important;
  border:0 !important;
}
.bbvcp-app--editor .bbvcp-editor-stage__inner{
  padding:0 !important;
}
.bbvcp-card-shell--editor{
  width:min(100%,368px,calc((100svh - 176px) * 4 / 7)) !important;
  max-width:100%;
}
.bbvcp-bottom-bar{
  min-height:88px !important;
  height:88px !important;
  padding:8px !important;
  overflow:hidden;
}
.bbvcp-bottom-bar--selected{
  grid-template-columns:1fr !important;
}
.bbvcp-tool-strip{
  display:flex;
  gap:8px;
  overflow-x:auto;
  overflow-y:hidden;
  width:100%;
  min-width:0;
  padding-bottom:4px;
  -webkit-overflow-scrolling:touch;
  scrollbar-width:none;
}
.bbvcp-tool-strip::-webkit-scrollbar{
  display:none;
}
.bbvcp-tool-action{
  flex:0 0 auto;
}
.bbvcp-tool-action.is-active{
  background:linear-gradient(135deg,#7a4dff,#9f7aea);
  color:#fff;
  border-color:transparent;
}
.bbvcp-tool-panel{
  display:flex;
  align-items:center;
  gap:8px;
  overflow-x:auto;
  width:100%;
  min-width:0;
  padding-bottom:4px;
  -webkit-overflow-scrolling:touch;
}
.bbvcp-tool-control{
  flex:0 0 auto;
}
.bbvcp-tool-control--wide{
  min-width:220px;
}
.bbvcp-input--compact{
  padding:10px 12px;
  min-height:42px;
}
.bbvcp-color-swatches{
  display:flex;
  gap:8px;
  margin:8px 0 10px;
  overflow-x:auto;
  padding-bottom:4px;
}
.bbvcp-color-swatch{
  width:28px;
  height:28px;
  border-radius:50%;
  border:2px solid rgba(107,72,229,.18);
  background:var(--bbvcp-swatch);
  box-shadow:0 4px 12px rgba(92,67,171,.14);
}
.bbvcp-color-swatch.is-active{
  border-color:#6b48e5;
  box-shadow:0 0 0 4px rgba(122,77,255,.12);
}
.bbvcp-sheet__grid--qr{
  grid-template-columns:repeat(2,minmax(0,1fr));
}
.bbvcp-field--full{
  grid-column:1 / -1;
}
.bbvcp-qr-preview{
  display:grid;
  place-items:center;
  padding:16px;
  background:#fff;
  border:1px solid var(--bbvcp-line);
  border-radius:28px;
  box-shadow:0 14px 38px rgba(96,64,176,.10);
}
.bbvcp-qr-preview img{
  width:min(280px,72vw);
  height:auto;
  display:block;
}
.bbvcp-qr-preview--rounded img{border-radius:22px;}
.bbvcp-qr-preview--dots img{border-radius:28px; filter:contrast(1.04) saturate(1.02);}
.bbvcp-qr-preview--soft{box-shadow:0 18px 46px rgba(122,77,255,.16);}
.bbvcp-qr-preview--frame{border-width:2px;}
.bbvcp-qr-preview--halo{box-shadow:0 0 0 1px rgba(122,77,255,.14),0 0 0 12px rgba(122,77,255,.06),0 16px 44px rgba(122,77,255,.14);}
.bbvcp-range{
  appearance:none;
  -webkit-appearance:none;
  height:28px;
  padding:0 !important;
  background:transparent !important;
  touch-action:none;
}
.bbvcp-range::-webkit-slider-runnable-track{
  height:6px;
  background:linear-gradient(90deg,#d6c4ff,#7a4dff);
  border-radius:999px;
}
.bbvcp-range::-moz-range-track{
  height:6px;
  background:linear-gradient(90deg,#d6c4ff,#7a4dff);
  border-radius:999px;
}
.bbvcp-range::-webkit-slider-thumb{
  -webkit-appearance:none;
  appearance:none;
  margin-top:-7px;
  width:20px;
  height:20px;
  border-radius:50%;
  border:2px solid #fff;
  background:#7a4dff;
  box-shadow:0 6px 14px rgba(122,77,255,.26);
}
.bbvcp-range::-moz-range-thumb{
  width:20px;
  height:20px;
  border:none;
  border-radius:50%;
  background:#7a4dff;
  box-shadow:0 6px 14px rgba(122,77,255,.26);
}
.bbvcp-preview-stage .bbvcp-card[data-side="front"] .bbvcp-face--back,
.bbvcp-public .bbvcp-card[data-side="front"] .bbvcp-face--back{
  opacity:0;
  visibility:hidden;
}
.bbvcp-preview-stage .bbvcp-card[data-side="back"] .bbvcp-face--front,
.bbvcp-public .bbvcp-card[data-side="back"] .bbvcp-face--front{
  opacity:0;
  visibility:hidden;
}
.bbvcp-preview-stage .bbvcp-face,
.bbvcp-public .bbvcp-face{
  transition:opacity .18s ease, visibility .18s ease, transform .9s cubic-bezier(.2,.8,.2,1);
  -webkit-backface-visibility:hidden;
  backface-visibility:hidden;
}
.bbvcp-preview-stage .bbvcp-face *,
.bbvcp-public .bbvcp-face *{
  -webkit-backface-visibility:hidden;
  backface-visibility:hidden;
}


/* v2.5.0 polish */
.bbvcp-brand{
  display:flex;
  align-items:center;
}
.bbvcp-brand__brush{
  display:flex;
  align-items:center;
  min-width:0;
}
.bbvcp-brand__brush img{
  display:block;
  max-width:min(220px,62vw);
  width:auto;
  height:auto;
}
.bbvcp-brand.is-compact .bbvcp-brand__brush img{
  max-width:132px;
}
.bbvcp-powered-by{
  margin-top:18px;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  color:#856fb0;
  font-size:.84rem;
  font-weight:700;
}
.bbvcp-powered-by img{
  max-width:140px;
  height:auto;
  display:block;
}
.bbvcp-header__row--dashboard-line{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}
.bbvcp-header__line-left{
  display:flex;
  align-items:center;
  gap:12px;
  min-width:0;
}
.bbvcp-kicker--inline{
  margin:0;
  white-space:nowrap;
}
.bbvcp-header__intro--compact{
  margin-top:10px;
}
.bbvcp-summary--active-card{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:14px 16px;
}
.bbvcp-summary__actions--inline{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  justify-content:flex-end;
}
.bbvcp-gallery--spaced{
  margin-top:20px;
}
.bbvcp-dashboard-message{
  margin-top:12px;
  margin-bottom:10px;
}
.bbvcp-card-mini{
  min-height:190px;
  padding:8px;
  display:grid;
}
.bbvcp-card-mini__stage{
  min-height:100%;
  display:grid;
  place-items:center;
  border-radius:22px;
  padding:10px;
  background:linear-gradient(180deg,rgba(122,77,255,.10),rgba(122,77,255,.04));
}
.bbvcp-card-mini .bbvcp-card-editor{
  width:min(100%,150px);
  max-width:100%;
  box-shadow:0 20px 44px rgba(95,62,174,.12);
}
.bbvcp-card-tile .bbvcp-card-mini{
  margin-bottom:8px;
}
.bbvcp-tool-strip,
.bbvcp-tool-strip__scroll,
.bbvcp-tool-strip--menu{
  min-height:92px;
}
.bbvcp-bottom-bar{
  min-height:104px;
  height:104px;
  align-items:stretch;
}
.bbvcp-bottom-bar--selected{
  padding:10px 12px;
}
.bbvcp-tool-action{
  min-height:72px;
  padding:10px 12px;
  border-radius:22px;
  display:inline-flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:6px;
  border:1px solid var(--bbvcp-line);
  background:#fff;
  color:var(--bbvcp-text);
  font-weight:800;
}
.bbvcp-tool-action span:last-child{
  font-size:.78rem;
  line-height:1.05;
}
.bbvcp-tool-action__icon{
  width:18px;
  height:18px;
  display:flex;
  align-items:center;
  justify-content:center;
}
.bbvcp-tool-control{
  min-width:154px;
  min-height:72px;
  padding:10px 12px;
  border-radius:20px;
  border:1px solid var(--bbvcp-line);
  background:#faf7ff;
  display:grid;
  gap:6px;
  align-content:center;
}
.bbvcp-tool-control--wide{
  min-width:210px;
}
.bbvcp-tool-control span{
  font-size:.74rem;
  font-weight:700;
  color:#6f5b9c;
  line-height:1.05;
}
.bbvcp-tool-control em{
  font-style:normal;
  font-size:.78rem;
  color:#6f5b9c;
}
.bbvcp-toolbar-input,
.bbvcp-tool-control .bbvcp-select,
.bbvcp-tool-control .bbvcp-range,
.bbvcp-tool-control input[type="color"]{
  min-height:42px;
}
.bbvcp-range{
  height:22px;
  padding:0;
  background:transparent;
  touch-action:none;
}
.bbvcp-range::-webkit-slider-runnable-track{
  height:6px;
  border-radius:999px;
  background:linear-gradient(90deg,#d8c8ff,#7a4dff);
}
.bbvcp-range::-moz-range-track{
  height:6px;
  border-radius:999px;
  background:linear-gradient(90deg,#d8c8ff,#7a4dff);
}
.bbvcp-range::-webkit-slider-thumb{
  margin-top:-7px;
}
.bbvcp-toolbar-color,
input[type="color"].bbvcp-input{
  touch-action:none;
}
.bbvcp-sheet--preview-full{
  width:100%;
  max-width:none;
  max-height:100svh;
  height:100svh;
  border-radius:0;
  border:none;
  background:transparent;
  box-shadow:none;
  backdrop-filter:none;
  padding:0;
}
.bbvcp-preview-stage--portal{
  width:100%;
  height:100svh;
  min-height:100svh;
  border-radius:0;
  padding:20px 16px;
  animation:bbvcpPortalIn .6s cubic-bezier(.2,.9,.24,1) both;
}
.bbvcp-preview-floating{
  position:fixed;
  top:max(14px, env(safe-area-inset-top));
  left:0;
  right:0;
  z-index:3;
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:0 14px;
  pointer-events:none;
}
.bbvcp-sheet__close--floating{
  pointer-events:auto;
  width:48px;
  height:48px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.45);
  background:rgba(255,255,255,.78);
  box-shadow:0 14px 36px rgba(79,54,146,.16);
}
.bbvcp-sheet__close--floating.is-confirm{
  background:linear-gradient(135deg,#7a4dff,#9d79ff);
  color:#fff;
  border-color:transparent;
}
.bbvcp-preview-stage .bbvcp-card{
  width:min(84vw,390px);
}
.bbvcp-add-groups{
  display:grid;
  gap:16px;
}
.bbvcp-add-group{
  display:grid;
  gap:10px;
}
.bbvcp-add-group__label{
  margin:0;
  font-size:.76rem;
  font-weight:800;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:#7d68aa;
}
.bbvcp-contact-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:12px;
}
.bbvcp-field--full{
  grid-column:1 / -1;
}
.bbvcp-suggestion-reward{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:14px 16px;
  border-radius:18px;
  border:1px solid #dfceff;
  background:linear-gradient(135deg,#fff9ff,#f1e8ff 55%,#e6d7ff);
  box-shadow:0 18px 36px rgba(122,77,255,.12), inset 0 1px 0 rgba(255,255,255,.7);
}
.bbvcp-suggestion-reward strong{
  font-size:1rem;
}
.bbvcp-suggestion-reward span{
  color:#6f5b9c;
  font-weight:700;
}
@keyframes bbvcpPortalIn{
  from{transform:scale(.88);opacity:0}
  to{transform:scale(1);opacity:1}
}
@media (max-width:720px){
  .bbvcp-header__line-left{
    gap:8px;
  }
  .bbvcp-brand.is-compact .bbvcp-brand__brush img{
    max-width:110px;
  }
  .bbvcp-kicker--inline{
    font-size:.72rem;
  }
  .bbvcp-summary--active-card{
    padding:12px 14px;
  }
  .bbvcp-summary__actions--inline{
    width:auto;
  }
  .bbvcp-contact-grid{
    grid-template-columns:1fr;
  }
  .bbvcp-preview-stage .bbvcp-card{
    width:min(86vw,calc((100svh - 140px) * 4 / 7));
  }
}

.bbvcp-preview-stage .bbvcp-card,
.bbvcp-preview-stage .bbvcp-face{
  transform-style:preserve-3d;
}
.bbvcp-preview-stage .bbvcp-face--front{
  transform:rotateY(0deg) translateZ(1px);
}
.bbvcp-preview-stage .bbvcp-face--back{
  transform:rotateY(180deg) translateZ(1px);
}

.bbvcp-sheet__menu-item--reward{
  background:linear-gradient(135deg,#fff7ff,#f3e8ff 55%,#e5d3ff);
  box-shadow:0 16px 34px rgba(122,77,255,.10);
}


/* v2.5.1 dashboard, thumbnails, toolbar fit, and animation system */
.bbvcp-dashboard-bar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}
.bbvcp-dashboard-bar__brand{
  display:flex;
  align-items:center;
  gap:12px;
  min-width:0;
}
.bbvcp-dashboard-bar__copy{
  display:flex;
  align-items:center;
  min-width:0;
}
.bbvcp-dashboard-bar__copy span{
  font-size:1rem;
  font-weight:900;
  letter-spacing:-0.02em;
  color:var(--bbvcp-text);
  white-space:nowrap;
}
.bbvcp-dashboard-bar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}
.bbvcp-dashboard-bar__brand-wrap{
  display:flex;
  align-items:center;
  gap:10px;
  min-width:0;
}
.bbvcp-dashboard-bar__brand{
  flex:0 0 auto;
}
.bbvcp-pill--plan{
  min-width:64px;
  text-align:center;
}
.bbvcp-card-mini{
  --bbvcp-mini-scale:.62;
  min-height:188px;
  padding:8px 8px 10px;
  border-radius:22px;
  overflow:hidden;
}
.bbvcp-card-mini__stage{
  min-height:100%;
  display:flex;
  align-items:flex-start;
  justify-content:center;
  overflow:hidden;
  padding:8px 0 0;
}
.bbvcp-card-mini__scale{
  width:240px;
  transform:scale(var(--bbvcp-mini-scale));
  transform-origin:top center;
  pointer-events:none;
}
.bbvcp-card-shell--mini{
  width:240px;
  max-width:none;
}
.bbvcp-card-mini .bbvcp-card-editor{
  width:100%;
  max-width:none;
  box-shadow:0 18px 40px rgba(95,62,174,.18);
  border-color:rgba(122,77,255,.3);
}
.bbvcp-card-mini .bbvcp-card-editor__surface::after{
  inset:8px;
  border-radius:14px;
}
.bbvcp-card-mini .bbvcp-editor-el,
.bbvcp-card-mini .bbvcp-el{
  font-size:clamp(8px, calc(var(--bbvcp-font-scale, 6) * 1.15px), 18px);
}
.bbvcp-header__actions--topright{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:8px;
}
.bbvcp-bottom-bar{
  min-height:92px;
  height:auto;
  padding:8px;
  align-items:stretch;
}
.bbvcp-bottom-bar--selected{
  min-height:92px;
  padding:8px 10px;
}
.bbvcp-tool-strip,
.bbvcp-tool-strip__scroll,
.bbvcp-tool-strip--menu{
  min-height:76px;
}
.bbvcp-tool-action{
  min-width:78px;
  min-height:64px;
  padding:10px 10px;
  border-radius:18px;
  gap:5px;
}
.bbvcp-tool-action span:last-child{
  font-size:.73rem;
  line-height:1.08;
}
.bbvcp-tool-control{
  min-width:148px;
  min-height:64px;
  padding:10px 10px;
  gap:5px;
}
.bbvcp-tool-control--wide{
  min-width:210px;
}
.bbvcp-tool-control span{
  font-size:.72rem;
  line-height:1.08;
}
.bbvcp-tool-control strong,
.bbvcp-tool-control em{
  line-height:1.08;
}
.bbvcp-toolbar-input,
.bbvcp-tool-control .bbvcp-input,
.bbvcp-tool-control .bbvcp-select{
  min-height:40px;
  padding:8px 10px;
}
.bbvcp-tool-control .bbvcp-range{
  height:24px;
}
.bbvcp-editor-stage__inner.is-theme-preview{
  animation:bbvcpThemePulse .75s ease both;
}
@keyframes bbvcpThemePulse{
  0%{transform:scale(.985);filter:saturate(.92)}
  100%{transform:scale(1);filter:saturate(1)}
}
.bbvcp-card-shell{
  --bbvcp-entrance-animation:none;
  --bbvcp-idle-animation:none;
  animation:var(--bbvcp-entrance-animation), var(--bbvcp-idle-animation);
  animation-fill-mode:both, both;
}
.bbvcp-card-shell--editor{
  animation:none !important;
}
.bbvcp-card-shell--editor.is-previewing-entrance{
  animation:var(--bbvcp-entrance-animation) !important;
}
.bbvcp-card-shell--editor.is-previewing-idle{
  animation:var(--bbvcp-idle-animation) !important;
}
.bbvcp-entrance--none{--bbvcp-entrance-animation:none;}
.bbvcp-entrance--summon-reveal{--bbvcp-entrance-animation:bbvcpSummonReveal 1.4s cubic-bezier(.22,.94,.25,1) both;}
.bbvcp-entrance--flip-reveal{--bbvcp-entrance-animation:bbvcpShellFlip .9s cubic-bezier(.22,.94,.25,1) both;}
.bbvcp-entrance--glow-pulse{--bbvcp-entrance-animation:bbvcpShellGlow 1.05s ease both;}
.bbvcp-entrance--slide-up-spotlight{--bbvcp-entrance-animation:bbvcpShellSpotlight 1s cubic-bezier(.22,.94,.25,1) both;}
.bbvcp-entrance--holographic-materialize{--bbvcp-entrance-animation:bbvcpShellHolo 1.1s cubic-bezier(.22,.94,.25,1) both;}
.bbvcp-entrance--velvet-rise{--bbvcp-entrance-animation:bbvcpVelvetRise 1.1s cubic-bezier(.2,.84,.18,1) both;}
.bbvcp-entrance--prism-bloom{--bbvcp-entrance-animation:bbvcpPrismBloom 1.25s cubic-bezier(.2,.84,.18,1) both;}
.bbvcp-entrance--spotlight-sweep{--bbvcp-entrance-animation:bbvcpSpotlightSweep 1s cubic-bezier(.2,.84,.18,1) both;}
.bbvcp-entrance--midnight-float{--bbvcp-entrance-animation:bbvcpMidnightFloat 1.15s cubic-bezier(.2,.84,.18,1) both;}
.bbvcp-entrance--neon-scan{--bbvcp-entrance-animation:bbvcpNeonScan 1.1s cubic-bezier(.2,.84,.18,1) both;}
.bbvcp-entrance--glass-pop{--bbvcp-entrance-animation:bbvcpGlassPop .95s cubic-bezier(.2,.84,.18,1) both;}
.bbvcp-entrance--lux-lift{--bbvcp-entrance-animation:bbvcpLuxLift 1.05s cubic-bezier(.2,.84,.18,1) both;}
.bbvcp-entrance--aurora-drift{--bbvcp-entrance-animation:bbvcpAuroraDrift 1.2s cubic-bezier(.2,.84,.18,1) both;}
.bbvcp-entrance--pulse-flip{--bbvcp-entrance-animation:bbvcpPulseFlip 1s cubic-bezier(.2,.84,.18,1) both;}
.bbvcp-idle--none{--bbvcp-idle-animation:none;}
.bbvcp-idle--floating{--bbvcp-idle-animation:bbvcpIdleFloat 4.2s ease-in-out .2s infinite;}
.bbvcp-idle--shimmer{--bbvcp-idle-animation:bbvcpIdleFloat 4.4s ease-in-out .3s infinite;}
.bbvcp-idle--breathe{--bbvcp-idle-animation:bbvcpIdleBreathe 3.8s ease-in-out .2s infinite;}
.bbvcp-idle--sway{--bbvcp-idle-animation:bbvcpIdleSway 4.8s ease-in-out .2s infinite;}
.bbvcp-idle--shake{--bbvcp-idle-animation:bbvcpIdleShake 3.2s ease-in-out .2s infinite;}
.bbvcp-idle--pulse{--bbvcp-idle-animation:bbvcpIdlePulse 3.4s ease-in-out .2s infinite;}
.bbvcp-idle--drift{--bbvcp-idle-animation:bbvcpIdleDrift 5.2s ease-in-out .2s infinite;}
.bbvcp-idle--tilt{--bbvcp-idle-animation:bbvcpIdleTilt 4.1s ease-in-out .2s infinite;}
.bbvcp-entrance--summon-reveal::after,
.bbvcp-idle--floating::after,
.bbvcp-idle--shimmer::after{
  animation:bbvcpShimmer 3.8s linear 2.2s infinite;
}
@keyframes bbvcpIdleBreathe{
  0%,100%{transform:translateY(0) scale(1)}
  50%{transform:translateY(-5px) scale(1.02)}
}
@keyframes bbvcpIdleSway{
  0%,100%{transform:rotateZ(-1.5deg)}
  50%{transform:rotateZ(1.4deg)}
}
@keyframes bbvcpIdleShake{
  0%,100%{transform:translateX(0)}
  20%{transform:translateX(-2px)}
  40%{transform:translateX(2px)}
  60%{transform:translateX(-1px)}
  80%{transform:translateX(1px)}
}
@keyframes bbvcpIdlePulse{
  0%,100%{transform:scale(1)}
  50%{transform:scale(1.02)}
}
@keyframes bbvcpIdleDrift{
  0%,100%{transform:translate3d(0,0,0) rotateZ(-1deg)}
  50%{transform:translate3d(6px,-6px,0) rotateZ(.8deg)}
}
@keyframes bbvcpIdleTilt{
  0%,100%{transform:rotateX(0) rotateY(0)}
  50%{transform:rotateX(2deg) rotateY(-4deg)}
}
@media (max-width: 680px){
  .bbvcp-dashboard-bar__copy span{
    font-size:.92rem;
  }
  .bbvcp-card-shell--mini{
    width:min(100%,156px);
  }
}

.bbvcp-card-mini{
  box-shadow:inset 0 0 0 1px rgba(122,77,255,.08);
}
.bbvcp-card-mini .bbvcp-card-editor{
  background:var(--card-bg,linear-gradient(180deg,#ffffff 0%,#f3ebff 100%));
}
.bbvcp-card-mini .bbvcp-card-editor__surface::after{
  inset:10px;
  border-color:rgba(122,77,255,.22);
}
.bbvcp-card-mini .bbvcp-editor-el,
.bbvcp-card-mini .bbvcp-el{
  font-size:calc(var(--bbvcp-font-scale, 6) * 1cqw);
  line-height:1.08;
}
@media (max-width: 420px){
  .bbvcp-card-mini{ --bbvcp-mini-scale:.58; }
  .bbvcp-dashboard-bar__copy span{ font-size:.96rem; }
}


/* Thumbnail hotfix: restore stable dashboard card rendering */
.bbvcp-card-mini{
  display:grid;
  place-items:center;
  min-height:156px;
  padding:14px 8px 8px;
  border-radius:22px;
  overflow:hidden;
  background:linear-gradient(180deg,#fbf8ff,#f4ecff);
}
.bbvcp-card-mini .bbvcp-card-editor{
  width:100%;
  max-width:112px;
  margin:0 auto;
  box-shadow:0 14px 34px rgba(94,65,172,.14);
  border-color:rgba(122,77,255,.20);
}
.bbvcp-card-mini .bbvcp-card-editor__surface::after{
  inset:10px;
  border-radius:14px;
}
.bbvcp-card-mini .bbvcp-el,
.bbvcp-card-mini .bbvcp-editor-el{
  font-size:clamp(7px, calc(var(--bbvcp-font-scale, 6) * 1px), 15px);
}


/* Preview flip reliability hotfix */
.bbvcp-sheet--preview .bbvcp-card{
  -webkit-transform-style:preserve-3d;
  transform-style:preserve-3d;
  will-change:transform;
}
.bbvcp-sheet--preview .bbvcp-face{
  -webkit-backface-visibility:hidden;
  backface-visibility:hidden;
  -webkit-transform-style:preserve-3d;
  transform-style:preserve-3d;
  transition:opacity .18s linear, visibility 0s linear .18s;
}
.bbvcp-sheet--preview .bbvcp-face--front{
  transform:rotateY(0deg) translateZ(1px);
}
.bbvcp-sheet--preview .bbvcp-face--back{
  transform:rotateY(180deg) translateZ(1px);
}
.bbvcp-sheet--preview .bbvcp-card[data-side="front"] .bbvcp-face--front{
  opacity:1;
  visibility:visible;
  transition-delay:0s;
}
.bbvcp-sheet--preview .bbvcp-card[data-side="front"] .bbvcp-face--back{
  opacity:0;
  visibility:hidden;
}
.bbvcp-sheet--preview .bbvcp-card[data-side="back"] .bbvcp-face--front{
  opacity:0;
  visibility:hidden;
}
.bbvcp-sheet--preview .bbvcp-card[data-side="back"] .bbvcp-face--back{
  opacity:1;
  visibility:visible;
  transition-delay:0s;
}

.bbvcp-dashboard-bar--clean{
  margin-bottom:8px;
}
.bbvcp-dashboard-bar__brand-wrap--stacked{
  flex:1;
  min-width:0;
}
.bbvcp-icon-button--settings{
  position:relative;
}
.bbvcp-notice-dot{
  position:absolute;
  top:8px;
  right:8px;
  width:10px;
  height:10px;
  border-radius:999px;
  background:linear-gradient(135deg,#ff7aa2,#d6456f);
  box-shadow:0 0 0 3px #fff;
}
.bbvcp-release-list{
  display:grid;
  gap:14px;
}
.bbvcp-release-card{
  padding:16px;
  border-radius:22px;
  border:1px solid var(--bbvcp-line);
  background:linear-gradient(180deg,#ffffff,#f8f3ff);
}
.bbvcp-release-card h3{
  margin:0 0 10px;
  font-size:1rem;
}
.bbvcp-release-card ul{
  margin:0;
  padding-left:18px;
  color:var(--bbvcp-soft);
  display:grid;
  gap:8px;
}
.bbvcp-sheet__menu-item--new{
  border-color:#d7c3ff;
  background:linear-gradient(180deg,#fff,#f7f0ff);
}
.bbvcp-sheet--tester{
  width:min(92vw,430px);
}
.bbvcp-tester-note{
  padding:14px;
  border-radius:20px;
  background:linear-gradient(180deg,#fbf8ff,#f4ecff);
  border:1px solid var(--bbvcp-line);
  color:#5b4a86;
}
.bbvcp-tester-note p{
  margin:0;
}
.bbvcp-color-row{
  display:grid;
  grid-template-columns:44px minmax(0,1fr);
  gap:8px;
  align-items:center;
}
.bbvcp-color-input{
  width:44px;
  height:40px;
  padding:0;
  border:1px solid var(--bbvcp-line-strong);
  border-radius:14px;
  background:#fff;
  overflow:hidden;
}
.bbvcp-color-input::-webkit-color-swatch-wrapper{
  padding:3px;
}
.bbvcp-color-input::-webkit-color-swatch{
  border:none;
  border-radius:10px;
}
.bbvcp-color-input::-moz-color-swatch{
  border:none;
  border-radius:10px;
}
.bbvcp-qr{
  display:grid;
  gap:16px;
}
.bbvcp-sheet--qr{
  max-width:min(96vw,740px);
}
.bbvcp-qr-preview{
  --bbvcp-qr-dark:#2B1F52;
  --bbvcp-qr-light:#FFFFFF;
  background:
    radial-gradient(circle at top left,rgba(122,77,255,.12),transparent 40%),
    linear-gradient(180deg,var(--bbvcp-qr-light),#f7f1ff);
}
.bbvcp-auth__card--minimal .bbvcp-brand{
  justify-content:center;
}
.bbvcp-qr-preview img{
  border-radius:18px;
  box-shadow:0 14px 34px rgba(96,64,176,.10);
}
.bbvcp-qr-preview--rounded img{
  border-radius:28px;
}
.bbvcp-qr-preview--dots img{
  border-radius:32px;
  box-shadow:0 0 0 10px rgba(122,77,255,.05),0 14px 34px rgba(96,64,176,.12);
}
.bbvcp-qr-preview--soft{
  box-shadow:0 18px 46px rgba(122,77,255,.16);
}
.bbvcp-qr-preview--frame{
  border-width:2px;
  border-color:rgba(122,77,255,.28);
}
.bbvcp-qr-preview--halo{
  box-shadow:0 0 0 1px rgba(122,77,255,.14),0 0 0 12px rgba(122,77,255,.06),0 16px 44px rgba(122,77,255,.14);
}
.bbvcp-qr-config{
  display:grid;
  gap:14px;
}
.bbvcp-qr-color-card{
  padding:14px;
  border-radius:22px;
  border:1px solid var(--bbvcp-line);
  background:#fbf8ff;
  display:grid;
  gap:12px;
}
.bbvcp-qr-color-card__head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}
.bbvcp-qr-color-card__head span{
  font-size:.82rem;
  color:var(--bbvcp-soft);
}
.bbvcp-color-swatches--qr{
  justify-content:flex-start;
}
.bbvcp-qr-color-card__inputs{
  display:grid;
  grid-template-columns:44px minmax(0,1fr);
  gap:10px;
  align-items:center;
}
.bbvcp-inline--spread{
  justify-content:space-between;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
}
.bbvcp-brand__brush img{
  display:block;
  height:100%;
  width:auto;
  object-fit:contain;
}
@media (max-width: 720px) {
  .bbvcp-auth{
    padding:14px;
  }
  .bbvcp-auth__card--minimal{
    border-radius:24px;
  }
  .bbvcp-dashboard-bar__brand .bbvcp-brand__brush{
    height:28px;
  }
  .bbvcp-pill--plan{
    min-width:56px;
    padding:0 10px;
  }
}

.bbvcp-icon-button,
.bbvcp-action-btn,
.bbvcp-chip,
.bbvcp-button,
.bbvcp-ghost,
.bbvcp-tool-action{
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease, background .18s ease;
}
.bbvcp-icon-button:active,
.bbvcp-action-btn:active,
.bbvcp-chip:active,
.bbvcp-button:active,
.bbvcp-tool-action:active{
  transform:translateY(1px) scale(.985);
}


.bbvcp-auth .bbvcp-brand{
  justify-content:center;
}
.bbvcp-auth .bbvcp-brand__brush{
  display:flex;
  align-items:center;
  justify-content:center;
  width:100%;
  height:auto;
}
.bbvcp-auth .bbvcp-brand__brush img{
  display:block;
  width:min(100%, 250px);
  max-width:250px;
  height:auto;
}
.bbvcp-brand.is-compact .bbvcp-brand__brush img{
  height:32px;
  width:auto;
  max-width:160px;
}
.bbvcp-code-wrap{
  position:relative;
  display:block;
}
.bbvcp-code-wrap .bbvcp-code{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  border:0;
  background:transparent;
  color:transparent;
  caret-color:transparent;
  letter-spacing:.82em;
  padding:0 18px;
  z-index:2;
}
.bbvcp-code-wrap .bbvcp-code::placeholder{
  color:transparent;
}
.bbvcp-code-slots{
  display:grid;
  grid-template-columns:repeat(6,minmax(0,1fr));
  gap:10px;
  pointer-events:none;
}
.bbvcp-code-slot{
  min-height:56px;
  border-radius:18px;
  border:1px solid var(--bbvcp-line-strong);
  background:#fff;
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight:800;
  font-size:1.12rem;
  color:#b8acd7;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.9);
}
.bbvcp-code-slot.has-value{
  color:var(--bbvcp-text);
  border-color:#cbb7ff;
  box-shadow:0 12px 22px rgba(122,77,255,.08), inset 0 1px 0 rgba(255,255,255,.95);
}


/* v2.5.1.5 auth resend, brand sizing, and login polish */
.bbvcp-auth{
  position:relative;
  overflow:hidden;
  background:
    radial-gradient(60% 46% at 12% 18%, rgba(145,103,255,.18) 0%, rgba(145,103,255,0) 72%),
    radial-gradient(44% 38% at 88% 16%, rgba(233,205,255,.85) 0%, rgba(233,205,255,0) 76%),
    radial-gradient(52% 44% at 50% 100%, rgba(175,128,255,.18) 0%, rgba(175,128,255,0) 72%),
    linear-gradient(180deg,#fbf8ff 0%,#efe7ff 56%,#f7f2ff 100%);
}
.bbvcp-auth::before,
.bbvcp-auth::after{
  content:"";
  position:absolute;
  inset:auto;
  pointer-events:none;
  z-index:0;
}
.bbvcp-auth::before{
  width:min(72vw,520px);
  height:min(72vw,520px);
  top:-14%;
  right:-12%;
  border-radius:50%;
  background:
    radial-gradient(circle at 35% 35%, rgba(255,255,255,.9) 0%, rgba(255,255,255,.38) 20%, rgba(255,255,255,0) 58%),
    radial-gradient(circle at 60% 60%, rgba(165,120,255,.22) 0%, rgba(165,120,255,.08) 28%, rgba(165,120,255,0) 60%);
  filter:blur(10px);
}
.bbvcp-auth::after{
  left:-18%;
  bottom:-12%;
  width:min(78vw,560px);
  height:min(78vw,560px);
  border-radius:50%;
  background:
    radial-gradient(circle at 58% 42%, rgba(255,255,255,.82) 0%, rgba(255,255,255,.25) 18%, rgba(255,255,255,0) 52%),
    conic-gradient(from 220deg, rgba(122,77,255,.08), rgba(255,255,255,0) 28%, rgba(122,77,255,.14) 62%, rgba(255,255,255,0) 88%, rgba(122,77,255,.08));
  filter:blur(14px);
  opacity:.9;
}
.bbvcp-auth__card{
  position:relative;
  z-index:1;
}
.bbvcp-auth .bbvcp-brand{
  justify-content:center;
}
.bbvcp-auth .bbvcp-brand__brush img{
  width:min(100%, 320px);
  max-width:320px;
  height:auto;
}
.bbvcp-dashboard-bar__brand .bbvcp-brand.is-compact .bbvcp-brand__brush img{
  max-width:156px;
  width:auto;
  height:auto;
}
.bbvcp-code-wrap{
  isolation:isolate;
}
.bbvcp-code-wrap .bbvcp-code{
  caret-color:transparent !important;
}
.bbvcp-auth__resend{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  min-height:22px;
  margin:-2px 2px 2px;
}
.bbvcp-auth__resend-copy{
  font-size:.84rem;
  font-weight:700;
  color:#7a68a4;
}
.bbvcp-auth__resend-button{
  border:0;
  background:transparent;
  color:#6f46ef;
  font-weight:800;
  padding:0;
  font-size:.84rem;
  cursor:pointer;
}
.bbvcp-auth__resend-button[disabled]{
  color:#998eb8;
  cursor:default;
}
.bbvcp-auth.is-success::before,
.bbvcp-auth.is-success::after{
  animation:bbvcpAuthBurst .72s cubic-bezier(.22,.94,.24,1) both;
}
.bbvcp-auth.is-success .bbvcp-auth__card{
  animation:bbvcpAuthLaunch .72s cubic-bezier(.22,.94,.24,1) both;
}
@keyframes bbvcpAuthLaunch{
  0%{transform:translateY(0) scale(1); opacity:1; filter:blur(0)}
  38%{transform:translateY(-6px) scale(1.015); opacity:1}
  100%{transform:translateY(-32px) scale(1.075); opacity:0; filter:blur(8px)}
}
@keyframes bbvcpAuthBurst{
  0%{transform:scale(1); opacity:.95}
  100%{transform:scale(1.18); opacity:0}
}
@media (max-width:720px){
  .bbvcp-auth .bbvcp-brand__brush img{
    width:min(100%, 290px);
    max-width:290px;
  }
  .bbvcp-dashboard-bar__brand .bbvcp-brand.is-compact .bbvcp-brand__brush img{
    max-width:148px;
  }
}


/* v2.5.1.6 auth background and transition polish */
.bbvcp-auth{
  position:relative;
  overflow:hidden;
  isolation:isolate;
  background:
    radial-gradient(circle at 14% 18%, rgba(171,122,255,.26), transparent 0 20%),
    radial-gradient(circle at 82% 16%, rgba(255,255,255,.9), transparent 0 14%),
    radial-gradient(circle at 86% 76%, rgba(122,77,255,.16), transparent 0 18%),
    linear-gradient(180deg,#faf7ff 0%,#f2e9ff 100%);
}
.bbvcp-auth::before,
.bbvcp-auth::after{
  content:"";
  position:absolute;
  inset:auto;
  pointer-events:none;
  z-index:0;
}
.bbvcp-auth::before{
  width:280px;
  height:280px;
  left:-70px;
  top:6%;
  border-radius:36% 64% 58% 42% / 42% 42% 58% 58%;
  background:
    radial-gradient(circle at 35% 35%, rgba(255,255,255,.78), rgba(255,255,255,0) 44%),
    linear-gradient(135deg, rgba(122,77,255,.22), rgba(188,160,255,.08));
  box-shadow:
    0 0 0 1px rgba(255,255,255,.32) inset,
    0 24px 80px rgba(122,77,255,.16);
  transform:rotate(-18deg);
  filter:blur(1px);
}
.bbvcp-auth::after{
  width:240px;
  height:240px;
  right:-80px;
  bottom:8%;
  border-radius:32px;
  background:
    repeating-radial-gradient(circle at center, rgba(255,255,255,.85) 0 2px, transparent 2px 13px),
    linear-gradient(135deg, rgba(255,255,255,.14), rgba(122,77,255,.12));
  opacity:.55;
  transform:rotate(14deg);
  filter:blur(.2px);
}
.bbvcp-auth__card{
  position:relative;
  z-index:1;
}
.bbvcp-auth__card--minimal{
  background:
    linear-gradient(180deg, rgba(255,255,255,.96), rgba(255,255,255,.92)),
    linear-gradient(180deg,#fff,#faf6ff);
}
.bbvcp-auth__card--minimal::before{
  content:"";
  position:absolute;
  inset:10px;
  border-radius:22px;
  border:1px solid rgba(122,77,255,.08);
  pointer-events:none;
}
.bbvcp-auth__card--minimal .bbvcp-brand{
  justify-content:center;
}
.bbvcp-auth__card--minimal .bbvcp-brand__brush{
  height:58px;
}
.bbvcp-auth__card--minimal .bbvcp-brand__brush img{
  height:58px;
  width:auto;
  max-width:min(100%, 240px);
}
.bbvcp-dashboard-bar .bbvcp-brand__brush{
  height:40px;
}
.bbvcp-dashboard-bar .bbvcp-brand__brush img{
  height:40px;
  width:auto;
  max-width:220px;
}
.bbvcp-app--dashboard-reveal{
  animation:bbvcpDashboardReveal .95s cubic-bezier(.22,.9,.25,1) both;
}
.bbvcp-app--dashboard-reveal .bbvcp-shell{
  animation:bbvcpDashboardRevealShell .95s cubic-bezier(.22,.9,.25,1) both;
}
@keyframes bbvcpDashboardReveal{
  0%{
    opacity:.08;
    filter:blur(18px) saturate(1.08);
    transform:scale(1.02);
  }
  55%{
    opacity:1;
    filter:blur(10px) saturate(1.04);
    transform:scale(1.008);
  }
  100%{
    opacity:1;
    filter:blur(0) saturate(1);
    transform:none;
  }
}
@keyframes bbvcpDashboardRevealShell{
  0%{
    transform:translateY(14px) scale(.988);
  }
  100%{
    transform:none;
  }
}

.bbvcp-code-wrap:focus-within .bbvcp-code-slot{
  border-color:rgba(122,77,255,.42);
  box-shadow:0 0 0 3px rgba(122,77,255,.10);
}
.bbvcp-code-slot.has-value{
  color:var(--bbvcp-text);
}


/* v2.5.1.7 auth motion background and larger login logo */
.bbvcp-auth{
  background-size:140% 140%, 118% 118%, 132% 132%, 100% 100%;
  animation:bbvcpAuthGradientFlow 18s ease-in-out infinite alternate;
}
.bbvcp-auth::before{
  animation:bbvcpAuthBlobFloatA 20s ease-in-out infinite alternate;
  will-change:transform, border-radius, filter;
}
.bbvcp-auth::after{
  animation:bbvcpAuthBlobFloatB 24s ease-in-out infinite alternate;
  will-change:transform, opacity, border-radius;
}
.bbvcp-auth__card{
  overflow:hidden;
}
.bbvcp-auth__card::after{
  content:"";
  position:absolute;
  inset:auto -12% -24% auto;
  width:180px;
  height:180px;
  border-radius:50%;
  background:
    radial-gradient(circle at 30% 30%, rgba(255,255,255,.8) 0 10%, rgba(255,255,255,0) 42%),
    radial-gradient(circle at 55% 55%, rgba(122,77,255,.12) 0 24%, rgba(122,77,255,0) 62%);
  opacity:.55;
  pointer-events:none;
  filter:blur(2px);
  animation:bbvcpAuthOrbFloat 16s ease-in-out infinite alternate;
}
.bbvcp-auth__card--minimal .bbvcp-brand{
  margin-bottom:4px;
}
.bbvcp-auth__card--minimal .bbvcp-brand__brush{
  min-height:78px !important;
  height:auto !important;
  display:flex;
  align-items:center;
  justify-content:center;
}
.bbvcp-auth__card--minimal .bbvcp-brand__brush img{
  display:block;
  width:min(100%, 292px) !important;
  max-width:292px !important;
  height:auto !important;
  max-height:none !important;
}
@media (max-width:720px){
  .bbvcp-auth__card--minimal .bbvcp-brand__brush{
    min-height:74px !important;
  }
  .bbvcp-auth__card--minimal .bbvcp-brand__brush img{
    width:min(100%, 276px) !important;
    max-width:276px !important;
  }
}
@media (max-width:480px){
  .bbvcp-auth__card--minimal .bbvcp-brand__brush{
    min-height:68px !important;
  }
  .bbvcp-auth__card--minimal .bbvcp-brand__brush img{
    width:min(100%, 252px) !important;
    max-width:252px !important;
  }
}
@keyframes bbvcpAuthGradientFlow{
  0%{background-position:0% 8%, 100% 0%, 82% 100%, 0 0}
  50%{background-position:12% 0%, 88% 10%, 100% 88%, 0 0}
  100%{background-position:0% 14%, 100% 2%, 78% 100%, 0 0}
}
@keyframes bbvcpAuthBlobFloatA{
  0%{
    transform:translate3d(0,0,0) rotate(-18deg) scale(1);
    border-radius:36% 64% 58% 42% / 42% 42% 58% 58%;
    filter:blur(1px);
  }
  50%{
    transform:translate3d(18px,-10px,0) rotate(-8deg) scale(1.06);
    border-radius:44% 56% 52% 48% / 50% 40% 60% 50%;
    filter:blur(1.5px);
  }
  100%{
    transform:translate3d(-8px,16px,0) rotate(-24deg) scale(.98);
    border-radius:52% 48% 60% 40% / 38% 54% 46% 62%;
    filter:blur(1px);
  }
}
@keyframes bbvcpAuthBlobFloatB{
  0%{
    transform:rotate(14deg) translate3d(0,0,0) scale(1);
    opacity:.5;
    border-radius:32px;
  }
  50%{
    transform:rotate(7deg) translate3d(-10px,-18px,0) scale(1.05);
    opacity:.64;
    border-radius:42px;
  }
  100%{
    transform:rotate(18deg) translate3d(8px,14px,0) scale(.98);
    opacity:.56;
    border-radius:28px;
  }
}
@keyframes bbvcpAuthOrbFloat{
  0%{transform:translate3d(0,0,0) scale(1); opacity:.42}
  50%{transform:translate3d(-18px,-8px,0) scale(1.08); opacity:.6}
  100%{transform:translate3d(8px,14px,0) scale(.96); opacity:.48}
}


/* v2.5.1.8 logout/auth transition */
.bbvcp-app--logout-exit{
  animation:bbvcpLogoutExit .62s cubic-bezier(.22,.9,.25,1) both;
}
.bbvcp-app--logout-exit .bbvcp-shell{
  animation:bbvcpLogoutExitShell .62s cubic-bezier(.22,.9,.25,1) both;
}
.bbvcp-auth--reveal{
  animation:bbvcpAuthReveal .92s cubic-bezier(.22,.9,.25,1) both;
}
.bbvcp-auth--reveal .bbvcp-auth__card{
  animation:bbvcpAuthRevealCard .92s cubic-bezier(.22,.9,.25,1) both;
}
@keyframes bbvcpLogoutExit{
  0%{
    opacity:1;
    filter:blur(0) saturate(1);
    transform:none;
  }
  100%{
    opacity:.18;
    filter:blur(18px) saturate(1.06);
    transform:scale(1.018);
  }
}
@keyframes bbvcpLogoutExitShell{
  0%{transform:none}
  100%{transform:translateY(10px) scale(.992)}
}
@keyframes bbvcpAuthReveal{
  0%{
    opacity:.12;
    filter:blur(18px) saturate(1.08);
    transform:scale(1.018);
  }
  58%{
    opacity:1;
    filter:blur(10px) saturate(1.04);
    transform:scale(1.006);
  }
  100%{
    opacity:1;
    filter:blur(0) saturate(1);
    transform:none;
  }
}
@keyframes bbvcpAuthRevealCard{
  0%{transform:translateY(12px) scale(.988); filter:blur(8px)}
  100%{transform:none; filter:blur(0)}
}


/* v2.5.1.9 dashboard scene background */
.bbvcp-app--dashboard-scene{
  position:relative;
  overflow:hidden;
  background:
    radial-gradient(42% 36% at 14% 10%, rgba(203,174,255,.24) 0%, rgba(203,174,255,0) 68%),
    radial-gradient(34% 30% at 86% 16%, rgba(151,110,255,.16) 0%, rgba(151,110,255,0) 72%),
    radial-gradient(44% 38% at 88% 16%, rgba(233,205,255,.85) 0%, rgba(233,205,255,0) 76%),
    radial-gradient(52% 44% at 50% 100%, rgba(175,128,255,.18) 0%, rgba(175,128,255,0) 72%),
    linear-gradient(180deg,#fbf8ff 0%,#efe7ff 56%,#f7f2ff 100%);
  background-size:140% 140%, 118% 118%, 132% 132%, 126% 126%, 100% 100%;
  animation:bbvcpAuthGradientFlow 18s ease-in-out infinite alternate;
}
.bbvcp-app--dashboard-scene::before,
.bbvcp-app--dashboard-scene::after{
  content:"";
  position:absolute;
  inset:auto;
  pointer-events:none;
  z-index:0;
}
.bbvcp-app--dashboard-scene::before{
  width:min(72vw,520px);
  height:min(72vw,520px);
  top:-14%;
  right:-12%;
  border-radius:50%;
  background:
    radial-gradient(circle at 35% 35%, rgba(255,255,255,.9) 0%, rgba(255,255,255,.38) 20%, rgba(255,255,255,0) 58%),
    radial-gradient(circle at 60% 60%, rgba(165,120,255,.22) 0%, rgba(165,120,255,.08) 28%, rgba(165,120,255,0) 60%);
  filter:blur(10px);
  animation:bbvcpAuthBlobFloatA 20s ease-in-out infinite alternate;
  will-change:transform, border-radius, filter;
}
.bbvcp-app--dashboard-scene::after{
  left:-18%;
  bottom:-12%;
  width:min(78vw,560px);
  height:min(78vw,560px);
  border-radius:50%;
  background:
    radial-gradient(circle at 58% 42%, rgba(255,255,255,.82) 0%, rgba(255,255,255,.25) 18%, rgba(255,255,255,0) 52%),
    conic-gradient(from 220deg, rgba(122,77,255,.08), rgba(255,255,255,0) 28%, rgba(122,77,255,.14) 62%, rgba(255,255,255,0) 88%, rgba(122,77,255,.08));
  filter:blur(14px);
  opacity:.9;
  animation:bbvcpAuthBlobFloatB 24s ease-in-out infinite alternate;
  will-change:transform, opacity, border-radius;
}
.bbvcp-app--dashboard-scene .bbvcp-shell{
  position:relative;
  z-index:1;
}


/* v2.5.1.11 dashboard animated shapes parity with login */
.bbvcp-app--dashboard-scene{
  isolation:isolate;
}
.bbvcp-scene-shapes{
  position:absolute;
  inset:0;
  overflow:hidden;
  pointer-events:none;
  z-index:0;
}
.bbvcp-scene-shape{
  position:absolute;
  display:block;
  border-radius:50%;
  filter:blur(10px);
  opacity:.92;
  will-change:transform, border-radius, opacity, filter;
}
.bbvcp-scene-shape--a{
  top:-14%;
  right:-12%;
  width:min(72vw,520px);
  height:min(72vw,520px);
  background:
    radial-gradient(circle at 35% 35%, rgba(255,255,255,.9) 0%, rgba(255,255,255,.38) 20%, rgba(255,255,255,0) 58%),
    radial-gradient(circle at 60% 60%, rgba(165,120,255,.22) 0%, rgba(165,120,255,.08) 28%, rgba(165,120,255,0) 60%);
  animation:bbvcpAuthBlobFloatA 20s ease-in-out infinite alternate;
}
.bbvcp-scene-shape--b{
  left:-18%;
  bottom:-12%;
  width:min(78vw,560px);
  height:min(78vw,560px);
  background:
    radial-gradient(circle at 58% 42%, rgba(255,255,255,.82) 0%, rgba(255,255,255,.25) 18%, rgba(255,255,255,0) 52%),
    conic-gradient(from 220deg, rgba(122,77,255,.08), rgba(255,255,255,0) 28%, rgba(122,77,255,.14) 62%, rgba(255,255,255,0) 88%, rgba(122,77,255,.08));
  filter:blur(14px);
  animation:bbvcpAuthBlobFloatB 24s ease-in-out infinite alternate;
}
.bbvcp-scene-shape--c{
  right:4%;
  bottom:8%;
  width:220px;
  height:220px;
  background:
    radial-gradient(circle at 30% 30%, rgba(255,255,255,.8) 0 10%, rgba(255,255,255,0) 42%),
    radial-gradient(circle at 55% 55%, rgba(122,77,255,.12) 0 24%, rgba(122,77,255,0) 62%);
  filter:blur(2px);
  opacity:.58;
  animation:bbvcpAuthOrbFloat 16s ease-in-out infinite alternate;
}
.bbvcp-app--dashboard-scene .bbvcp-shell{
  position:relative;
  z-index:1;
}


/* v2.5.1.12 dashboard refresh */
.bbvcp-app--dashboard-elegant{
  min-height:100vh;
  background:#f6f2fb;
}
.bbvcp-shell--dashboard-elegant{
  width:min(100%,640px);
  padding:calc(28px + env(safe-area-inset-top)) 16px calc(110px + var(--bbvcp-safe-bottom));
}
.bbvcp-header--dashboard-elegant{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:14px;
  margin-bottom:14px;
}
.bbvcp-header__intro--elegant{
  gap:6px;
}
.bbvcp-header__intro--elegant h1{
  margin:0 0 6px;
  font-size:clamp(1.85rem,7vw,2.35rem);
  font-weight:850;
  letter-spacing:-.03em;
  line-height:.98;
}
.bbvcp-header__intro--elegant p{
  margin:0;
  color:#8777ac;
}
.bbvcp-profile-button{
  position:relative;
  flex:0 0 auto;
  width:56px;
  height:56px;
  padding:0;
  border:0;
  border-radius:20px;
  background:rgba(255,255,255,.9);
  box-shadow:0 14px 34px rgba(98,61,176,.12);
  display:grid;
  place-items:center;
}
.bbvcp-avatar{
  width:42px;
  height:42px;
  border-radius:16px;
  display:grid;
  place-items:center;
  color:#fff;
  font-weight:800;
  font-size:1.1rem;
  overflow:hidden;
  box-shadow:0 10px 22px rgba(122,77,255,.18);
}
.bbvcp-avatar img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.bbvcp-avatar--button{
  width:42px;
  height:42px;
}
.bbvcp-avatar--large{
  width:68px;
  height:68px;
  border-radius:22px;
  font-size:1.4rem;
}
.bbvcp-avatar--spark{background:linear-gradient(135deg,#7a4dff,#b28eff);}
.bbvcp-avatar--halo{background:linear-gradient(135deg,#8b58ff,#ff9fd1);}
.bbvcp-avatar--iris{background:linear-gradient(135deg,#6b4de5,#9fd2ff);}
.bbvcp-avatar--wave{background:linear-gradient(135deg,#5737cf,#7ec8ff);}
.bbvcp-avatar--nova{background:linear-gradient(135deg,#7a4dff,#ff8f6b);}
.bbvcp-avatar--lilac{background:linear-gradient(135deg,#a15cff,#d7b5ff);}
.bbvcp-notice-dot{
  position:absolute;
  top:6px;
  right:6px;
  width:10px;
  height:10px;
  border-radius:999px;
  background:#ff5b82;
  border:2px solid #fff;
  box-shadow:0 0 0 4px rgba(255,91,130,.12);
}
.bbvcp-dashboard-message{
  margin-bottom:16px;
}
.bbvcp-dashboard-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:14px;
  align-items:stretch;
}
.bbvcp-library-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:14px;
  margin-top:14px;
}
.bbvcp-create-tile--elegant,
.bbvcp-library-card{
  position:relative;
  min-height:222px;
  border-radius:28px;
  overflow:hidden;
  border:1px solid #ece3ff;
  background:rgba(255,255,255,.9);
  box-shadow:0 18px 36px rgba(88,56,168,.08);
}
.bbvcp-create-tile--elegant{
  padding:22px 18px;
  place-items:center;
}
.bbvcp-library-card{
  cursor:pointer;
}
.bbvcp-create-tile--elegant strong{
  display:block;
  margin-top:12px;
  color:#6140d9;
}
.bbvcp-create-tile--elegant .bbvcp-muted{
  margin-top:4px;
}
.bbvcp-library-card__topline{
  position:absolute;
  top:12px;
  right:12px;
  z-index:3;
}
.bbvcp-library-card .bbvcp-card-tile__badge{
  position:static;
  min-height:28px;
  padding:0 12px;
  border-radius:999px;
  background:rgba(255,255,255,.92);
  border:1px solid #e8ddff;
  color:#6f49ea;
}
.bbvcp-library-card .bbvcp-card-tile__toggle{
  width:28px;
  height:28px;
  border-radius:999px;
  border:2px solid #d7c3ff;
  background:rgba(255,255,255,.96);
}
.bbvcp-library-card--placeholder{
  display:grid;
  place-items:center;
  padding:18px;
}
.bbvcp-library-card__empty{
  text-align:center;
  color:#8d7bab;
  display:grid;
  gap:6px;
}
.bbvcp-card-mini{
  min-height:100%;
  height:100%;
  padding:0;
  border:0;
  border-radius:0;
  background:transparent;
}
.bbvcp-card-mini__stage{
  min-height:222px;
  height:100%;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:20px;
  background:
    radial-gradient(circle at top left,rgba(122,77,255,.18),transparent 36%),
    linear-gradient(180deg,#ffffff 0%,#f2eaff 100%);
}
.bbvcp-card-mini .bbvcp-card-shell--mini{
  width:min(100%,150px);
}
.bbvcp-card-mini .bbvcp-card-editor{
  width:100%;
  box-shadow:0 18px 42px rgba(96,64,174,.16);
}
.bbvcp-powered-by{
  margin-top:18px;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  color:#998ab7;
  font-size:.8rem;
}
.bbvcp-powered-by img{
  height:18px;
  width:auto;
  opacity:.86;
}
.bbvcp-sheet--profile .bbvcp-sheet__menu-list{
  display:grid;
  gap:10px;
}
.bbvcp-profile-card{
  display:flex;
  align-items:center;
  gap:14px;
  padding:14px 0 18px;
}
.bbvcp-profile-card__meta{
  display:flex;
  flex-direction:column;
  gap:6px;
}
.bbvcp-sheet__menu-row{
  width:100%;
  text-align:left;
  padding:15px 16px;
  border-radius:20px;
  border:1px solid var(--bbvcp-line);
  background:#faf7ff;
  color:var(--bbvcp-text);
  display:grid;
  gap:4px;
}
.bbvcp-sheet__menu-row span{
  font-weight:800;
}
.bbvcp-sheet__menu-row em{
  color:#8777ac;
  font-style:normal;
  font-size:.88rem;
}
.bbvcp-sheet__menu-row--danger span{color:#c64a6f;}
.bbvcp-sheet__menu-row--reward{
  background:linear-gradient(180deg,#fff8ff,#f5edff);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.8);
}
.bbvcp-sheet__menu-row--new{
  border-color:#ccb6ff;
}
.bbvcp-avatar-picker{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:12px;
}
.bbvcp-avatar-choice{
  padding:10px;
  border-radius:18px;
  border:1px solid var(--bbvcp-line);
  background:#fbf8ff;
  display:grid;
  place-items:center;
}
.bbvcp-avatar-choice.is-active{
  border-color:#7a4dff;
  box-shadow:0 0 0 3px rgba(122,77,255,.12);
}
.bbvcp-contact-actions{
  margin-top:16px;
}
.bbvcp-preview-actions{
  position:absolute;
  left:14px;
  right:14px;
  bottom:calc(14px + var(--bbvcp-safe-bottom));
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:10px;
  z-index:5;
}
.bbvcp-preview-action{
  min-height:54px;
  border-radius:18px;
  border:1px solid rgba(255,255,255,.25);
  background:rgba(19,10,39,.55);
  color:#fff;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  backdrop-filter:blur(16px);
}
.bbvcp-preview-action svg{width:20px;height:20px}
.bbvcp-preview-action--danger{
  background:rgba(180,49,91,.75);
}
.bbvcp-sheet__close--badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:74px;
  padding:0 14px;
  color:#fff;
  font-weight:800;
}
@media (max-width:720px){
  .bbvcp-shell--dashboard-elegant{
    padding:18px 16px calc(110px + var(--bbvcp-safe-bottom));
  }
}


/* Dashboard hotfix: restore centered card thumbnails and add proper top breathing room */
.bbvcp-shell--dashboard-elegant{
  padding:calc(48px + env(safe-area-inset-top)) 16px calc(110px + var(--bbvcp-safe-bottom));
}
.bbvcp-header--dashboard-elegant{
  margin-bottom:22px;
}
.bbvcp-header__intro--elegant h1{
  margin:0 0 10px;
  line-height:1.02;
}
.bbvcp-dashboard-grid,
.bbvcp-library-grid{
  align-items:start;
}
.bbvcp-create-tile--elegant,
.bbvcp-library-card{
  min-height:196px;
}
.bbvcp-card-mini__stage{
  min-height:196px;
  padding:12px;
}
.bbvcp-card-mini .bbvcp-card-shell--mini{
  width:min(100%,104px) !important;
  max-width:104px !important;
  transform:none !important;
}
.bbvcp-card-mini .bbvcp-card-editor{
  width:100%;
  max-width:none;
}
@media (max-width:720px){
  .bbvcp-shell--dashboard-elegant{
    padding:calc(42px + env(safe-area-inset-top)) 16px calc(110px + var(--bbvcp-safe-bottom));
  }
  .bbvcp-header--dashboard-elegant{
    margin-bottom:18px;
  }
}


/* v2.5.1.15 dashboard thumbnail lock */
.bbvcp-shell--dashboard-elegant{
  padding-top:calc(40px + env(safe-area-inset-top)) !important;
}
.bbvcp-header--dashboard-elegant{
  margin-bottom:20px !important;
}
.bbvcp-header__intro--elegant{
  padding-top:6px;
}
.bbvcp-card-mini{
  min-height:100% !important;
  height:100% !important;
  padding:0 !important;
  border:0 !important;
  border-radius:0 !important;
  background:transparent !important;
}
.bbvcp-card-mini__stage{
  min-height:222px !important;
  height:100% !important;
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  padding:16px !important;
  background:
    radial-gradient(circle at top left,rgba(122,77,255,.18),transparent 36%),
    linear-gradient(180deg,#ffffff 0%,#f2eaff 100%) !important;
}
.bbvcp-card-mini .bbvcp-card-shell--mini{
  width:min(100%,104px) !important;
  max-width:104px !important;
}
.bbvcp-card-mini .bbvcp-card-editor{
  width:100% !important;
  max-width:104px !important;
  margin:0 auto !important;
  box-shadow:0 14px 34px rgba(94,65,172,.16) !important;
}
.bbvcp-card-mini .bbvcp-card-editor__surface::after{
  inset:8px !important;
  border-radius:12px !important;
}


/* v2.5.1.16 dashboard thumbnail hotfix */
.bbvcp-library-card .bbvcp-card-mini{
  min-height:100% !important;
  height:100% !important;
  padding:0 !important;
  display:block !important;
  background:transparent !important;
}
.bbvcp-library-card .bbvcp-card-mini__stage{
  min-height:100% !important;
  height:100% !important;
  padding:14px 12px 12px !important;
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  overflow:hidden !important;
}
.bbvcp-library-card .bbvcp-card-shell--mini{
  width:100px !important;
  max-width:100px !important;
  flex:0 0 100px !important;
  transform:none !important;
}
.bbvcp-library-card .bbvcp-card-editor{
  width:100px !important;
  max-width:100px !important;
  aspect-ratio:4 / 7 !important;
  margin:0 auto !important;
  box-shadow:0 16px 36px rgba(94,65,172,.14) !important;
}
.bbvcp-library-card .bbvcp-card-editor__surface::after{
  inset:8px !important;
  border-radius:12px !important;
}
.bbvcp-library-card .bbvcp-editor-el,
.bbvcp-library-card .bbvcp-el{
  font-size:calc(var(--bbvcp-font-scale, 6) * .92px) !important;
  line-height:1.08 !important;
}


/* v2.5.1.20 dashboard QR quick access */
.bbvcp-app--dashboard-elegant{
  position:relative;
}
.bbvcp-shell--dashboard-elegant{
  padding-bottom:calc(132px + var(--bbvcp-safe-bottom));
}
.bbvcp-fab-qr{
  position:fixed;
  right:calc(24px + env(safe-area-inset-right, 0px));
  bottom:calc(18px + var(--bbvcp-safe-bottom));
  z-index:60;
  min-width:68px;
  min-height:68px;
  padding:10px 14px;
  border:0;
  border-radius:24px;
  background:linear-gradient(135deg,#7a4dff 0%,#9466ff 58%,#b28eff 100%);
  color:#fff;
  box-shadow:0 20px 42px rgba(122,77,255,.28), 0 0 0 8px rgba(122,77,255,.10);
  display:grid;
  justify-items:center;
  align-content:center;
  gap:4px;
}
.bbvcp-fab-qr__icon{
  width:24px;
  height:24px;
  display:flex;
  align-items:center;
  justify-content:center;
}
.bbvcp-fab-qr__label{
  font-size:.72rem;
  font-weight:800;
  letter-spacing:.03em;
}
.bbvcp-sheet--qr{
  max-width:min(94vw,460px);
  border-radius:30px;
}
.bbvcp-sheet--qr .bbvcp-sheet__head{
  align-items:flex-start;
}
.bbvcp-sheet--qr .bbvcp-sheet__head h2{
  margin:0 0 4px;
}
.bbvcp-sheet--qr-quick .bbvcp-qr{
  gap:18px;
}
.bbvcp-sheet--qr-settings{
  max-width:min(96vw,780px);
}
.bbvcp-qr--quick{
  justify-items:center;
}
.bbvcp-qr-preview{
  width:100%;
}
.bbvcp-qr-preview--live{
  padding:18px;
  border-radius:28px;
  background:
    radial-gradient(circle at top left,rgba(122,77,255,.14),transparent 40%),
    linear-gradient(180deg,var(--bbvcp-qr-light),#f7f1ff);
}
.bbvcp-qr-live{
  width:min(100%,320px);
  margin:0 auto;
}
.bbvcp-qr-live svg,
.bbvcp-qr-preview > img{
  width:100%;
  height:auto;
  display:block;
  border-radius:24px;
  background:var(--bbvcp-qr-light);
}
.bbvcp-qr-preview--dots .bbvcp-qr-live svg{
  border-radius:30px;
}
.bbvcp-qr-preview--halo{
  box-shadow:0 0 0 1px rgba(122,77,255,.10),0 0 0 12px rgba(122,77,255,.06),0 18px 44px rgba(122,77,255,.18);
}
.bbvcp-qr-preview--frame .bbvcp-qr-live svg{
  box-shadow:inset 0 0 0 10px rgba(122,77,255,.08);
}
.bbvcp-link-button{
  min-height:48px;
  padding:0 18px;
  border-radius:999px;
  border:1px solid #ddd0ff;
  background:#fff;
  color:#6341db;
  font-weight:800;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
}
.bbvcp-link-button svg{
  width:18px;
  height:18px;
}
.bbvcp-qr-style-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:10px;
}
.bbvcp-qr-style-chip{
  padding:12px 12px 10px;
  border-radius:20px;
  border:1px solid var(--bbvcp-line);
  background:#fff;
  color:var(--bbvcp-text);
  display:grid;
  gap:10px;
  justify-items:center;
  text-align:center;
}
.bbvcp-qr-style-chip.is-active{
  border-color:#b595ff;
  background:#f6f1ff;
  box-shadow:0 14px 28px rgba(122,77,255,.08);
}
.bbvcp-qr-style-chip strong{
  font-size:.86rem;
  line-height:1.15;
}
.bbvcp-qr-style-chip__preview{
  width:58px;
  height:58px;
  border-radius:18px;
  border:1px solid #e6dcff;
  background:
    radial-gradient(circle at top left,rgba(122,77,255,.10),transparent 40%),
    linear-gradient(180deg,#fff,#f7f1ff);
  display:grid;
  place-items:center;
}
.bbvcp-qr-style-chip__preview span{
  width:30px;
  height:30px;
  background:#7a4dff;
}
.bbvcp-qr-style-chip__preview--rounded span{
  border-radius:8px;
}
.bbvcp-qr-style-chip__preview--dots span{
  width:28px;
  height:28px;
  border-radius:50%;
}
.bbvcp-qr-style-chip__preview--soft span{
  border-radius:12px;
}
.bbvcp-qr-style-chip__preview--frame span{
  background:transparent;
  border:4px solid #7a4dff;
  border-radius:10px;
}
.bbvcp-qr-style-chip__preview--halo span{
  border-radius:12px;
  box-shadow:0 0 0 6px rgba(122,77,255,.14);
}
.bbvcp-icon-button--soft{
  width:42px;
  height:42px;
  border-radius:16px;
  border:1px solid var(--bbvcp-line);
  background:#fff;
  color:#6a48e2;
  box-shadow:0 10px 24px rgba(122,77,255,.10);
}
@media (max-width:720px){
  .bbvcp-fab-qr{
    right:calc(24px + env(safe-area-inset-right, 0px));
    bottom:calc(14px + var(--bbvcp-safe-bottom));
  }
  .bbvcp-qr-style-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
}


.bbvcp-sheet__head--qr-compact{
  align-items:center;
  justify-content:space-between;
  margin-bottom:10px;
}
.bbvcp-sheet__head--qr-compact .bbvcp-sheet__spacer{
  width:36px;
  height:36px;
}
.bbvcp-chip--icon{
  display:inline-grid;
  place-items:center;
  gap:0;
  padding:0;
}
.bbvcp-chip--compact{
  width:38px;
  height:38px;
  border-radius:14px;
}
.bbvcp-chip--compact svg{
  width:16px;
  height:16px;
}


/* v2.5.1.22 profile and contact-card polish */
.bbvcp-sheet--profile{
  max-width:440px;
}
.bbvcp-profile-card{
  padding:6px 0 18px;
  justify-content:space-between;
}
.bbvcp-profile-card__meta{
  flex:1;
  min-width:0;
}
.bbvcp-plan-link{
  margin-top:2px;
  align-self:flex-start;
  display:inline-flex;
  align-items:flex-end;
  gap:8px;
  padding:0;
  background:transparent;
  border:0;
  color:inherit;
}
.bbvcp-plan-link em{
  font-style:normal;
  font-size:.78rem;
  color:#7f6aa7;
  text-decoration:underline;
  text-underline-offset:3px;
}
.bbvcp-sheet__menu-row{
  display:grid;
  grid-template-columns:auto 1fr auto;
  align-items:center;
  gap:12px;
  min-height:72px;
}
.bbvcp-sheet__menu-avatar{
  display:grid;
  place-items:center;
}
.bbvcp-sheet__menu-avatar .bbvcp-avatar--menu{
  width:52px;
  height:52px;
  border-radius:18px;
  font-size:1.1rem;
}
.bbvcp-sheet__menu-copy{
  display:flex;
  flex-direction:column;
  min-width:0;
  gap:4px;
  text-align:left;
}
.bbvcp-sheet__menu-copy strong{
  font-size:.98rem;
  line-height:1.1;
}
.bbvcp-sheet__menu-copy em{
  margin:0;
  line-height:1.24;
}
.bbvcp-sheet__menu-trailing{
  display:grid;
  place-items:center;
  color:#8d78b7;
}
.bbvcp-sheet__menu-trailing svg{
  width:18px;
  height:18px;
}
.bbvcp-sheet__menu-row--contact{
  background:linear-gradient(180deg,#ffffff 0%,#f8f2ff 100%);
  box-shadow:0 14px 28px rgba(122,77,255,.08);
}
.bbvcp-sheet__menu-row--contact:hover{
  border-color:#d8c8ff;
}
.bbvcp-sheet--profile .bbvcp-sheet__menu-row:not(.bbvcp-sheet__menu-row--contact){
  grid-template-columns:1fr;
  gap:4px;
}
.bbvcp-sheet--profile .bbvcp-sheet__menu-row:not(.bbvcp-sheet__menu-row--contact) span,
.bbvcp-sheet--profile .bbvcp-sheet__menu-row:not(.bbvcp-sheet__menu-row--contact) em{
  display:block;
}
.bbvcp-sheet--contact{
  max-width:560px;
}
.bbvcp-sheet__head--contact{
  padding-bottom:10px;
}
.bbvcp-sheet__head--contact .bbvcp-inline{
  display:flex;
  align-items:flex-start;
  gap:12px;
}
.bbvcp-contact-hero{
  display:flex;
  align-items:center;
  gap:16px;
  padding:14px 16px;
  border-radius:24px;
  background:linear-gradient(135deg,#ffffff 0%,#f7f1ff 60%,#efe5ff 100%);
  border:1px solid #e6dbff;
  box-shadow:0 18px 34px rgba(122,77,255,.08);
  margin-bottom:14px;
}
.bbvcp-contact-hero__media{
  display:grid;
  gap:8px;
  justify-items:center;
  flex:0 0 auto;
}
.bbvcp-contact-hero__avatar .bbvcp-avatar--contact{
  width:64px;
  height:64px;
  border-radius:22px;
  font-size:1.35rem;
}
.bbvcp-contact-hero__avatar-actions{
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  gap:8px;
}
.bbvcp-contact-photo-button{
  min-height:38px;
  padding:0 14px;
  border-radius:999px;
  border:1px solid #ddd0ff;
  background:#fff;
  color:#6440dc;
  font-weight:800;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
}
.bbvcp-contact-photo-button__icon{
  width:16px;
  height:16px;
  display:inline-grid;
  place-items:center;
}
.bbvcp-contact-photo-button__icon svg{
  width:16px;
  height:16px;
}
.bbvcp-contact-photo-button--ghost{
  background:#f6f0ff;
}
.bbvcp-contact-hero__meta{
  display:flex;
  flex-direction:column;
  gap:4px;
  min-width:0;
  flex:1 1 auto;
  align-self:center;
}
.bbvcp-contact-hero__meta strong,
.bbvcp-contact-hero__meta span{
  display:block;
  max-width:100%;
  overflow-wrap:anywhere;
}
.bbvcp-contact-hero__meta strong{
  font-size:1.08rem;
  line-height:1.1;
}
.bbvcp-contact-hero__meta span{
  color:#7f6ca4;
  line-height:1.24;
}
.bbvcp-field-label{
  display:flex;
  align-items:center;
  gap:10px;
  color:#5f4f89;
  font-size:.94rem;
  font-weight:800;
}
.bbvcp-field-label__icon{
  width:30px;
  height:30px;
  border-radius:12px;
  display:grid;
  place-items:center;
  color:#fff;
  background:linear-gradient(135deg,#7a4dff 0%,#9b78ff 100%);
  box-shadow:0 10px 22px rgba(122,77,255,.18);
  flex:0 0 auto;
}
.bbvcp-field-label__icon svg{
  width:16px;
  height:16px;
}
.bbvcp-field--social{
  margin:0;
}
.bbvcp-contact-card-editor{
  display:grid;
  gap:12px;
}
.bbvcp-contact-card-editor__group{
  border:1px solid #e7ddff;
  background:rgba(255,255,255,.88);
  border-radius:24px;
  padding:14px;
  box-shadow:0 12px 28px rgba(102,64,189,.06);
}
.bbvcp-contact-card-editor__group--hero{
  display:grid;
  gap:12px;
}
.bbvcp-contact-card-editor__title{
  font-size:.8rem;
  font-weight:900;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:#7d68aa;
  margin-bottom:12px;
}
.bbvcp-contact-card-editor__hint{
  margin:4px 0 0;
  color:#7d68aa;
  font-size:.86rem;
}
.bbvcp-link-builder{
  display:grid;
  grid-template-columns:auto 1fr;
  align-items:center;
  border:1px solid var(--bbvcp-line);
  border-radius:18px;
  background:#fff;
  overflow:hidden;
}
.bbvcp-link-builder__prefix{
  padding:0 12px;
  min-height:48px;
  display:grid;
  place-items:center;
  background:#f7f2ff;
  color:#705ba0;
  font-weight:700;
  border-right:1px solid #eadfff;
  white-space:nowrap;
}
.bbvcp-link-builder__prefix--brand{
  display:flex;
  align-items:center;
  gap:10px;
  justify-content:flex-start;
  padding:0 14px;
}
.bbvcp-link-builder__prefix-icon{
  width:30px;
  height:30px;
  border-radius:12px;
  background:linear-gradient(135deg,#7a4dff 0%,#8f63ff 100%);
  color:#fff;
  display:grid;
  place-items:center;
  box-shadow:0 10px 22px rgba(122,77,255,.16);
  flex:0 0 auto;
}
.bbvcp-link-builder__prefix-icon svg{
  width:16px;
  height:16px;
}
.bbvcp-link-builder__prefix-text{
  line-height:1.1;
}
.bbvcp-link-builder .bbvcp-input{
  margin:0;
  border:0;
  border-radius:0;
  box-shadow:none;
}
@media (max-width:720px){
  .bbvcp-sheet--contact{
    max-width:none;
  }
  .bbvcp-contact-hero{
    display:grid;
    grid-template-columns:1fr;
    padding:12px 14px;
    border-radius:22px;
    align-items:flex-start;
  }
  .bbvcp-contact-hero__media{
    width:auto;
    justify-items:flex-start;
  }
  .bbvcp-contact-hero__meta{
    width:100%;
    align-self:flex-start;
  }
  .bbvcp-contact-hero__avatar .bbvcp-avatar--contact{
    width:58px;
    height:58px;
    border-radius:20px;
  }
  .bbvcp-contact-hero__avatar-actions{
    justify-content:flex-start;
  }
  .bbvcp-contact-card-editor .bbvcp-contact-grid{
    grid-template-columns:1fr;
  }
  .bbvcp-link-builder{
    grid-template-columns:1fr;
  }
  .bbvcp-link-builder__prefix{
    min-height:42px;
    justify-content:flex-start;
    border-right:0;
    border-bottom:1px solid #eadfff;
  }
}


.bbvcp-button.is-current,
.bbvcp-chip.is-current{
  opacity:1;
  cursor:default;
  background:linear-gradient(135deg,#7a4dff 0%,#8f63ff 65%,#a783ff 100%);
  color:#fff;
  border-color:transparent;
  box-shadow:0 12px 30px rgba(122,77,255,.18);
}
.bbvcp-plan.is-current{
  border-color:#ccb6ff;
  box-shadow:0 14px 30px rgba(122,77,255,.08);
}
.bbvcp-profile-card{
  justify-content:space-between;
  gap:12px;
}
.bbvcp-profile-card__avatar{
  flex:0 0 auto;
}
.bbvcp-profile-card__meta{
  flex:1 1 auto;
  min-width:0;
}
.bbvcp-profile-logout{
  width:42px;
  height:42px;
  border-radius:16px;
  border:1px solid #f3c2cf;
  background:#fff3f6;
  color:#c64a6f;
  display:grid;
  place-items:center;
  box-shadow:0 8px 18px rgba(198,74,111,.12);
  flex:0 0 auto;
}
.bbvcp-profile-logout svg{
  width:19px;
  height:19px;
}
