.vtk-hostess-checkin {
  margin: 0 auto;
  width: 100%;
  max-width: 920px;
  padding: 1.25rem 0;
  color: var(--vtk-blue, #292562);
}

.vtk-hostess-card,
.vtk-hostess-scanner-card,
.vtk-hostess-result-card,
.vtk-hostess-manual-toggle-wrap {
  border: 1px solid rgba(50, 51, 77, 0.08);
  border-radius: 1rem;
  box-shadow: 0 1rem 2.5rem rgba(35, 31, 32, 0.08);
  background: #fff;
  padding: 0.75rem;
}

.vtk-hostess-card {
  text-align: center;
}

.vtk-hostess-card h2,
.vtk-hostess-header h1,
.vtk-hostess-result-card h3 {
  margin: 0 0 0.5rem;
  color: var(--vtk-blue, #292562);
  font-weight: 700;
}

.vtk-hostess-card p,
.vtk-hostess-header p,
.vtk-hostess-result-card p {
  margin: 0 0 1rem;
  color: var(--bs-gray-600, #6c757d);
}

.vtk-hostess-card-error {
  border-color: rgba(122, 23, 0, 0.18);
  background: rgba(122, 23, 0, 0.04);
}

.vtk-hostess-header {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  margin-bottom: 1rem;
  gap: 1rem;
}

.vtk-hostess-eyebrow {
  margin: 0 0 0.25rem !important;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--vtk-gold, #c3996b) !important;
  font-size: 0.78rem;
  font-weight: 800;
}

.vtk-hostess-scanner-card {
  margin-bottom: 1rem;
  padding: 0.75rem;
}

.vtk-hostess-video-wrap {
  position: relative;
  min-height: 420px;
  border-radius: 0.875rem;
  background:
    radial-gradient(circle at top, rgba(195, 153, 107, 0.22), transparent 34%),
    linear-gradient(135deg, #15162a, #292562);
  overflow: hidden;
  aspect-ratio: 3 / 4;
}

.vtk-hostess-video-wrap video {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.vtk-hostess-scan-frame {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: min(72vw, 310px);
  height: min(72vw, 310px);
  border: 2px solid rgba(255, 255, 255, 0.92);
  border-radius: 1rem;
  box-shadow: 0 0 0 999px rgba(0, 0, 0, 0.28), 0 0 2rem rgba(195, 153, 107, 0.35);
  pointer-events: none;
}

.vtk-hostess-scan-frame::before,
.vtk-hostess-scan-frame::after {
  position: absolute;
  right: 1rem;
  left: 1rem;
  height: 2px;
  background: linear-gradient(90deg, transparent, var(--vtk-gold, #c3996b), transparent);
  content: "";
}

.vtk-hostess-scan-frame::before {
  top: 1.15rem;
}

.vtk-hostess-scan-frame::after {
  bottom: 1.15rem;
}

.vtk-hostess-scan-status {
  position: absolute;
  right: 0.75rem;
  bottom: 0.75rem;
  left: 0.75rem;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.92);
  padding: 0.7rem 1rem;
  text-align: center;
  line-height: normal;
  color: var(--vtk-blue, #292562);
  font-size: 0.875rem;
  font-weight: 500;
  backdrop-filter: blur(10px);
}

.vtk-hostess-scan-status.is-active {
  background: rgba(195, 153, 107, 0.95);
  color: #fff;
}

.vtk-hostess-scan-status.is-success {
  background: rgba(141, 198, 63, 0.95);
  color: #fff;
}

.vtk-hostess-scan-status.is-error {
  background: rgba(122, 23, 0, 0.95);
  color: #fff;
}

.vtk-hostess-actions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  margin-bottom: 0.75rem;
  gap: 0.75rem;
}

.vtk-hostess-actions .btn,
.vtk-hostess-manual-row .btn,
.vtk-hostess-checkin-confirm {
  min-height: 48px;
  border-radius: 999px;
  font-weight: 600;
}

.vtk-hostess-manual-toggle-wrap {
  margin-bottom: 1rem;
}

.vtk-hostess-manual-switch-row {
  display: flex;
  align-items: center;
  min-height: 36px;
  padding: 0;
  gap: 0.6rem;
}

#vtk-hostess-manual-toggle {
  margin-left: 0.125rem;
  -webkit-appearance: unset;
  -moz-appearance: unset;
  appearance: unset;
}

.vtk-hostess-manual-switch-row .form-check-label {
  color: var(--vtk-blue, #292562);
  font-weight: 600;
  cursor: pointer;
  user-select: none;
  line-height: normal;
}

.vtk-hostess-manual-collapse {
  margin-top: 0.75rem;
}

.vtk-hostess-manual-row {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0.75rem;
}

.vtk-hostess-manual-row .form-control {
  min-height: 48px;
  border-radius: 999px;
  padding-right: 1.25rem;
  padding-left: 1.25rem;
  text-transform: uppercase;
  font-size: 1rem;
  font-weight: 600;
}

.vtk-hostess-result {
  margin-top: 1rem;
}

.vtk-hostess-result-card {
  position: relative;
  overflow: hidden;
}

.vtk-hostess-result-card::before {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 0.4rem;
  background: var(--vtk-gold, #c3996b);
  content: "";
}

.vtk-hostess-result-card.is-valid::before {
  background: var(--vtk-green, #8dc63f);
}

.vtk-hostess-result-card.is-warning::before,
.vtk-hostess-result-card.is-error::before {
  background: var(--vtk-red, #7a1700);
}

.vtk-hostess-result-status {
  display: inline-flex;
  align-items: center;
  margin-top: 0.5rem;
  margin-bottom: 0.75rem;
  border-radius: 999px;
  background: rgba(50, 51, 77, 0.08);
  padding: 0.35rem 0.8rem;
  color: var(--vtk-blue, #292562);
  font-size: 0.75rem;
  font-weight: 500;
}

.vtk-hostess-result-card.is-valid .vtk-hostess-result-status {
  background: rgba(141, 198, 63, 0.16);
  color: #4d7f16;
}

.vtk-hostess-result-card.is-warning .vtk-hostess-result-status,
.vtk-hostess-result-card.is-error .vtk-hostess-result-status {
  background: rgba(122, 23, 0, 0.12);
  color: var(--vtk-red, #7a1700);
}

.vtk-hostess-ticket-code {
  margin: 1rem 0;
  border-radius: 1rem;
  background: rgba(50, 51, 77, 0.06);
  padding: 0.85rem 1rem;
  letter-spacing: 0.08em;
  word-break: break-word;
  color: var(--vtk-blue, #292562);
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", monospace;
  font-size: 0.96rem;
  font-weight: 600;
}

.vtk-hostess-meta {
  display: grid;
  margin: 1rem 0;
  gap: 0.6rem;
}

.vtk-hostess-meta-row {
  display: grid;
  grid-template-columns: 105px 1fr;
  border-bottom: 1px solid rgba(50, 51, 77, 0.08);
  padding-bottom: 0.6rem;
  gap: 0.75rem;
}

.vtk-hostess-meta-row span {
  color: var(--bs-gray-600, #6c757d);
  font-size: 0.86rem;
}

.vtk-hostess-meta-row strong {
  color: var(--vtk-blue, #292562);
  font-size: 0.92rem;
}

.vtk-hostess-checkin-confirm {
  margin-top: 0.5rem;
  width: 100%;
}

@media (min-width: 768px) {
  .vtk-hostess-checkin {
    padding: 2rem 0;
  }

  .vtk-hostess-card,
  .vtk-hostess-scanner-card,
  .vtk-hostess-result-card,
  .vtk-hostess-manual-toggle-wrap {
    padding: 1rem;
  }

  .vtk-hostess-video-wrap {
    min-height: 440px;
    aspect-ratio: 16 / 9;
  }

  .vtk-hostess-manual-row {
    grid-template-columns: 1fr auto;
  }

  .vtk-hostess-manual-row .btn {
    min-width: 150px;
  }

  .vtk-hostess-checkin-confirm {
    width: auto;
    min-width: 260px;
  }
}

/*** Media on mobile hide ***/
@media (max-width: 767px) {
  .vtk-hostess-checkin {
    padding: 1rem 0;
  }

  .vtk-hostess-header {
    display: none;
  }

  .et-l.et-l--footer {
    display: none;
  }

  #vtk-hostess-start-camera,
  #vtk-hostess-stop-camera {
    min-height: 36px;
    line-height: 1.2;
  }

  .vtk-hostess-video-wrap {
    min-height: 340px;
    height: 340px;
    aspect-ratio: auto;
  }

  .vtk-hostess-scan-frame {
    top: 43%;
    width: min(66vw, 240px);
    height: min(66vw, 240px);
  }
}
