/* ── OpenTicket — Waitlist Shortcode ──────────────────────── */

.ot-waitlist-wrap {
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    max-width: 540px; margin: 0 auto;
    border: 1px solid #e5e7eb; border-radius: 12px; overflow: hidden;
}

.ot-waitlist-header {
    background: #0a0a0a; color: #fff;
    padding: 20px 24px; display: flex; align-items: center; gap: 16px;
}
.ot-waitlist-icon { font-size: 32px; line-height: 1; }
.ot-waitlist-header h3 { margin: 0 0 4px; font-size: 18px; font-weight: 700; }
.ot-waitlist-header p  { margin: 0; font-size: 13px; opacity: .75; }

.ot-wl-desc {
    padding: 20px 24px 0; font-size: 14px; color: #374151; line-height: 1.6;
}

.ot-wl-form { padding: 16px 24px 24px; background: #fff; }

.ot-wl-fields { display: flex; gap: 14px; flex-wrap: wrap; margin-bottom: 16px; }
.ot-wl-fields .ot-field { flex: 1; min-width: 200px; }
.ot-wl-fields label { display: block; font-size: 12px; font-weight: 600; color: #374151;
    text-transform: uppercase; letter-spacing: .4px; margin-bottom: 5px; }
.ot-wl-fields input {
    width: 100%; padding: 9px 12px; border: 1.5px solid #d1d5db;
    border-radius: 7px; font-size: 14px; box-sizing: border-box;
}
.ot-wl-fields input:focus { border-color: #0073aa; outline: none; }

.ot-btn-waitlist { width: 100%; background: #374151 !important; }
.ot-btn-waitlist:hover { background: #1f2937 !important; }

.ot-wl-privacy {
    font-size: 11px; color: #9ca3af; margin: 10px 0 0; line-height: 1.5;
}

.ot-wl-error {
    background: #fee2e2; color: #991b1b; padding: 10px 16px;
    margin: 12px 24px 0; border-radius: 6px; font-size: 13px;
}

/* Success / joined state */
.ot-waitlist-success {
    max-width: 540px; margin: 0 auto; text-align: center;
    padding: 40px 24px;
    border: 1px solid #d1fae5; border-radius: 12px; background: #f0fdf4;
}
.ot-waitlist-success .ot-waitlist-icon { font-size: 40px; display: block; margin-bottom: 12px; }
.ot-waitlist-success h3 { color: #065f46; margin: 0 0 8px; }
.ot-waitlist-success p  { color: #374151; font-size: 14px; }

/* Token banner above shop shortcode */
.ot-waitlist-token-banner {
    background: #fef3c7; border: 1px solid #fcd34d; border-radius: 10px;
    padding: 14px 18px; margin-bottom: 16px; font-size: 14px; color: #92400e;
    line-height: 1.5;
}

/* Expired token */
.ot-waitlist-expired {
    max-width: 540px; margin: 0 auto; text-align: center;
    padding: 32px 24px; border: 1px solid #fee2e2; border-radius: 12px;
    background: #fff5f5;
}
.ot-waitlist-expired p { color: #374151; font-size: 14px; margin-bottom: 8px; }
