/* Shared StartLocal QR frame component.
   Source of truth: business-card.html */
.sl-qr-wrap{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:10px;
  margin-inline:auto;
  width:min(300px, 90vw);
}

.sl-qr-label{
  width:100%;
  text-align:center;
  font-size:12px;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.18em;
  color:#6b7280;
}

.sl-qr-frame{
  --qr-frame-bg:#ffffff;
  --qr-frame-ink:#0f172a;
  --qr-frame-line:rgba(15,23,42,.22);
  width:100%;
  max-width:300px;
  aspect-ratio:1 / 1;
  border-radius:18px;
  position:relative;
  overflow:hidden;
  background:var(--qr-frame-bg);
  border:1px solid rgba(15,23,42,.16);
  box-shadow:0 14px 30px rgba(2,6,23,.12);
  isolation:isolate;
  margin-inline:auto;
}

.sl-qr-frame-svg{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  pointer-events:none;
  z-index:0;
}

.sl-qr-frame-svg .qr-frame-outer,
.sl-qr-frame-svg .qr-frame-inner{
  fill:none;
  stroke:var(--qr-frame-line);
  vector-effect:non-scaling-stroke;
}

.sl-qr-frame-svg .qr-frame-outer{ stroke-width:1.7; }
.sl-qr-frame-svg .qr-frame-inner{ stroke-width:1; opacity:.65; }
.sl-qr-frame-svg .qr-frame-copy{
  fill:var(--qr-frame-ink);
  font:700 3.05px/1.05 "SFMono-Regular",Consolas,"Liberation Mono",Menlo,monospace;
  letter-spacing:.18px;
  text-transform:uppercase;
  opacity:.86;
}

.sl-qr-frame-top{
  position:absolute;
  left:18%;
  right:18%;
  top:14%;
  z-index:2;
  display:none;
  align-items:center;
  justify-content:center;
  gap:10px;
  min-height:38px;
  padding:9px 15px;
  border-radius:999px;
  background:rgba(255,255,255,.84);
  box-shadow:0 10px 26px rgba(17,17,17,.08), inset 0 0 0 1px rgba(17,17,17,.08);
  color:var(--qr-frame-ink);
  backdrop-filter:blur(10px);
}

.sl-qr-frame-name{
  min-width:0;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  font:900 15px/1.1 Inter,system-ui,sans-serif;
  letter-spacing:.02em;
}

.sl-qr-frame-code{
  flex:0 0 auto;
  max-width:46%;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  color:rgba(17,17,17,.56);
  font:800 12px/1.1 Inter,system-ui,sans-serif;
  letter-spacing:.12em;
}

.sl-qr-frame-inner{
  position:absolute;
  inset:12%;
  z-index:1;
  display:grid;
  place-items:center;
  padding:8px;
  border-radius:14px;
  background:#f8fafc;
  box-shadow:inset 0 0 0 1px rgba(15,23,42,.10);
}

.sl-qr-frame-qrwrap{
  width:100%;
  height:100%;
  display:grid;
  place-items:center;
  border-radius:11px;
  background:#fff;
  padding:8px;
  position:relative;
  box-shadow:inset 0 0 0 1px rgba(15,23,42,.12);
}

.sl-qr-frame-canvas,
.sl-qr-frame-img{
  width:100%;
  height:auto;
  aspect-ratio:1 / 1;
  display:block;
  border-radius:8px;
  background:#fff;
}

.sl-qr-frame-badge{ display:none; }
