/* ═══════════════════════════════════════════
   BMark Training Manager — Frontend Styles
   ═══════════════════════════════════════════ */

/* ── Badges ────────────────────────────── */
.bmark-badge { display: inline-block; padding: 4px 12px; border-radius: 20px; font-size: 13px; font-weight: 600; }
.bmark-badge--online { background: #dbeafe; color: #1d4ed8; }
.bmark-badge--onsite { background: #d1fae5; color: #047857; }
.bmark-badge--hybrid { background: #fef3c7; color: #92400e; }
.bmark-card-badge { position: absolute; top: 12px; left: 12px; z-index: 2; padding: 4px 10px; border-radius: 6px; font-size: 12px; font-weight: 700; }
.bmark-card-badge--onsite { background: #d1fae5; color: #047857; }
.bmark-card-badge--hybrid { background: #fef3c7; color: #92400e; }

/* ── Price ──────────────────────────────── */
.bmark-price { font-size: 24px; font-weight: 700; color: #1e293b; }
.bmark-price--free { color: #059669; }

/* ── Payment Box ───────────────────────── */
.bmark-payment-box { padding: 0; }
.bmark-payment-box__price { text-align: center; padding: 16px 0; border-bottom: 1px solid #e2e8f0; margin-bottom: 16px; }

/* ── Payment Methods ───────────────────── */
.bmark-payment-methods { margin-bottom: 16px; }
.bmark-payment-methods h4 { font-size: 15px; margin: 0 0 12px; }
.bmark-pm-card { border: 1px solid #e2e8f0; border-radius: 8px; margin-bottom: 10px; overflow: hidden; cursor: pointer; transition: border-color .2s; }
.bmark-pm-card:hover, .bmark-pm-card.active { border-color: #93c5fd; }
.bmark-pm-card__header { display: flex; align-items: center; gap: 8px; padding: 10px 14px; background: #f8fafc; }
.bmark-pm-card__icon { font-size: 18px; }
.bmark-pm-card__details { display: none; margin: 0; padding: 12px 14px; font-size: 13px; line-height: 1.6; background: #fff; white-space: pre-line; font-family: inherit; border-top: 1px solid #e2e8f0; }
.bmark-pm-card.active .bmark-pm-card__details { display: block; }

/* ── WhatsApp Button ───────────────────── */
.bmark-whatsapp-btn { display: flex; align-items: center; justify-content: center; gap: 8px; padding: 12px 20px; background: #25d366; color: #fff !important; border-radius: 8px; text-decoration: none !important; font-weight: 600; font-size: 14px; margin-bottom: 16px; transition: background .2s; }
.bmark-whatsapp-btn:hover { background: #1ebe5d; color: #fff !important; }

/* ── Enrollment Form ───────────────────── */
.bmark-enrollment-form-wrap { border-top: 1px solid #e2e8f0; padding-top: 16px; }
.bmark-enrollment-form-wrap h4 { font-size: 15px; margin: 0 0 12px; }
.bmark-field { margin-bottom: 14px; }
.bmark-field label { display: block; font-weight: 600; font-size: 13px; margin-bottom: 4px; color: #374151; }
.bmark-field .required { color: #dc2626; }
.bmark-field input, .bmark-field select, .bmark-field textarea { width: 100%; padding: 8px 12px; border: 1px solid #d1d5db; border-radius: 6px; font-size: 14px; }
.bmark-field input:focus, .bmark-field select:focus, .bmark-field textarea:focus { border-color: #3b82f6; outline: none; box-shadow: 0 0 0 3px rgba(59,130,246,.1); }
.bmark-field small { color: #6b7280; font-size: 12px; }
.bmark-submit-btn { width: 100%; padding: 14px; background: #1e293b; color: #fff; border: none; border-radius: 8px; font-size: 15px; font-weight: 600; cursor: pointer; transition: background .2s; }
.bmark-submit-btn:hover { background: #0f172a; }
.bmark-submit-btn:disabled { opacity: .6; cursor: not-allowed; }
#bmark-enroll-message { margin-top: 12px; padding: 10px 14px; border-radius: 6px; font-size: 14px; }
#bmark-enroll-message.success { background: #d1fae5; color: #047857; border: 1px solid #a7f3d0; }
#bmark-enroll-message.error { background: #fee2e2; color: #b91c1c; border: 1px solid #fecaca; }

/* ── Enrollment Status ─────────────────── */
.bmark-enrollment-status { display: flex; gap: 12px; align-items: flex-start; padding: 14px; border-radius: 8px; margin-bottom: 16px; }
.bmark-enrollment-status--pending { background: #fef3c7; border: 1px solid #fde68a; }
.bmark-enrollment-status--approved { background: #d1fae5; border: 1px solid #a7f3d0; }
.bmark-enrollment-status--rejected { background: #fee2e2; border: 1px solid #fecaca; }
.bmark-enrollment-status__icon { font-size: 24px; }
.bmark-enrollment-status p { margin: 4px 0 0; font-size: 13px; color: #4b5563; }

/* ── Login Notice ──────────────────────── */
.bmark-login-notice { text-align: center; padding: 16px; background: #f0f9ff; border-radius: 8px; border: 1px solid #bae6fd; }
.bmark-login-notice a { font-weight: 600; }

/* ── Schedule Table ────────────────────── */
.bmark-schedule { margin: 20px 0; }
.bmark-schedule__title { font-size: 16px; margin: 0 0 12px; }
.bmark-schedule__table { width: 100%; border-collapse: collapse; font-size: 14px; }
.bmark-schedule__table th { text-align: left; padding: 8px 12px; background: #f8fafc; border-bottom: 2px solid #e2e8f0; font-size: 12px; text-transform: uppercase; color: #64748b; }
.bmark-schedule__table td { padding: 10px 12px; border-bottom: 1px solid #f1f5f9; }
.bmark-schedule__row--completed { opacity: .6; }
.bmark-schedule__row--today { background: #fffbeb; }
.bmark-status { display: inline-block; padding: 2px 10px; border-radius: 12px; font-size: 12px; font-weight: 600; }
.bmark-status--completed { background: #d1fae5; color: #047857; }
.bmark-status--today { background: #fef3c7; color: #92400e; }
.bmark-status--upcoming { background: #dbeafe; color: #1d4ed8; }

/* ── Venue Card ────────────────────────── */
.bmark-venue-card { display: flex; gap: 12px; padding: 14px; background: #f8fafc; border: 1px solid #e2e8f0; border-radius: 8px; margin: 12px 0; }
.bmark-venue-card__icon { font-size: 24px; }
.bmark-venue-card__details { display: flex; flex-direction: column; gap: 2px; }
.bmark-venue-card__address { font-size: 13px; color: #64748b; }
.bmark-venue-card__map-link { font-size: 13px; font-weight: 600; }

/* ── Seats ─────────────────────────────── */
.bmark-seats { padding: 14px; background: #f8fafc; border: 1px solid #e2e8f0; border-radius: 8px; margin: 12px 0; }
.bmark-seats--full { background: #fee2e2; border-color: #fecaca; }
.bmark-seats__header { display: flex; align-items: center; gap: 8px; margin-bottom: 8px; font-size: 14px; }
.bmark-seats__bar-wrap { height: 8px; background: #e2e8f0; border-radius: 4px; overflow: hidden; }
.bmark-seats__bar { height: 100%; background: #059669; border-radius: 4px; transition: width .3s; }
.bmark-seats--full .bmark-seats__bar { background: #dc2626; }

/* ── Lesson Lock ───────────────────────── */
.bmark-lesson-locked { text-align: center; padding: 40px 24px; background: #f8fafc; border: 2px dashed #cbd5e1; border-radius: 12px; margin: 20px 0; }
.bmark-lesson-locked__icon { font-size: 48px; margin-bottom: 12px; }
.bmark-lesson-locked h3 { margin: 0 0 8px; color: #1e293b; }
.bmark-lesson-locked p { color: #475569; margin: 4px 0; }
.bmark-lesson-locked__hint { font-size: 13px; color: #94a3b8; margin-top: 12px !important; }
.bmark-lock-icon { font-size: 12px; color: #d97706; margin-left: 4px; }
.bmark-unlock-icon { font-size: 12px; color: #059669; margin-left: 4px; }

/* ── Misc ──────────────────────────────── */
.bmark-hybrid-note { display: flex; gap: 8px; padding: 12px 16px; background: #fef3c7; border-radius: 8px; font-size: 14px; color: #92400e; border: 1px solid #fde68a; }
.bmark-zoom-btn { display: inline-flex; align-items: center; gap: 6px; padding: 10px 18px; background: #2563eb; color: #fff !important; border-radius: 8px; text-decoration: none !important; font-weight: 600; font-size: 14px; }
.bmark-zoom-btn:hover { background: #1d4ed8; color: #fff !important; }
.bmark-lesson-info-banner { padding: 10px 16px; background: #f0f9ff; border: 1px solid #bae6fd; border-radius: 8px; font-size: 14px; margin-bottom: 16px; }
.bmark-next-session { font-size: 14px; }
.bmark-next-session__label { color: #64748b; }
.bmark-instructor { font-size: 14px; }
.bmark-access-info { font-size: 14px; }
.bmark-course-status { display: inline-block; padding: 4px 12px; border-radius: 12px; font-size: 12px; font-weight: 600; }
.bmark-course-status--upcoming { background: #dbeafe; color: #1d4ed8; }
.bmark-course-status--ongoing { background: #fef3c7; color: #92400e; }
.bmark-course-status--completed { background: #d1fae5; color: #047857; }
.bmark-course-status--available { background: #d1fae5; color: #047857; }

/* ── Auth Buttons ──────────────────────── */
.bmark-auth-buttons { display: flex; flex-direction: column; gap: 10px; padding: 4px 0; }
.bmark-btn { display: inline-flex; align-items: center; justify-content: center; padding: 14px 20px; border-radius: 8px; font-size: 15px; font-weight: 600; cursor: pointer; transition: all .2s; border: 2px solid transparent; text-decoration: none; }
.bmark-btn--primary { background: #1e293b; color: #fff; border-color: #1e293b; }
.bmark-btn--primary:hover { background: #0f172a; }
.bmark-btn--outline { background: #fff; color: #1e293b; border-color: #cbd5e1; }
.bmark-btn--outline:hover { border-color: #1e293b; background: #f8fafc; }
.bmark-btn--full { width: 100%; }

/* ── Auth Modals ───────────────────────── */
.bmark-modal-overlay { position: fixed; inset: 0; background: rgba(0,0,0,.6); z-index: 999999; display: flex; align-items: center; justify-content: center; backdrop-filter: blur(4px); }
.bmark-modal { background: #fff; border-radius: 16px; max-width: 440px; width: 92%; padding: 32px; box-shadow: 0 24px 48px rgba(0,0,0,.2); position: relative; animation: bmark-modal-in .25s ease-out; }
@keyframes bmark-modal-in { from { opacity: 0; transform: translateY(16px) scale(.97); } to { opacity: 1; transform: none; } }
.bmark-modal-close { position: absolute; top: 12px; right: 16px; background: none; border: none; font-size: 28px; color: #94a3b8; cursor: pointer; line-height: 1; padding: 4px; }
.bmark-modal-close:hover { color: #1e293b; }
.bmark-auth-modal h2 { font-size: 22px; margin: 0 0 4px; color: #1e293b; }
.bmark-modal-subtitle { color: #64748b; font-size: 14px; margin: 0 0 20px; }
.bmark-auth-form .bmark-field { margin-bottom: 16px; }
.bmark-auth-form .bmark-field label { font-size: 13px; font-weight: 600; color: #374151; margin-bottom: 4px; display: block; }
.bmark-auth-form .bmark-field input { width: 100%; padding: 10px 14px; border: 1.5px solid #d1d5db; border-radius: 8px; font-size: 14px; transition: border-color .2s; }
.bmark-auth-form .bmark-field input:focus { border-color: #3b82f6; outline: none; box-shadow: 0 0 0 3px rgba(59,130,246,.1); }
.bmark-auth-error { background: #fee2e2; color: #b91c1c; padding: 10px 14px; border-radius: 6px; font-size: 13px; margin-bottom: 12px; border: 1px solid #fecaca; }
.bmark-auth-switch { text-align: center; font-size: 13px; color: #64748b; margin: 16px 0 0; }
.bmark-auth-switch a { color: #2563eb; font-weight: 600; }

/* ── Divider ───────────────────────────── */
.bmark-divider { display: flex; align-items: center; gap: 12px; margin: 16px 0; }
.bmark-divider::before, .bmark-divider::after { content: ''; flex: 1; height: 1px; background: #e2e8f0; }
.bmark-divider span { font-size: 12px; color: #94a3b8; text-transform: uppercase; letter-spacing: 0.5px; white-space: nowrap; }

/* ── Google Button Wrapper ─────────────── */
.bmark-google-btn-wrap { display: flex; justify-content: center; min-height: 44px; }
.bmark-google-btn-wrap > div { width: 100% !important; }
