/* VS Class Booking — public (fully scoped) */
.vscb-wrap, .vscb-wrap * { box-sizing: border-box; }

.vscb-wrap{
  width:100%;
  margin: 18px 0;
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
}

.vscb-wrap .vscb-card{
  border: 1px solid rgba(20,40,80,.12);
  background: #ffffff;
  border-radius: 18px;
  padding: 18px;
  box-shadow: 0 10px 24px rgba(0,0,0,.06);
}

.vscb-wrap .vscb-title{
  margin: 0 0 6px 0;
  font-size: 20px;
  line-height: 1.2;
}

.vscb-wrap .vscb-desc{
  color: rgba(20,40,80,.75);
  font-size: 14px;
}

.vscb-wrap .vscb-alert{
  margin: 14px 0;
  padding: 12px 12px;
  border-radius: 12px;
  font-weight: 600;
  font-size: 14px;
}
.vscb-wrap .vscb-alert-ok{
  border:1px solid rgba(0,130,60,.22);
  background: rgba(0,130,60,.08);
}
.vscb-wrap .vscb-alert-err{
  border:1px solid rgba(190,25,25,.22);
  background: rgba(190,25,25,.08);
}

.vscb-wrap .vscb-form{ margin-top: 12px; }
.vscb-wrap .vscb-grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}
@media (max-width: 640px){
  .vscb-wrap .vscb-grid{ grid-template-columns: 1fr; }
}

.vscb-wrap .vscb-field span{
  display:block;
  font-size: 13px;
  color: rgba(20,40,80,.8);
  margin-bottom: 6px;
}
.vscb-wrap input,
.vscb-wrap select{
  width:100%;
  padding: 11px 12px;
  border-radius: 12px;
  border: 1px solid rgba(20,40,80,.18);
  outline: none;
  background: #fff;
}
.vscb-wrap input:focus,
.vscb-wrap select:focus{
  border-color: rgba(10,124,255,.45);
  box-shadow: 0 0 0 4px rgba(10,124,255,.12);
}

.vscb-wrap .vscb-btn{
  margin-top: 12px;
  padding: 11px 14px;
  border-radius: 999px;
  border: 0;
  cursor: pointer;
  font-weight: 800;
  background: #0a7cff;
  color: #fff;
}

.vscb-wrap .vscb-footnote{
  margin-top: 10px;
  font-size: 12px;
  color: rgba(20,40,80,.65);
}
