.zlp-checkin-page{
  max-width:680px;
  margin:24px auto;
  padding:0 16px;
}
.zlp-checkin-shell{
  display:flex;
  flex-direction:column;
  gap:16px;
}
.zlp-checkin-header{
  display:flex;
  align-items:center;
  justify-content:space-between;
}
.zlp-checkin-eyebrow{
  font-size:12px;
  color:#6b7280;
  letter-spacing:.08em;
  text-transform:uppercase;
  margin-bottom:6px;
}
.zlp-checkin-title{
  margin:0;
  font-size:28px;
  line-height:1.2;
}
.zlp-checkin-card{
  background:#fff;
  border:1px solid #e5e7eb;
  border-radius:16px;
  padding:20px;
  box-shadow:0 6px 18px rgba(17,24,39,.04);
}
.zlp-checkin-card--error{
  border-color:#fecaca;
  background:#fff7f7;
}
.zlp-checkin-card-title{
  margin:0 0 10px;
  font-size:24px;
  line-height:1.3;
}
.zlp-checkin-muted{
  margin:0 0 16px;
  color:#6b7280;
}
.zlp-checkin-form{
  display:flex;
  flex-direction:column;
  gap:14px;
}
.zlp-checkin-form--compact{ margin-top:18px; }
.zlp-checkin-field label{
  display:block;
  margin-bottom:6px;
  font-weight:600;
}
.zlp-checkin-field input{
  width:100%;
  box-sizing:border-box;
  border:1px solid #d1d5db;
  border-radius:12px;
  padding:14px 16px;
  font-size:16px;
}
.zlp-checkin-remember{
  display:flex;
  gap:10px;
  align-items:center;
  font-size:14px;
  color:#4b5563;
}
.zlp-checkin-button{
  appearance:none;
  border:none;
  border-radius:14px;
  padding:15px 18px;
  font-size:16px;
  font-weight:700;
  cursor:pointer;
}
.zlp-checkin-button--primary{
  background:#111827;
  color:#fff;
}
.zlp-checkin-button--primary:hover{ opacity:.92; }
.zlp-checkin-booking-meta{
  display:flex;
  flex-direction:column;
  gap:12px;
}
.zlp-checkin-row{
  display:flex;
  flex-direction:column;
  gap:4px;
  padding-bottom:12px;
  border-bottom:1px solid #f1f5f9;
}
.zlp-checkin-row:last-child{
  border-bottom:none;
  padding-bottom:0;
}
.zlp-checkin-label{
  font-size:12px;
  font-weight:700;
  color:#6b7280;
}
.zlp-checkin-value{
  font-size:18px;
  font-weight:700;
  color:#111827;
}
.zlp-checkin-notice{
  border-radius:12px;
  padding:14px 16px;
  font-weight:600;
}
.zlp-checkin-notice--success{
  background:#ecfdf5;
  color:#065f46;
  border:1px solid #a7f3d0;
}
.zlp-checkin-notice--error{
  background:#fef2f2;
  color:#991b1b;
  border:1px solid #fecaca;
}
@media (max-width: 640px){
  .zlp-checkin-page{
    padding:0 12px;
    margin:16px auto;
  }
  .zlp-checkin-title{ font-size:24px; }
  .zlp-checkin-card{ padding:16px; border-radius:14px; }
  .zlp-checkin-card-title{ font-size:22px; }
  .zlp-checkin-value{ font-size:17px; }
}


.zlp-checkin-customer-panel {
  border: 1px solid #ececf3;
  border-radius: 18px;
  padding: 20px;
  background: #fff;
  max-width: 520px;
}
.zlp-checkin-customer-title-row { margin-bottom: 12px; }
.zlp-checkin-customer-eyebrow {
  color: #7b86a2;
  font-size: 12px;
  letter-spacing: .04em;
  margin-bottom: 4px;
}
.zlp-checkin-customer-title { margin: 0; font-size: 24px; line-height: 1.3; }
.zlp-checkin-customer-message {
  border-radius: 12px;
  padding: 12px 14px;
  margin-bottom: 14px;
  font-size: 14px;
}
.zlp-checkin-customer-message--pending { background: #fff5da; color: #6b5600; }
.zlp-checkin-customer-message--ready { background: #eef7ff; color: #214d77; }
.zlp-checkin-customer-message--success { background: #edf9f1; color: #21643b; }
.zlp-checkin-customer-message--muted { background: #f6f7fb; color: #667085; }
.zlp-checkin-customer-qr-box {
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 14px 0 6px;
}
.zlp-checkin-qr-image {
  display: block;
  max-width: 220px;
  width: 100%;
  height: auto;
}
.zlp-checkin-customer-meta {
  display: grid;
  gap: 10px;
  margin-top: 12px;
}
.zlp-checkin-customer-meta div {
  display: grid;
  gap: 2px;
}
.zlp-checkin-customer-meta span {
  font-size: 12px;
  color: #7b86a2;
}
.zlp-checkin-customer-meta strong {
  font-size: 16px;
  color: #1b2437;
  font-weight: 700;
}
.zlp-checkin-inline-link { color: #ff5a5f; font-weight: 700; }
