.rlt-portal-shell { max-width: 1160px; margin: 30px auto; padding: 0 18px; font-family: Inter, Arial, sans-serif; color: #111827; }
.rlt-form-card, .rlt-profile-card, .rlt-course-card, .rlt-mission-card, .rlt-front-stat, .rlt-empty-card { background: #fff; border: 1px solid #e5e7eb; border-radius: 20px; box-shadow: 0 12px 35px rgba(17,24,39,.08); overflow: hidden; }
.rlt-form-card { padding: 28px; max-width: 680px; margin: 0 auto; }
.rlt-form-card h2 { margin: 0 0 8px; font-size: 30px; }
.rlt-form-card p { color: #6b7280; }
.rlt-form label { display: block; font-weight: 700; color: #374151; margin-bottom: 14px; }
.rlt-form input, .rlt-form textarea, .rlt-inline-form input, .rlt-login-card input[type="text"], .rlt-login-card input[type="password"] { width: 100%; border: 1px solid #d1d5db; border-radius: 12px; padding: 13px 14px; margin-top: 6px; box-sizing: border-box; }
.rlt-button, .login-submit input { display: inline-flex; align-items: center; justify-content: center; gap: 8px; background: #cc3553; color: #fff !important; border: 0; padding: 12px 18px; border-radius: 999px; text-decoration: none; font-weight: 800; cursor: pointer; box-shadow: 0 10px 25px rgba(204,53,83,.25); }
.rlt-button:hover, .login-submit input:hover { background: #9d2440; color: #fff; }
.rlt-button-light { background: #f3f4f6; color: #111827 !important; box-shadow: none; }
.rlt-muted-link { display: inline-block; margin-top: 12px; color: #cc3553; text-decoration: none; }
.rlt-profile-card { margin-bottom: 28px; }
.rlt-profile-banner { min-height: 190px; background: radial-gradient(circle at 20% 20%, #f0c3cc, transparent 30%), linear-gradient(135deg, #111827, #cc3553); background-size: cover; background-position: center; }
.rlt-profile-body { display: flex; gap: 22px; padding: 0 28px 22px; align-items: flex-end; margin-top: -55px; }
.rlt-avatar { width: 128px; height: 128px; border-radius: 50%; border: 6px solid #fff; object-fit: cover; background: #fff; box-shadow: 0 12px 30px rgba(17,24,39,.2); }
.rlt-profile-info h1 { margin: 8px 0 4px; font-size: 32px; }
.rlt-profile-info p { margin: 0 0 12px; color: #6b7280; }
.rlt-pill, .rlt-pill-light { display: inline-flex; align-items: center; border-radius: 999px; padding: 6px 12px; font-size: 12px; font-weight: 800; }
.rlt-pill { background: #fff3f6; color: #9d2440; }
.rlt-pill-light { background: #f3f4f6; color: #374151; }
.rlt-progress { height: 9px; border-radius: 999px; background: #e5e7eb; overflow: hidden; max-width: 420px; }
.rlt-progress span { display: block; height: 100%; background: linear-gradient(90deg, #cc3553, #f0c3cc); border-radius: inherit; }
.rlt-badges-row { display: flex; flex-wrap: wrap; gap: 10px; padding: 0 28px 28px; }
.rlt-badge-chip { display: inline-flex; gap: 7px; align-items: center; padding: 9px 13px; border-radius: 999px; background: #fafafa; border: 1px solid #e5e7eb; font-weight: 700; }
.rlt-section-heading { margin: 28px 0 16px; }
.rlt-section-heading h2 { font-size: 28px; margin: 0 0 6px; }
.rlt-section-heading p { margin: 0; color: #6b7280; }
.rlt-missions-grid, .rlt-course-grid, .rlt-dashboard-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); gap: 18px; }
.rlt-mission-card { padding: 20px; }
.rlt-mission-card h3 { margin: 14px 0 8px; font-size: 19px; }
.rlt-mission-card p { color: #6b7280; min-height: 42px; }
.rlt-mission-card strong { color: #cc3553; }
.rlt-course-card { display: flex; flex-direction: column; }
.rlt-course-thumb { height: 145px; background: linear-gradient(135deg, #e5e7eb, #fff3f6); background-size: cover; background-position: center; }
.rlt-course-content { padding: 18px; }
.rlt-course-content h3 { margin: 12px 0 8px; font-size: 20px; line-height: 1.25; }
.rlt-course-content p { color: #6b7280; min-height: 48px; }
.rlt-course-meta { display: flex; justify-content: space-between; color: #6b7280; font-size: 13px; margin-bottom: 10px; }
.rlt-front-stat { padding: 22px; }
.rlt-front-stat strong { font-size: 34px; display: block; }
.rlt-front-stat span { color: #6b7280; }
.rlt-empty-card { padding: 25px; color: #6b7280; }
.rlt-inline-form { display: flex; gap: 10px; align-items: center; }
.rlt-success-box, .rlt-error-box { max-width: 680px; margin: 16px auto; padding: 14px 16px; border-radius: 14px; font-weight: 700; }
.rlt-success-box { background: #dcfce7; color: #166534; }
.rlt-error-box { background: #fee2e2; color: #991b1b; }
@media (max-width: 720px) { .rlt-profile-body { flex-direction: column; align-items: flex-start; } .rlt-inline-form { flex-direction: column; align-items: stretch; } }
.rlt-school-avatar { display:flex; align-items:center; justify-content:center; font-size:52px; background:#fff; }
.rlt-standalone-portal { background:#f9fafb; }

.rlt-school-avatar-logo { padding: 10px; object-fit: contain; background: #fff; }
.rlt-school-logo { display: block; max-width: 190px; max-height: 82px; object-fit: contain; margin: 12px 0 8px; }
.rlt-standalone-portal .rlt-profile-card { margin-top: 22px; }


/* Course links and learning view - v0.1.1 */
.rlt-course-link { color: inherit; text-decoration: none !important; cursor: pointer; transition: transform .2s ease, box-shadow .2s ease; }
.rlt-course-link:hover { color: inherit; text-decoration: none; box-shadow: 0 18px 45px rgba(17,24,39,.12); transform: translateY(-3px); }
.rlt-course-link h3 { color: #111827; }
.rlt-back-link { display: inline-flex; margin-bottom: 12px; color: #cc3553; text-decoration: none; font-weight: 800; }
.rlt-course-hero { display: grid; grid-template-columns: minmax(0, 1.4fr) minmax(260px, .7fr); gap: 24px; background: #fff; border: 1px solid #e5e7eb; border-radius: 26px; padding: 28px; box-shadow: 0 14px 40px rgba(17,24,39,.08); margin-bottom: 24px; align-items: stretch; }
.rlt-course-hero h1 { font-size: clamp(32px, 5vw, 52px); line-height: 1.05; margin: 14px 0 12px; letter-spacing: -.04em; }
.rlt-course-hero p { color: #6b7280; font-size: 16px; max-width: 720px; }
.rlt-course-hero-meta { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 18px; }
.rlt-course-hero-meta span { background: #f3f4f6; border: 1px solid #e5e7eb; border-radius: 999px; padding: 8px 12px; font-weight: 800; font-size: 13px; color: #374151; }
.rlt-course-hero-thumb { min-height: 240px; border-radius: 20px; background: linear-gradient(135deg, #fff3f6, #e5e7eb); background-size: cover; background-position: center; }
.rlt-learning-layout { display: grid; grid-template-columns: minmax(0, 1fr) 330px; gap: 22px; align-items: start; }
.rlt-lesson-main, .rlt-lessons-sidebar, .rlt-lesson-content-card { min-width: 0; }
.rlt-video-box, .rlt-lesson-content-card, .rlt-lessons-sidebar { background: #fff; border: 1px solid #e5e7eb; border-radius: 22px; box-shadow: 0 12px 35px rgba(17,24,39,.07); overflow: hidden; }
.rlt-video-box { margin-bottom: 18px; }
.rlt-responsive-embed { position: relative; width: 100%; padding-top: 56.25%; background: #111827; }
.rlt-responsive-embed iframe { position: absolute; inset: 0; width: 100% !important; height: 100% !important; border: 0; }
.rlt-video-placeholder { min-height: 300px; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 8px; text-align: center; background: linear-gradient(135deg, #111827, #9d2440); color: #fff; padding: 28px; }
.rlt-video-placeholder span, .rlt-video-placeholder small { opacity: .8; }
.rlt-video-placeholder a { color: #fff; font-weight: 800; }
.rlt-lesson-content-card { padding: 24px; }
.rlt-lesson-content-card h2 { margin: 12px 0; font-size: 30px; }
.rlt-lesson-content { color: #374151; line-height: 1.75; }
.rlt-resources-box { margin-top: 20px; background: #f9fafb; border: 1px solid #e5e7eb; border-radius: 18px; padding: 18px; }
.rlt-resources-box h3 { margin-top: 0; }
.rlt-lessons-sidebar { padding: 18px; position: sticky; top: 30px; }
.rlt-lessons-sidebar h3 { margin: 0 0 14px; font-size: 20px; }
.rlt-lesson-row { display: grid; grid-template-columns: 34px minmax(0, 1fr); gap: 10px; align-items: center; padding: 12px; border: 1px solid #e5e7eb; border-radius: 16px; color: #111827; text-decoration: none !important; margin-bottom: 10px; background: #fff; }
.rlt-lesson-row:hover, .rlt-lesson-row.is-active { border-color: #f0c3cc; background: #fff3f6; color: #111827; }
.rlt-lesson-row span { display: flex; align-items: center; justify-content: center; width: 34px; height: 34px; border-radius: 50%; background: #fff3f6; color: #9d2440; font-weight: 900; }
.rlt-lesson-row strong { font-size: 14px; line-height: 1.3; }
@media (max-width: 900px) { .rlt-course-hero, .rlt-learning-layout { grid-template-columns: 1fr; } .rlt-lessons-sidebar { position: static; } }

/* Course curriculum and learning experience - v0.1.2 */
.rlt-udemy-hero { grid-template-columns: minmax(0, 1fr) 360px; background: linear-gradient(135deg, #111827 0%, #9d2440 58%, #cc3553 100%); color: #fff; border: 0; overflow: visible; }
.rlt-udemy-hero .rlt-back-link, .rlt-udemy-hero h1, .rlt-udemy-hero .rlt-course-hero-copy p { color: #fff; }
.rlt-udemy-hero .rlt-course-hero-copy p { opacity: .86; font-size: 17px; }
.rlt-udemy-hero .rlt-course-hero-meta span { background: rgba(255,255,255,.12); border-color: rgba(255,255,255,.2); color: #fff; }
.rlt-course-hero-card { background: #fff; color: #111827; border-radius: 22px; overflow: hidden; box-shadow: 0 22px 55px rgba(0,0,0,.22); align-self: start; }
.rlt-course-hero-card .rlt-course-hero-thumb { border-radius: 0; min-height: 205px; }
.rlt-course-hero-card-body { padding: 18px; }
.rlt-start-course-button { width: 100%; min-height: 52px; font-size: 16px; }
.rlt-button-disabled { opacity: .6; cursor: not-allowed; }
.rlt-course-quick-stats { margin-top: 16px; display: grid; gap: 8px; color: #4b5563; font-size: 14px; }
.rlt-course-quick-stats strong { color: #111827; font-size: 15px; }
.rlt-course-stats-strip { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 14px; margin: 0 0 22px; }
.rlt-course-stats-strip > div { background: #fff; border: 1px solid #e5e7eb; border-radius: 18px; padding: 18px; box-shadow: 0 10px 25px rgba(17,24,39,.06); }
.rlt-course-stats-strip strong { display: block; font-size: 20px; line-height: 1.2; color: #111827; }
.rlt-course-stats-strip span { display: block; color: #6b7280; margin-top: 4px; font-size: 13px; font-weight: 700; }
.rlt-content-panel, .rlt-curriculum-panel { background: #fff; border: 1px solid #e5e7eb; border-radius: 22px; box-shadow: 0 12px 35px rgba(17,24,39,.07); padding: 24px; margin-bottom: 22px; }
.rlt-content-panel h2, .rlt-curriculum-panel h2 { margin: 0 0 12px; font-size: 26px; }
.rlt-curriculum-header { display: flex; align-items: center; justify-content: space-between; gap: 16px; margin-bottom: 18px; }
.rlt-curriculum-header p { margin: 0; color: #6b7280; }
.rlt-curriculum-list { display: grid; gap: 10px; }
.rlt-curriculum-item { border: 1px solid #e5e7eb; border-radius: 18px; overflow: hidden; background: #fff; }
.rlt-curriculum-item > a { display: grid; grid-template-columns: 42px minmax(0, 1fr) auto; align-items: center; gap: 12px; padding: 14px 16px; text-decoration: none !important; color: #111827; }
.rlt-curriculum-item > a:hover { background: #f9fafb; color: #111827; }
.rlt-curriculum-item > a > span { width: 42px; height: 42px; border-radius: 50%; background: #fff3f6; color: #9d2440; display: inline-flex; align-items: center; justify-content: center; font-weight: 900; }
.rlt-curriculum-item strong { line-height: 1.25; }
.rlt-curriculum-item em { color: #6b7280; font-style: normal; font-weight: 800; font-size: 12px; background: #f3f4f6; padding: 6px 10px; border-radius: 999px; }
.rlt-curriculum-subitems { display: grid; gap: 8px; padding: 0 16px 14px 70px; }
.rlt-curriculum-subitems a, .rlt-sidebar-subitem { display: block; text-decoration: none !important; color: #4b5563; font-size: 13px; font-weight: 700; border-radius: 12px; padding: 9px 12px; background: #f9fafb; border: 1px solid #eef2f7; }
.rlt-curriculum-subitems a:hover, .rlt-sidebar-subitem:hover, .rlt-sidebar-subitem.is-active { background: #fff3f6; color: #9d2440; border-color: #f0c3cc; }
.rlt-learning-topbar { display: flex; align-items: center; justify-content: space-between; gap: 16px; background: #fff; border: 1px solid #e5e7eb; border-radius: 20px; padding: 14px 18px; margin-bottom: 18px; box-shadow: 0 10px 25px rgba(17,24,39,.06); }
.rlt-learning-topbar .rlt-back-link { margin: 0; }
.rlt-sidebar-subitems { display: grid; gap: 8px; margin: -4px 0 14px 44px; }
.rlt-sidebar-course-quizzes { margin-top: 18px; border-top: 1px solid #e5e7eb; padding-top: 14px; }
.rlt-sidebar-course-quizzes h4 { margin: 0 0 10px; }
.rlt-ready-box { margin-top: 22px; border: 1px solid #e5e7eb; border-radius: 18px; padding: 18px; background: #fafafa; }
.rlt-ready-box h3 { margin: 0 0 12px; }
.rlt-ready-actions { display: flex; flex-wrap: wrap; gap: 10px; }
.rlt-mini-action { display: inline-flex; align-items: center; padding: 9px 12px; border-radius: 999px; background: #fff3f6; color: #9d2440; text-decoration: none !important; font-weight: 800; font-size: 13px; }
.rlt-question-prompt { font-size: 18px; color: #374151; line-height: 1.7; }
.rlt-question-note { margin-top: 18px; border-radius: 14px; background: #fffbeb; color: #92400e; padding: 12px 14px; font-weight: 700; }
.rlt-options-list { display: grid; gap: 10px; margin: 16px 0; }
.rlt-options-list label { display: flex; gap: 10px; align-items: center; border: 1px solid #e5e7eb; border-radius: 14px; padding: 13px; cursor: pointer; }
.rlt-options-list label:hover { background: #f9fafb; }
.rlt-answer-textarea { width: 100%; border: 1px solid #d1d5db; border-radius: 14px; padding: 14px; }
.rlt-image-choice-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); gap: 14px; }
.rlt-image-choice { border: 1px solid #e5e7eb; border-radius: 18px; background: #fff; padding: 10px; cursor: pointer; text-align: center; font-weight: 800; }
.rlt-image-choice:hover { border-color: #f0c3cc; background: #fff3f6; }
.rlt-image-choice img { width: 100%; aspect-ratio: 4/3; object-fit: cover; border-radius: 12px; display: block; margin-bottom: 8px; }
.rlt-match-grid { display: grid; gap: 12px; }
.rlt-match-pair { display: grid; grid-template-columns: 1fr 36px 1fr; align-items: center; gap: 10px; background: #f9fafb; border: 1px solid #e5e7eb; border-radius: 18px; padding: 12px; }
.rlt-match-pair img { width: 100%; aspect-ratio: 4/3; object-fit: cover; border-radius: 12px; background: #fff; }
.rlt-match-pair span { text-align: center; font-weight: 900; color: #cc3553; }
.rlt-quiz-meta { margin-bottom: 16px; }
.rlt-quiz-question-list { display: grid; gap: 10px; }
.rlt-quiz-question-row { display: grid; grid-template-columns: 36px minmax(0, 1fr); gap: 10px; align-items: center; text-decoration: none !important; color: #111827; border: 1px solid #e5e7eb; border-radius: 14px; padding: 12px; }
.rlt-quiz-question-row:hover { background: #fff3f6; border-color: #f0c3cc; }
.rlt-quiz-question-row span { display: inline-flex; align-items: center; justify-content: center; width: 36px; height: 36px; border-radius: 50%; background: #fff3f6; color: #9d2440; font-weight: 900; }
.rlt-rich-content img { max-width: 100%; height: auto; border-radius: 14px; }
.rlt-rich-content .wpb_content_element { margin-bottom: 18px; }
@media (max-width: 900px) { .rlt-udemy-hero, .rlt-course-stats-strip { grid-template-columns: 1fr; } .rlt-curriculum-header, .rlt-learning-topbar { align-items: flex-start; flex-direction: column; } .rlt-curriculum-item > a { grid-template-columns: 42px minmax(0, 1fr); } .rlt-curriculum-item em { grid-column: 2; justify-self: start; } }

/* Brand color system and active learning UI - v0.1.4 */
.rlt-button, .login-submit input { background: var(--rlt-primary, #cc3553) !important; box-shadow: 0 10px 25px var(--rlt-primary-shadow, rgba(204,53,83,.25)); }
.rlt-button:hover, .login-submit input:hover { background: var(--rlt-primary-hover, #f0c3cc) !important; color: #111827 !important; }
.rlt-button-light { background: #f8f0f2 !important; color: var(--rlt-primary, #cc3553) !important; box-shadow: none !important; border: 1px solid var(--rlt-primary-hover, #f0c3cc); }
.rlt-button-light:hover { background: var(--rlt-primary-hover, #f0c3cc) !important; color: #111827 !important; }
.rlt-muted-link, .rlt-back-link, .rlt-mission-card strong, .rlt-match-pair span { color: var(--rlt-primary, #cc3553) !important; }
.rlt-pill { background: #fff3f6 !important; color: var(--rlt-primary, #cc3553) !important; }
.rlt-progress span { background: linear-gradient(90deg, var(--rlt-primary, #cc3553), var(--rlt-primary-hover, #f0c3cc)) !important; }
.rlt-profile-banner:not([style]) { background: radial-gradient(circle at 20% 20%, var(--rlt-primary-hover, #f0c3cc), transparent 30%), linear-gradient(135deg, #111827, var(--rlt-primary, #cc3553)) !important; }
.rlt-profile-banner[style] { background-size: cover !important; background-position: center center !important; background-repeat: no-repeat !important; }
.rlt-course-thumb, .rlt-course-hero-thumb { background-size: cover !important; background-position: center !important; }
.rlt-course-thumb:not([style]), .rlt-course-hero-thumb:not([style]) { background: linear-gradient(135deg, #fff3f6, #f8f0f2) !important; }
.rlt-lesson-row:hover, .rlt-lesson-row.is-active, .rlt-curriculum-subitems a:hover, .rlt-sidebar-subitem:hover, .rlt-sidebar-subitem.is-active, .rlt-quiz-question-row:hover { background: #fff3f6 !important; border-color: var(--rlt-primary-hover, #f0c3cc) !important; color: var(--rlt-primary, #cc3553) !important; }
.rlt-lesson-row span, .rlt-curriculum-item > a > span, .rlt-quiz-question-row span, .rlt-quiz-question-title span { background: #fff3f6 !important; color: var(--rlt-primary, #cc3553) !important; }
.rlt-udemy-hero { background: linear-gradient(135deg, #111827 0%, var(--rlt-primary, #cc3553) 58%, var(--rlt-primary-hover, #f0c3cc) 100%) !important; }
.rlt-mini-action { background: #fff3f6 !important; color: var(--rlt-primary, #cc3553) !important; border: 1px solid var(--rlt-primary-hover, #f0c3cc); }
.rlt-image-choice:hover, .rlt-image-choice.is-selected, .rlt-image-choice:has(input:checked) { border-color: var(--rlt-primary, #cc3553) !important; background: #fff3f6 !important; box-shadow: 0 10px 24px rgba(204,53,83,.12); }
.rlt-image-choice input { margin: 0 0 8px; accent-color: var(--rlt-primary, #cc3553); }
.rlt-options-list input { accent-color: var(--rlt-primary, #cc3553); }
.rlt-options-list label:has(input:checked) { border-color: var(--rlt-primary, #cc3553); background: #fff3f6; }
.rlt-learning-topbar-info { display: grid; gap: 6px; min-width: min(420px, 100%); }
.rlt-topbar-progress { display: grid; grid-template-columns: minmax(160px, 1fr) auto; gap: 10px; align-items: center; margin-top: 6px; }
.rlt-topbar-progress small { color: #6b7280; font-weight: 800; white-space: nowrap; }
.rlt-course-hero-progress { max-width: 520px; margin-top: 20px; }
.rlt-lesson-card-topline { display: flex; flex-wrap: wrap; align-items: center; gap: 10px; }
.rlt-status-pill { display: inline-flex; align-items: center; border-radius: 999px; padding: 6px 12px; font-size: 12px; font-weight: 900; }
.rlt-status-pill.is-complete { background: #dcfce7; color: #166534; }
.rlt-complete-box { margin-top: 22px; border: 1px solid #e5e7eb; border-radius: 18px; padding: 18px; background: #fafafa; }
.rlt-complete-box p { color: #6b7280; margin: 6px 0 14px; }
.rlt-action-form { margin: 0; }
.rlt-result-box { margin: 0 0 18px; padding: 14px 16px; border-radius: 16px; font-weight: 800; border: 1px solid transparent; }
.rlt-result-box.is-success { background: #dcfce7; color: #166534; border-color: #bbf7d0; }
.rlt-result-box.is-error { background: #fee2e2; color: #991b1b; border-color: #fecaca; }
.rlt-result-box.is-info { background: #eff6ff; color: #1d4ed8; border-color: #bfdbfe; }
.rlt-question-form, .rlt-quiz-form { display: grid; gap: 16px; }
.rlt-quiz-question-list-active { display: grid; gap: 16px; margin: 18px 0; }
.rlt-quiz-question-card { border: 1px solid #e5e7eb; border-radius: 18px; padding: 18px; background: #fff; }
.rlt-quiz-question-card > p { color: #374151; margin: 10px 0 14px; }
.rlt-quiz-question-title { display: grid; grid-template-columns: 36px minmax(0, 1fr); gap: 10px; align-items: center; }
.rlt-quiz-question-title span { display: inline-flex; align-items: center; justify-content: center; width: 36px; height: 36px; border-radius: 50%; font-weight: 900; }
.rlt-sidebar-subitem.is-done, .rlt-curriculum-subitems a.is-done, .rlt-curriculum-item.is-complete > a { border-color: #bbf7d0 !important; background: #f0fdf4 !important; color: #166534 !important; }
.rlt-sidebar-group.is-complete .rlt-lesson-row span, .rlt-curriculum-item.is-complete > a > span { background: #dcfce7 !important; color: #166534 !important; }
.rlt-match-answer-grid { display: grid; gap: 16px; margin: 16px 0; }
.rlt-match-right-bank { border: 1px solid #e5e7eb; border-radius: 18px; padding: 14px; background: #fafafa; }
.rlt-match-right-bank > div { display: grid; grid-template-columns: repeat(auto-fill, minmax(130px, 1fr)); gap: 12px; margin-top: 10px; }
.rlt-match-right-bank span { display: grid; gap: 8px; font-weight: 900; color: var(--rlt-primary, #cc3553); }
.rlt-match-right-bank img, .rlt-match-answer-row img { width: 100%; aspect-ratio: 4/3; object-fit: cover; border-radius: 12px; background: #fff; border: 1px solid #e5e7eb; }
.rlt-match-answer-row { display: grid; grid-template-columns: 180px minmax(0, 1fr); gap: 14px; align-items: center; border: 1px solid #e5e7eb; border-radius: 18px; padding: 14px; }
.rlt-match-answer-row label { display: grid; gap: 6px; font-weight: 800; color: #374151; }
.rlt-match-answer-row select { width: 100%; border: 1px solid #d1d5db; border-radius: 12px; padding: 12px; }
@media (max-width: 720px) { .rlt-topbar-progress, .rlt-match-answer-row { grid-template-columns: 1fr; } }

/* Student tabs, icons, clean profile dashboard - v0.1.6 */
.rlt-student-profile-shell { max-width:1180px; }
.rlt-profile-tabs { display:flex; flex-wrap:wrap; gap:10px; background:#fff; border:1px solid #e5e7eb; border-radius:22px; padding:10px; margin:0 0 24px; box-shadow:0 14px 40px rgba(17,24,39,.07); }
.rlt-profile-tab { display:inline-flex; align-items:center; gap:8px; padding:12px 16px; border-radius:16px; color:#374151; text-decoration:none !important; font-weight:900; transition:all .18s ease; }
.rlt-profile-tab:hover { background:#fff3f6; color:var(--rlt-primary, #cc3553); }
.rlt-profile-tab.is-active { background:linear-gradient(135deg, var(--rlt-primary, #cc3553), var(--rlt-primary-hover, #f0c3cc)); color:#fff; box-shadow:0 12px 26px rgba(204,53,83,.22); }
.rlt-profile-tab span { font-size:18px; }
.rlt-tab-content { min-height:320px; }
.rlt-card-icon, .rlt-front-icon { display:inline-flex; align-items:center; justify-content:center; width:42px; height:42px; border-radius:16px; background:#fff3f6; color:var(--rlt-primary, #cc3553); font-size:22px; }
.rlt-front-icon { width:36px; height:36px; margin-right:8px; vertical-align:middle; }
.rlt-mission-card, .rlt-front-stat, .rlt-course-card { transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease; }
.rlt-mission-card:hover, .rlt-front-stat:hover, .rlt-course-card:hover { transform:translateY(-3px); box-shadow:0 20px 50px rgba(17,24,39,.12); border-color:var(--rlt-primary-hover, #f0c3cc); }
.rlt-profile-card { border-radius:26px; box-shadow:0 18px 50px rgba(17,24,39,.09); }
.rlt-profile-banner { min-height:220px; }
.rlt-profile-info small { display:block; margin-top:8px; color:#6b7280; font-weight:800; }
.rlt-avatar { background:#fff3f6; }
.rlt-achievements-grid { display:grid; grid-template-columns:repeat(auto-fill, minmax(230px, 1fr)); gap:18px; }
.rlt-achievement-card { background:#fff; border:1px solid #e5e7eb; border-radius:22px; padding:20px; box-shadow:0 12px 35px rgba(17,24,39,.07); display:grid; gap:10px; transition:all .18s ease; }
.rlt-achievement-card:hover { transform:translateY(-3px); box-shadow:0 20px 50px rgba(17,24,39,.12); }
.rlt-achievement-card.is-locked { opacity:.72; filter:grayscale(.15); }
.rlt-achievement-card.is-earned { border-color:#bbf7d0; background:linear-gradient(180deg, #fff, #f0fdf4); }
.rlt-achievement-icon { width:64px; height:64px; display:flex; align-items:center; justify-content:center; border-radius:20px; background:#fff3f6; font-size:30px; color:var(--rlt-primary, #cc3553); }
.rlt-achievement-icon img { width:100%; height:100%; object-fit:contain; border-radius:18px; }
.rlt-achievement-card h3 { margin:0; font-size:19px; }
.rlt-achievement-card p { margin:0; color:#6b7280; min-height:44px; }
.rlt-achievement-card span { width:max-content; border-radius:999px; padding:7px 12px; font-size:12px; font-weight:900; background:#f3f4f6; color:#374151; }
.rlt-achievement-card.is-earned span { background:#dcfce7; color:#166534; }
.rlt-achievement-card small { color:#6b7280; font-weight:800; }
.rlt-certificate-card code { margin-top:12px; display:inline-flex; width:max-content; background:#f3f4f6; border-radius:999px; padding:7px 10px; color:#374151; }
.rlt-logout-card { text-align:left; }
@media (max-width:720px){ .rlt-profile-tabs { display:grid; grid-template-columns:1fr 1fr; } .rlt-profile-tab { justify-content:center; } }


/* Portal and course layout refinements - v0.1.7 */
body.rlt-standalone-portal #wpadminbar { display:none !important; }
body.rlt-standalone-portal { background:#f9fafb; }
.rlt-school-login-page { max-width:920px; margin:38px auto; padding:0 18px; font-family:Inter, Arial, sans-serif; color:#111827; }
.rlt-school-login-card { background:#fff; border:1px solid #e5e7eb; border-radius:28px; box-shadow:0 18px 55px rgba(17,24,39,.10); padding:34px; }
.rlt-school-login-brand { text-align:center; display:grid; justify-items:center; gap:10px; margin-bottom:22px; }
.rlt-school-login-logo { max-width:220px; max-height:130px; object-fit:contain; display:block; }
.rlt-school-login-logo-fallback { width:96px; height:96px; border-radius:28px; display:flex; align-items:center; justify-content:center; background:#fff3f6; color:var(--rlt-primary, #cc3553); font-size:46px; }
.rlt-school-login-brand h1 { margin:2px 0 0; font-size:clamp(28px,4vw,42px); line-height:1.1; letter-spacing:-.03em; }
.rlt-school-login-page .rlt-portal-shell { max-width:100%; margin:0; padding:0; }
.rlt-school-login-page .rlt-form-card { box-shadow:none; border:1px solid #edf0f4; border-radius:22px; max-width:560px; padding:26px; }
.rlt-school-login-page .rlt-login-card h2,
.rlt-school-login-page .rlt-login-card p { text-align:left; }
.rlt-school-login-page .rlt-profile-tabs { margin-top:20px; }

.rlt-course-landing-hero.rlt-udemy-hero { grid-template-columns:minmax(0,1fr) 310px; min-height:unset; padding:24px; gap:22px; align-items:center; margin-bottom:22px; }
.rlt-course-landing-hero .rlt-course-hero-copy { display:grid; align-content:center; min-height:280px; }
.rlt-course-landing-hero .rlt-back-link { margin-bottom:4px; }
.rlt-course-landing-hero h1 { font-size:clamp(30px,4.2vw,48px); margin:10px 0 8px; }
.rlt-course-landing-hero .rlt-course-hero-copy p { margin:0; max-width:620px; }
.rlt-course-hero-meta-clean { margin-top:14px; }
.rlt-course-hero-progress { max-width:460px; margin-top:14px; }
.rlt-course-landing-hero .rlt-course-hero-card { border-radius:24px; overflow:hidden; box-shadow:0 18px 48px rgba(17,24,39,.20); align-self:center; }
.rlt-course-landing-hero .rlt-course-hero-card .rlt-course-hero-thumb { min-height:150px; background-size:cover !important; background-position:center !important; }
.rlt-course-landing-hero .rlt-course-hero-card-body { padding:16px; }
.rlt-course-landing-hero .rlt-start-course-button { min-height:54px; border-radius:18px; width:100%; }
.rlt-course-landing-hero + .rlt-content-panel { margin-top:0; }
.rlt-course-thumb[style], .rlt-course-hero-thumb[style] { background-size:cover !important; background-position:center !important; }
@media (max-width:900px){
  .rlt-course-landing-hero.rlt-udemy-hero { grid-template-columns:1fr; }
  .rlt-course-landing-hero .rlt-course-hero-copy { min-height:auto; }
  .rlt-course-landing-hero .rlt-course-hero-card { max-width:420px; width:100%; }
}


/* Portal navigation and course hero fixes - v0.1.8 */
.rlt-course-landing-hero .rlt-course-hero-copy { justify-items:start; min-width:0; }
.rlt-course-landing-hero .rlt-course-hero-copy > .rlt-pill-light { width:max-content; max-width:100%; }
.rlt-course-landing-hero .rlt-course-hero-card { min-width:0; width:100%; box-sizing:border-box; }
.rlt-course-landing-hero .rlt-course-hero-card * { box-sizing:border-box; }
.rlt-course-landing-hero .rlt-start-course-button { width:100% !important; max-width:100%; box-sizing:border-box; padding-left:14px; padding-right:14px; white-space:normal; text-align:center; }
.rlt-course-landing-hero.rlt-udemy-hero { grid-template-columns:minmax(0,1fr) minmax(250px,310px); overflow:hidden; }
.rlt-course-landing-hero .rlt-course-hero-copy { min-height:230px; }
.rlt-course-landing-hero .rlt-course-hero-card .rlt-course-hero-thumb { min-height:130px; }
.rlt-course-landing-hero h1 { font-size:clamp(30px,3.8vw,44px); }
.rlt-course-hero-meta-clean span { white-space:nowrap; }

.rlt-school-portal-mode { max-width:1180px; }
.rlt-school-portal-topbar { display:flex; align-items:center; justify-content:space-between; gap:18px; background:#fff; border:1px solid #e5e7eb; border-radius:24px; padding:12px 14px; margin:0 0 24px; box-shadow:0 16px 45px rgba(17,24,39,.08); }
.rlt-school-portal-brand { display:flex; align-items:center; gap:12px; min-width:0; color:#111827; text-decoration:none !important; }
.rlt-school-portal-brand img { width:58px; height:58px; object-fit:contain; border-radius:16px; background:#fff; border:1px solid #edf0f4; padding:5px; flex:0 0 auto; }
.rlt-school-portal-brand strong { font-size:17px; line-height:1.15; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; max-width:280px; }
.rlt-school-portal-logo-fallback { width:58px; height:58px; border-radius:16px; background:#fff3f6; display:flex; align-items:center; justify-content:center; font-size:28px; }
.rlt-school-portal-menu { display:flex; flex-wrap:wrap; justify-content:flex-end; align-items:center; gap:8px; }
.rlt-school-portal-menu a { display:inline-flex; align-items:center; gap:7px; padding:10px 13px; border-radius:15px; color:#374151; text-decoration:none !important; font-weight:900; transition:all .18s ease; }
.rlt-school-portal-menu a:hover, .rlt-school-portal-menu a.is-active { background:linear-gradient(135deg, var(--rlt-primary, #cc3553), var(--rlt-primary-hover, #f0c3cc)); color:#fff !important; box-shadow:0 10px 24px rgba(204,53,83,.18); }
.rlt-school-portal-content .rlt-portal-shell { margin-top:0; margin-bottom:0; padding-left:0; padding-right:0; max-width:100%; }
.rlt-school-portal-content .rlt-student-profile-shell { max-width:100%; }
.rlt-school-portal-content .rlt-profile-tabs { display:none; }
.rlt-school-portal-footer { margin:28px auto 0; text-align:center; color:#6b7280; }
.rlt-rouyatok-footer-logo { font-family:Georgia, serif; font-size:30px; letter-spacing:.12em; color:#1f2b50; font-weight:700; margin-bottom:6px; }
.rlt-school-login-mode .rlt-school-portal-footer { max-width:920px; }
.rlt-school-portal-mode .rlt-school-login-brand { display:none; }

@media (max-width:900px){
  .rlt-school-portal-topbar { align-items:flex-start; flex-direction:column; }
  .rlt-school-portal-menu { justify-content:flex-start; width:100%; }
  .rlt-school-portal-brand strong { max-width:calc(100vw - 150px); }
}

/* Quiz runner and footer cleanup - v0.1.9 */
.rlt-ready-note { margin: 0 0 10px; color: #6b7280; font-size: 14px; }
.rlt-quiz-runner-header { display:flex; justify-content:space-between; align-items:flex-start; gap:18px; margin-bottom:16px; }
.rlt-quiz-timer { min-width:128px; text-align:center; padding:12px 14px; border-radius:18px; background:#fff3f6; color:var(--rlt-primary, #cc3553); border:1px solid var(--rlt-primary-hover, #f0c3cc); box-shadow:0 10px 24px rgba(204,53,83,.12); }
.rlt-quiz-timer small { display:block; font-size:11px; font-weight:900; text-transform:uppercase; letter-spacing:.04em; opacity:.8; }
.rlt-quiz-timer strong { display:block; font-size:22px; line-height:1.1; margin-top:4px; }
.rlt-quiz-timer.is-ending { background:#fff1f2; color:#be123c; border-color:#fecdd3; animation:rltPulseTimer 1s infinite; }
@keyframes rltPulseTimer { 0%,100%{transform:scale(1)} 50%{transform:scale(1.03)} }
.rlt-quiz-progress-head { display:grid; gap:10px; margin:20px 0; padding:16px; border:1px solid #e5e7eb; border-radius:18px; background:#f9fafb; }
.rlt-quiz-step-label { color:#111827; font-size:15px; }
.rlt-quiz-progress { max-width:100%; }
.rlt-quiz-step { display:none; }
.rlt-quiz-step.is-active { display:block; }
.rlt-quiz-runner-actions { display:flex; justify-content:space-between; align-items:center; gap:10px; margin-top:18px; }
.rlt-quiz-runner-actions .rlt-button[hidden] { display:none !important; }
.rlt-quiz-runner-actions .rlt-button:disabled { opacity:.45; cursor:not-allowed; box-shadow:none; }
.rlt-quiz-question-card { margin-bottom:0; }
.rlt-sidebar-subitems { margin-top:8px; display:grid; gap:8px; }
.rlt-sidebar-subitem { display:block; padding:10px 12px; border-radius:14px; border:1px solid #e5e7eb; background:#fff; color:#374151; text-decoration:none !important; font-weight:800; font-size:13px; }
.rlt-sidebar-subitem:hover, .rlt-sidebar-subitem.is-active { border-color:var(--rlt-primary-hover, #f0c3cc); background:#fff3f6; color:var(--rlt-primary, #cc3553); }
.rlt-sidebar-subitem.is-done { background:#ecfdf5; border-color:#bbf7d0; color:#166534; }
.rlt-sidebar-course-quizzes { margin-top:14px; }
.rlt-sidebar-course-quizzes h4 { margin:0 0 8px; font-size:14px; color:#6b7280; }
.rlt-school-portal-footer, .rlt-rouyatok-footer-logo { display:none !important; }
@media (max-width:720px){
  .rlt-quiz-runner-header { flex-direction:column; }
  .rlt-quiz-timer { width:100%; box-sizing:border-box; }
  .rlt-quiz-runner-actions { flex-direction:column; align-items:stretch; }
  .rlt-quiz-runner-actions .rlt-button { width:100%; }
}

/* Quiz result controls - v0.2.0 */
.rlt-quiz-result-actions { display:flex; flex-wrap:wrap; gap:12px; margin:18px 0 8px; align-items:center; }
.rlt-quiz-result-actions .rlt-button { text-decoration:none !important; }

/* v0.2.3 manager portal refinements */
.rlt-manager-portal-shell{display:block;}
.rlt-manager-tab-content{margin-top:22px;}
.rlt-manager-profile-card .rlt-profile-body{align-items:flex-end;}
.rlt-manager-stats-grid{margin-top:24px;}
.rlt-clickable-stat{text-decoration:none;color:inherit;transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease;}
.rlt-clickable-stat:hover{transform:translateY(-3px);border-color:var(--rlt-primary-hover);box-shadow:0 18px 45px rgba(15,23,42,.10);}
.rlt-manager-mini-stats{margin-bottom:22px;}
.rlt-manager-table-panel{overflow:auto;}
.rlt-front-table{width:100%;border-collapse:separate;border-spacing:0;border:1px solid #e5e7eb;border-radius:18px;overflow:hidden;background:#fff;}
.rlt-front-table th,.rlt-front-table td{padding:16px 18px;text-align:left;border-bottom:1px solid #edf0f4;vertical-align:middle;}
.rlt-front-table th{background:#f8fafc;color:#0f172a;font-weight:800;font-size:14px;}
.rlt-front-table tr:last-child td{border-bottom:0;}
.rlt-front-table code{background:#fff3f6;color:var(--rlt-primary);padding:4px 8px;border-radius:8px;}
.rlt-manager-tabs{margin-bottom:20px;}
.rlt-school-portal-menu a[href*="logout"]{white-space:nowrap;}
@media (max-width: 900px){
  .rlt-front-table th,.rlt-front-table td{padding:12px;font-size:14px;}
}

/* v0.2.4 profile editing and responsive profile refinements */
.rlt-profile-card { overflow: visible; }
.rlt-profile-banner { min-height: 210px; border-radius: 26px 26px 0 0; background-size: cover !important; background-position: center center !important; }
.rlt-profile-body { align-items: flex-start; margin-top: -66px; padding: 0 28px 24px; }
.rlt-profile-info { padding-top: 78px; min-width: 0; }
.rlt-profile-info h1 { word-break: break-word; line-height: 1.12; margin-top: 6px; }
.rlt-profile-actions { display:flex; flex-wrap:wrap; gap:10px; margin-top: 16px; }
.rlt-edit-profile-button { border:1px solid var(--rlt-primary-hover, #f0c3cc); color:var(--rlt-primary, #cc3553) !important; background:#fff !important; }
.rlt-edit-profile-button:hover { background:#fff3f6 !important; color:var(--rlt-primary, #cc3553) !important; }
.rlt-profile-edit-card { max-width: 100%; margin: 0 0 28px; }
.rlt-profile-edit-card h2 { display:flex; align-items:center; gap:8px; }
.rlt-edit-images-grid { display:grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap:18px; margin:14px 0 18px; }
.rlt-edit-image-field { border:1px solid #e5e7eb; border-radius:18px; padding:16px; background:#fafafa; display:grid; gap:10px; }
.rlt-edit-image-field strong { color:#111827; font-size:16px; }
.rlt-edit-image-field img { width:112px; height:112px; object-fit:cover; border-radius:24px; border:4px solid #fff; box-shadow:0 12px 28px rgba(17,24,39,.13); background:#fff; }
.rlt-edit-image-field img.is-banner { width:100%; height:126px; border-radius:18px; border:1px solid #e5e7eb; }
.rlt-edit-image-field input[type="file"] { padding:10px; background:#fff; border:1px dashed #cbd5e1; border-radius:14px; }
.rlt-edit-image-field small { color:#6b7280; line-height:1.5; }
.rlt-checkline { display:flex !important; align-items:center; gap:8px; margin:4px 0 0 !important; font-weight:700 !important; color:#374151 !important; }
.rlt-checkline input { width:auto !important; margin:0 !important; }
.rlt-profile-edit-actions { display:flex; flex-wrap:wrap; gap:12px; align-items:center; }
.rlt-profile-edit-actions .rlt-button { text-decoration:none !important; }
.rlt-manager-profile-card .rlt-profile-info { padding-top: 78px; }
.rlt-missions-grid { margin-top: 10px; }
@media (max-width: 720px) {
  .rlt-profile-banner { min-height: 160px; }
  .rlt-profile-body { margin-top: -52px; padding:0 18px 18px; gap:14px; }
  .rlt-profile-info { padding-top: 0; }
  .rlt-profile-body { flex-direction: row; align-items:flex-start; }
  .rlt-avatar { width:104px; height:104px; border-width:5px; }
  .rlt-profile-info h1 { font-size:26px; margin-top:8px; }
  .rlt-profile-info p { font-size:14px; }
  .rlt-badges-row { padding:0 18px 22px; }
  .rlt-edit-images-grid { grid-template-columns:1fr; }
}
@media (max-width: 540px) {
  .rlt-profile-body { flex-direction:column; margin-top:-48px; }
  .rlt-profile-info { padding-top:0; }
  .rlt-profile-actions .rlt-button { width:100%; }
}


/* v0.2.5 profile banner image fix */
.rlt-profile-banner[style*="background-image"] { background-size: cover !important; background-position: center center !important; background-repeat:no-repeat !important; }

/* v0.2.6 learning paths */
.rlt-path-list{display:grid;gap:26px;margin-top:18px;}
.rlt-path-card{background:#fff;border:1px solid #eef0f4;border-radius:28px;padding:22px;box-shadow:0 16px 40px rgba(15,23,42,.07);}
.rlt-path-card.is-complete{border-color:#bbf7d0;}
.rlt-path-card.is-locked{opacity:.76;background:#f8fafc;}
.rlt-path-header{display:flex;gap:20px;justify-content:space-between;align-items:stretch;margin-bottom:18px;}
.rlt-path-title-wrap{min-width:0;flex:1;}
.rlt-path-title-wrap h3{font-size:28px;line-height:1.15;margin:8px 0;color:#111827;}
.rlt-path-title-wrap p{margin:0 0 14px;color:#64748b;line-height:1.65;}
.rlt-path-thumb{width:220px;min-height:150px;border-radius:24px;background-size:cover;background-position:center;box-shadow:inset 0 0 0 1px rgba(255,255,255,.5);}
.rlt-path-card .rlt-course-grid{margin-top:18px;}
.rlt-course-card.is-locked{cursor:not-allowed;filter:grayscale(.15);}
.rlt-course-card.is-locked:hover{transform:none;box-shadow:0 10px 30px rgba(15,23,42,.06);}
.rlt-locked-note{margin-top:12px;border:1px dashed #cbd5e1;background:#f8fafc;color:#475569;border-radius:14px;padding:10px 12px;font-weight:700;font-size:13px;}
.rlt-path-success{margin:12px 0 0;padding:10px 12px;}
@media (max-width: 820px){
  .rlt-path-header{flex-direction:column;}
  .rlt-path-thumb{width:100%;min-height:180px;}
  .rlt-path-title-wrap h3{font-size:24px;}
}

.rlt-language-switcher{display:inline-flex;align-items:center;gap:4px;margin-left:10px;padding:5px;background:#f8fafc;border-radius:999px;border:1px solid #e5e7eb;white-space:nowrap}.rlt-language-link{display:inline-flex;align-items:center;padding:6px 10px;border-radius:999px;text-decoration:none;font-weight:800;color:#334155}.rlt-language-link.is-active{background:var(--rlt-primary,#cc3553);color:#fff}.rtl .rlt-language-switcher{margin-left:0;margin-right:10px}.rlt-flat-course-section .rlt-course-grid{margin-top:16px}

/* Portal header compact brand and sectioned curriculum - v0.2.8 */
.rlt-school-portal-brand{flex-direction:column;align-items:center;justify-content:center;gap:5px;flex:0 0 96px;text-align:center}.rlt-school-portal-brand img{width:54px;height:54px}.rlt-school-portal-brand-text{display:block;max-width:96px}.rlt-school-portal-brand strong{display:block;font-size:11px!important;line-height:1.15;max-width:96px!important;white-space:normal!important;text-align:center;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.rlt-school-portal-topbar{align-items:center}.rlt-school-portal-menu{flex:1;min-width:0}.rlt-school-portal-menu a{padding:9px 11px}.rlt-curriculum-section-title{margin:14px 0 8px;padding:8px 12px;border-radius:14px;background:#f8fafc;color:#374151;font-weight:900;border:1px solid #e5e7eb}.rlt-sidebar-section-title{margin:14px 0 8px;font-size:13px;color:#6b7280;text-transform:uppercase;letter-spacing:.04em}.rlt-sidebar-sequence-quiz{margin:0 0 8px}.rtl .rlt-school-portal-brand{margin-left:4px;margin-right:0}@media(max-width:900px){.rlt-school-portal-brand{flex-direction:row;flex-basis:auto}.rlt-school-portal-brand strong{font-size:13px!important;max-width:calc(100vw - 150px)!important;-webkit-line-clamp:1}}

/* Question interaction updates - v0.2.9 */
.rlt-options-list.is-multiple label,
.rlt-image-choice-grid.is-multiple .rlt-image-choice{cursor:pointer}
.rlt-sorting-answer-list{list-style:none;margin:18px 0;padding:0;display:grid;gap:10px;max-width:760px}
.rlt-sorting-answer-list li{display:grid;grid-template-columns:42px minmax(0,1fr);align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:14px;box-shadow:0 8px 22px rgba(15,23,42,.06);overflow:hidden;cursor:grab}
.rlt-sorting-answer-list li.is-dragging{opacity:.65}
.rlt-sorting-answer-list .rlt-drag-handle{display:flex;align-items:center;justify-content:center;min-height:50px;background:#f1f5f9;color:#64748b;font-weight:900}
.rlt-sorting-answer-list strong{padding:14px 16px;font-size:16px;color:#111827}
.rlt-small-hint{font-size:13px;color:#64748b;margin-top:8px}
.rtl .rlt-sorting-answer-list li{grid-template-columns:42px minmax(0,1fr)}

/* v0.3.2 skill completion summary */
.rlt-skills-summary-card{margin-top:22px}
.rlt-skills-summary-list{display:grid;gap:10px;margin-top:14px}
.rlt-skill-summary-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:10px;align-items:center;text-decoration:none!important;color:#111827;background:#fff;border:1px solid #e5e7eb;border-radius:16px;padding:14px 16px;box-shadow:0 10px 26px rgba(15,23,42,.05)}
.rlt-skill-summary-row:hover{border-color:#f2b6c2;box-shadow:0 14px 32px rgba(204,53,83,.08)}
.rlt-skill-course-title{font-weight:900;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.rlt-skill-count{font-weight:800;color:#64748b;white-space:nowrap}
.rlt-skill-summary-row .rlt-progress{grid-column:1/-1;height:8px;margin-top:2px}
.rtl .rlt-skill-summary-row{direction:rtl}
@media(max-width:640px){.rlt-skill-summary-row{grid-template-columns:1fr}.rlt-skill-count{white-space:normal}}

/* Image matching drag UI - v0.3.3 */
.rlt-match-drag-builder{display:grid;gap:18px;margin:18px 0}
.rlt-match-right-bank p{margin:6px 0 12px;color:#64748b;font-weight:700}
.rlt-match-bank-items{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:12px;margin-top:10px}
.rlt-match-bank-item{display:grid;gap:8px;border:1px solid #e5e7eb;background:#fff;border-radius:14px;padding:8px;cursor:grab;text-align:center;font-weight:900;color:#334155;box-shadow:0 8px 18px rgba(15,23,42,.05)}
.rlt-match-bank-item:hover,.rlt-match-bank-item.is-selected{border-color:var(--rlt-primary,#cc3553);box-shadow:0 10px 22px rgba(204,53,83,.12)}
.rlt-match-bank-item.is-used{opacity:.48}
.rlt-match-bank-item img{width:100%;aspect-ratio:4/3;object-fit:cover;border-radius:10px;background:#fff}
.rlt-match-left-list{display:grid;gap:12px}
.rlt-match-answer-row{grid-template-columns:180px minmax(0,1fr)}
.rlt-match-left-image{width:100%;aspect-ratio:4/3;object-fit:cover;border-radius:12px;border:1px solid #e5e7eb;background:#fff}
.rlt-match-dropzone{min-height:132px;border:2px dashed #cbd5e1;border-radius:16px;background:#f8fafc;display:flex;align-items:center;justify-content:center;padding:10px;transition:border-color .15s ease,background .15s ease}
.rlt-match-dropzone.is-over{border-color:var(--rlt-primary,#cc3553);background:#fff3f6}
.rlt-match-placeholder{font-weight:900;color:#64748b;text-align:center}
.rlt-match-selected{position:relative;display:grid;grid-template-columns:110px minmax(0,1fr) 34px;gap:10px;align-items:center;width:100%;background:#fff;border:1px solid #e5e7eb;border-radius:14px;padding:8px;box-shadow:0 8px 18px rgba(15,23,42,.05)}
.rlt-match-selected img{width:110px;aspect-ratio:4/3;object-fit:cover;border-radius:10px;background:#fff}
.rlt-match-selected span{font-weight:900;color:#334155}
.rlt-clear-match{width:30px;height:30px;border:0;border-radius:999px;background:#fee2e2;color:#991b1b;font-size:18px;font-weight:900;cursor:pointer}
.rtl .rlt-match-selected{grid-template-columns:34px minmax(0,1fr) 110px}.rtl .rlt-clear-match{grid-column:1}.rtl .rlt-match-selected span{grid-column:2}.rtl .rlt-match-selected img{grid-column:3;grid-row:1}
@media(max-width:720px){.rlt-match-answer-row{grid-template-columns:1fr}.rlt-match-selected{grid-template-columns:90px minmax(0,1fr) 34px}.rlt-match-selected img{width:90px}}

/* v0.3.4 frontend login and reports */
.rlt-login-form .rlt-remember-line { margin:10px 0 14px !important; }
.rlt-panel-actions { display:flex; justify-content:flex-end; gap:10px; margin-bottom:16px; }
.rlt-report-panel h3 { margin:0 0 14px; }

/* v0.3.6 AI Journal + first-login profile onboarding */
.rlt-ai-journal-card,.rlt-ai-onboarding-card{position:relative;overflow:hidden;border:1px solid #f4d3db;background:linear-gradient(135deg,#fff 0%,#fff7fa 100%)}
.rlt-ai-journal-card:before,.rlt-ai-onboarding-card:before{content:"";position:absolute;inset:0 0 auto auto;width:160px;height:160px;background:radial-gradient(circle,rgba(204,53,83,.12),transparent 68%);pointer-events:none}
.rlt-ai-journal-prompt{margin:14px 0;padding:14px 16px;border-radius:16px;background:#fff;border:1px solid #f3d5dc;color:#374151;line-height:1.55}
.rlt-ai-journal-form textarea,.rlt-ai-onboarding-form textarea{width:100%;border:1px solid #e5e7eb;border-radius:16px;padding:14px 16px;background:#fff;box-shadow:inset 0 1px 2px rgba(15,23,42,.03);font-size:15px;line-height:1.6}
.rlt-ai-actions{display:flex;flex-wrap:wrap;gap:10px;margin:14px 0 0;align-items:center}
.rlt-ai-response{margin:18px 0 0;padding:18px;border-radius:18px;background:#fff;border:1px solid #f3d5dc;color:#1f2937;font-weight:700;line-height:1.75;white-space:pre-wrap;box-shadow:0 10px 26px rgba(204,53,83,.08)}
.rlt-ai-status{min-height:24px;margin-top:12px;font-weight:800;color:#166534}.rlt-ai-status.is-error{color:#b91c1c}
.rlt-journal-history{margin-top:22px;display:grid;gap:12px}.rlt-journal-history h3{margin:0;color:#111827}.rlt-journal-entry{padding:14px 16px;border:1px solid #e5e7eb;border-radius:16px;background:#fff}.rlt-journal-entry small{display:block;color:#64748b;font-weight:800;margin-bottom:6px}.rlt-journal-entry p{margin:0 0 8px}.rlt-journal-entry blockquote{margin:0;padding:10px 12px;border-inline-start:4px solid var(--rlt-primary,#cc3553);background:#fff7fa;border-radius:12px;color:#374151}
.rlt-onboarding-grid{margin:10px 0 16px}.rlt-avatar-template-picker{margin:18px 0;padding:16px;border-radius:18px;background:#fff;border:1px solid #f3d5dc}.rlt-avatar-template-picker>strong{display:block;margin-bottom:12px;color:#111827}.rlt-avatar-template-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px}.rlt-avatar-template{display:grid;gap:8px;text-align:center;padding:10px;border:2px solid #e5e7eb;border-radius:18px;background:#fff;cursor:pointer;font-weight:900;color:#374151;transition:border-color .15s ease,box-shadow .15s ease,transform .15s ease}.rlt-avatar-template:hover{border-color:var(--rlt-primary,#cc3553);box-shadow:0 10px 26px rgba(204,53,83,.12);transform:translateY(-2px)}.rlt-avatar-template input{position:absolute;opacity:0;pointer-events:none}.rlt-avatar-template:has(input:checked){border-color:var(--rlt-primary,#cc3553);box-shadow:0 10px 26px rgba(204,53,83,.16);background:#fff7fa}.rlt-avatar-template img{width:86px;height:86px;margin:0 auto;border-radius:50%;background:#fff;object-fit:cover;border:4px solid #fff;box-shadow:0 8px 18px rgba(15,23,42,.10)}.rlt-avatar-template-picker small{display:block;margin-top:12px;color:#64748b;font-weight:700}.rlt-ai-onboarding-card.is-saved{border-color:#bbf7d0;background:#f0fdf4}
.rtl .rlt-ai-response,.rtl .rlt-journal-entry blockquote{direction:rtl;text-align:right}
@media(max-width:640px){.rlt-ai-actions .rlt-button{width:100%;justify-content:center}.rlt-avatar-template-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}

/* v0.3.8 AI onboarding guide + generated avatars */
.rlt-onboarding-header{position:relative;z-index:1;margin-bottom:16px}.rlt-onboarding-badge{display:inline-flex;align-items:center;padding:6px 12px;border-radius:999px;background:#fff;border:1px solid #f3d5dc;color:var(--rlt-primary,#cc3553);font-weight:900;font-size:13px;margin-bottom:8px}.rlt-onboarding-steps{display:flex;flex-wrap:wrap;gap:10px;margin:10px 0 18px}.rlt-onboarding-steps span{display:inline-flex;align-items:center;gap:6px;border:1px solid #f3d5dc;background:#fff;border-radius:999px;padding:8px 12px;font-weight:900;color:#374151}.rlt-ai-guide-box{display:flex;justify-content:space-between;align-items:center;gap:16px;margin:18px 0;padding:16px;border-radius:18px;border:1px solid #e0f2fe;background:linear-gradient(135deg,#f0f9ff,#fff)}.rlt-ai-guide-box p{margin:4px 0 0;color:#64748b;font-weight:700}.rlt-ai-guide-response{margin:14px 0;padding:16px 18px;border-radius:18px;background:#fff;border:1px solid #bae6fd;color:#0f172a;line-height:1.75;white-space:pre-wrap;font-weight:800;box-shadow:0 10px 24px rgba(14,165,233,.08)}.rlt-text-avatar-generator{margin:18px 0;padding:16px;border-radius:18px;background:#fff;border:1px solid #f3d5dc}.rlt-text-avatar-generator>strong{display:block;margin-bottom:6px;color:#111827}.rlt-text-avatar-generator p{margin:0 0 10px;color:#64748b;font-weight:700}.rlt-text-avatar-generator textarea{width:100%;border:1px solid #e5e7eb;border-radius:16px;padding:14px 16px;background:#fff;line-height:1.6}.rlt-generated-avatar-preview{display:flex;align-items:center;gap:14px;margin-top:14px;padding:12px;border-radius:18px;background:#f8fafc;border:1px dashed #cbd5e1;color:#374151;font-weight:900}.rlt-generated-avatar-preview img{width:96px;height:96px;border-radius:50%;object-fit:cover;background:#fff;box-shadow:0 8px 18px rgba(15,23,42,.12)}.rlt-generated-avatar-preview[hidden]{display:none}.rlt-ai-privacy-note{margin:14px 0;padding:12px 14px;border-radius:14px;background:#fffbeb;border:1px solid #fde68a;color:#92400e;font-weight:800}.rlt-profile-extra{display:grid;gap:6px;margin:12px 0;padding:12px 14px;border-radius:16px;background:#fff;border:1px solid #eef2f7;color:#475569;font-weight:700}.rlt-profile-extra span{display:block}.rlt-profile-extra strong{color:#0f172a}.rtl .rlt-ai-guide-response,.rtl .rlt-ai-guide-box,.rtl .rlt-text-avatar-generator,.rtl .rlt-generated-avatar-preview,.rtl .rlt-profile-extra{direction:rtl;text-align:right}@media(max-width:680px){.rlt-ai-guide-box{display:block}.rlt-ai-guide-box .rlt-button{width:100%;margin-top:12px;justify-content:center}.rlt-generated-avatar-preview{align-items:flex-start}.rlt-onboarding-steps span{width:100%;justify-content:center}}


/* v0.3.9 creative personality picker + richer 3D avatar cards */
.rlt-section-title-line{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:12px}
.rlt-section-title-line strong{font-size:18px;color:#111827}.rlt-section-title-line small{max-width:520px;color:#64748b;font-weight:800;line-height:1.5}
.rlt-personality-picker{margin:18px 0;padding:18px;border-radius:22px;background:linear-gradient(135deg,#fff,#fff7fb);border:1px solid #f3d5dc;box-shadow:0 14px 34px rgba(15,23,42,.04)}
.rlt-personality-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:12px}
.rlt-personality-card{position:relative;display:grid;gap:7px;align-content:start;min-height:142px;padding:16px;border-radius:22px;border:2px solid #e5e7eb;background:linear-gradient(135deg,#fff,#f8fafc);cursor:pointer;overflow:hidden;transition:transform .15s ease,border-color .15s ease,box-shadow .15s ease}
.rlt-personality-card:before{content:"";position:absolute;inset:auto -30px -44px auto;width:116px;height:116px;border-radius:50%;background:radial-gradient(circle,rgba(204,53,83,.14),transparent 70%)}
.rlt-personality-card:hover{transform:translateY(-3px);border-color:var(--rlt-primary,#cc3553);box-shadow:0 16px 34px rgba(204,53,83,.12)}
.rlt-personality-card input{position:absolute;opacity:0;pointer-events:none}.rlt-personality-card:has(input:checked){border-color:var(--rlt-primary,#cc3553);background:linear-gradient(135deg,#fff7fa,#fff);box-shadow:0 16px 34px rgba(204,53,83,.16)}
.rlt-personality-icon{position:relative;z-index:1;display:grid;place-items:center;width:46px;height:46px;border-radius:16px;background:#fff;box-shadow:0 10px 22px rgba(15,23,42,.10);font-size:24px}.rlt-personality-label{position:relative;z-index:1;font-weight:1000;color:#111827;font-size:16px}.rlt-personality-card small{position:relative;z-index:1;color:#64748b;font-weight:800;line-height:1.45}
.rlt-avatar-template-picker{background:linear-gradient(135deg,#fff,#f9fafb)}.rlt-avatar-template-grid{grid-template-columns:repeat(auto-fill,minmax(155px,1fr));gap:14px}.rlt-avatar-template{border-radius:24px;background:linear-gradient(145deg,#fff,#f8fafc);padding:14px;box-shadow:0 10px 26px rgba(15,23,42,.04)}
.rlt-avatar-template:after{content:"3D";position:absolute;top:10px;inset-inline-end:10px;font-size:11px;font-weight:1000;color:var(--rlt-primary,#cc3553);background:#fff0f4;border-radius:999px;padding:3px 7px}.rlt-avatar-template img{width:104px;height:104px;box-shadow:0 16px 30px rgba(15,23,42,.16);border:5px solid #fff}.rlt-avatar-template span{font-size:13px;line-height:1.35;color:#111827}
.rtl .rlt-section-title-line{direction:rtl;text-align:right}@media(max-width:680px){.rlt-section-title-line{display:block}.rlt-personality-grid{grid-template-columns:1fr}.rlt-avatar-template-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}

/* v0.4.0 premium 3D avatar upgrade */
.rlt-avatar-template-picker{margin:22px 0;padding:22px;border-radius:28px;background:linear-gradient(180deg,#ffffff 0%,#f8f9ff 100%);border:1px solid #ebeafe;box-shadow:0 20px 60px rgba(17,24,39,.06)}
.rlt-avatar-template-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:18px}
.rlt-avatar-template{position:relative;display:grid;align-content:start;gap:12px;padding:16px 14px 18px;border:1px solid #e8eaf3;border-radius:28px;background:linear-gradient(180deg,#ffffff 0%,#fbfbfe 100%);box-shadow:0 14px 40px rgba(15,23,42,.06);transition:transform .18s ease,border-color .18s ease,box-shadow .18s ease,background .18s ease;overflow:hidden}
.rlt-avatar-template:hover{transform:translateY(-3px);border-color:#c7bfff;box-shadow:0 18px 48px rgba(99,102,241,.14)}
.rlt-avatar-template input{position:absolute;opacity:0;pointer-events:none}
.rlt-avatar-template img{width:132px;height:132px;margin:0 auto;border-radius:50%;border:6px solid rgba(255,255,255,.95);object-fit:cover;background:#fff;box-shadow:0 18px 36px rgba(15,23,42,.14)}
.rlt-avatar-template .rlt-avatar-template-label{display:block;text-align:center;font-size:14px;line-height:1.35;font-weight:900;color:#182235}
.rlt-avatar-template:after{content:"3D";position:absolute;top:12px;inset-inline-end:12px;padding:4px 8px;border-radius:999px;background:#eef2ff;color:#6d5dfc;font-size:11px;font-weight:1000;letter-spacing:.03em;box-shadow:0 6px 14px rgba(109,93,252,.12)}
.rlt-avatar-template.is-recommended{border-color:#b9b1ff;background:linear-gradient(180deg,#f9f7ff 0%,#ffffff 100%);box-shadow:0 18px 48px rgba(99,102,241,.16)}
.rlt-avatar-template.is-recommended:not(:has(input:checked))::before{content:"★";position:absolute;top:12px;inset-inline-start:12px;padding:4px 8px;border-radius:999px;background:#f5f3ff;color:#7c3aed;font-size:11px;font-weight:1000;z-index:1}
.rlt-avatar-template:has(input:checked){border-color:#8b5cf6;background:linear-gradient(180deg,#faf7ff 0%,#ffffff 100%);box-shadow:0 20px 50px rgba(139,92,246,.22);transform:translateY(-2px)}
.rlt-avatar-template:has(input:checked)::before{content:"✓";position:absolute;top:12px;inset-inline-start:12px;width:30px;height:30px;border-radius:50%;display:grid;place-items:center;background:linear-gradient(135deg,#8b5cf6,#5b7cff);color:#fff;font-size:18px;font-weight:1000;box-shadow:0 10px 20px rgba(91,124,255,.25);z-index:2}
.rlt-avatar-template-picker small{margin-top:14px;color:#667085;font-weight:800}
.rlt-section-title-line{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:14px}
.rlt-section-title-line strong{font-size:22px;line-height:1.2}
.rlt-section-title-line small{font-size:14px;line-height:1.6;max-width:560px}
.rlt-personality-picker{padding:22px;border-radius:28px;background:linear-gradient(180deg,#ffffff 0%,#fff7fb 100%);border:1px solid #f2d7e4;box-shadow:0 18px 50px rgba(17,24,39,.05)}
.rlt-personality-grid{grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:14px}
.rlt-personality-card{min-height:152px;border-radius:24px;padding:18px;background:linear-gradient(180deg,#ffffff 0%,#fbfbfe 100%);box-shadow:0 12px 30px rgba(15,23,42,.05)}
.rlt-personality-card:has(input:checked){border-color:#8b5cf6;background:linear-gradient(180deg,#fbf8ff 0%,#ffffff 100%);box-shadow:0 18px 40px rgba(139,92,246,.14)}
.rlt-personality-icon{width:52px;height:52px;border-radius:18px;background:linear-gradient(135deg,#ffffff,#f6f5ff)}
@media(max-width:680px){.rlt-avatar-template-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.rlt-avatar-template{padding:14px 10px 16px;border-radius:22px}.rlt-avatar-template img{width:104px;height:104px}.rlt-section-title-line{display:block}.rlt-section-title-line small{display:block;margin-top:6px}}


/* v0.4.1 onboarding/avatar polish */
.rlt-ai-onboarding-card{position:relative;overflow:hidden}
.rlt-ai-onboarding-card:before{content:"";position:absolute;inset:-120px -120px auto auto;width:320px;height:320px;border-radius:50%;background:radial-gradient(circle,rgba(139,92,246,.11),transparent 70%);pointer-events:none}
.rlt-onboarding-header h2{font-size:clamp(28px,4vw,48px);line-height:1.05;margin-bottom:8px}
.rlt-onboarding-badge{box-shadow:0 10px 25px rgba(139,92,246,.08)}
.rlt-avatar-premium-note{display:flex;align-items:center;gap:12px;margin:4px 0 16px;padding:12px 14px;border-radius:18px;background:linear-gradient(135deg,#f8f7ff,#ffffff);border:1px solid #e9e5ff;color:#344054}
.rlt-avatar-premium-note span{display:grid;place-items:center;width:34px;height:34px;border-radius:12px;background:#fff;box-shadow:0 8px 18px rgba(15,23,42,.08)}
.rlt-avatar-premium-note strong{font-weight:1000;color:#111827}
.rlt-avatar-premium-note small{display:block;margin:2px 0 0;color:#667085;font-weight:800;line-height:1.45}
.rlt-avatar-template{min-height:210px}
.rlt-avatar-template[hidden]{display:none!important}
.rlt-avatar-template img{transition:transform .2s ease,filter .2s ease}
.rlt-avatar-template:hover img,.rlt-avatar-template:has(input:checked) img{transform:scale(1.035);filter:saturate(1.04) contrast(1.02)}
.rlt-avatar-template.is-recommended:not(:has(input:checked)){animation:rltAvatarPulse 1.8s ease-in-out infinite}
@keyframes rltAvatarPulse{0%,100%{box-shadow:0 18px 48px rgba(99,102,241,.12)}50%{box-shadow:0 18px 54px rgba(139,92,246,.24)}}
.rtl .rlt-avatar-premium-note{direction:rtl;text-align:right}
@media(max-width:680px){.rlt-avatar-premium-note{align-items:flex-start}.rlt-avatar-premium-note span{flex:0 0 auto}.rlt-avatar-template{min-height:178px}}


/* v0.4.2 AI guide custom input + avatar clarity */
.rlt-ai-guide-box{display:grid;gap:14px;padding:18px 20px;border-radius:22px;border:1px solid #d8eefc;background:linear-gradient(135deg,#f8fcff,#ffffff)}
.rlt-ai-guide-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.rlt-ai-guide-head strong{display:block;margin-bottom:4px;font-size:20px;color:#0f172a}.rlt-ai-guide-head p{margin:0;color:#64748b;font-weight:800;line-height:1.6}
.rlt-ai-guide-input-wrap{display:grid;gap:8px}.rlt-ai-guide-input-wrap>span{font-weight:900;color:#111827}.rlt-ai-guide-input-wrap textarea{min-height:96px;background:#fff;border:1px solid #dbe4f0;border-radius:18px;padding:14px 16px;line-height:1.65;resize:vertical}
.rlt-ai-guide-counter{display:flex;justify-content:flex-end;gap:10px;color:#667085;font-weight:800}
.rlt-ai-guide-response{background:linear-gradient(180deg,#ffffff,#fcfdff);border:1px solid #c8e6ff;box-shadow:0 12px 30px rgba(56,189,248,.08)}
.rlt-avatar-template{padding-top:26px}
.rlt-avatar-template img{object-position:center center}
.rlt-avatar-template:has(input:checked) img{transform:scale(1.045)}
.rlt-avatar-badge{position:absolute;top:18px;left:50%;transform:translateX(-50%);z-index:3;display:grid;place-items:center;width:34px;height:34px;border-radius:50%;background:#fff;box-shadow:0 10px 22px rgba(15,23,42,.14);font-size:18px;border:1px solid #eef2ff}
.rlt-avatar-template:has(input:checked) .rlt-avatar-badge{box-shadow:0 12px 26px rgba(91,124,255,.22);transform:translateX(-50%) translateY(-1px) scale(1.04)}
.rlt-avatar-template img{background:radial-gradient(circle at 50% 35%,#ffffff 0%,#f3f4ff 62%,#eef1f7 100%)}
.rlt-avatar-template::marker{display:none}
.rtl .rlt-ai-guide-head,.rtl .rlt-ai-guide-input-wrap,.rtl .rlt-ai-guide-counter{direction:rtl;text-align:right}
@media(max-width:680px){.rlt-ai-guide-head{display:block}.rlt-ai-guide-head .rlt-button{width:100%;margin-top:12px}.rlt-ai-guide-counter{justify-content:flex-start;flex-wrap:wrap}}


/* v0.4.3 onboarding layout and avatar positioning */
.rlt-onboarding-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px 22px;margin:18px 0 18px!important;align-items:start}
.rlt-onboarding-field{display:grid;gap:8px;align-content:start;margin:0!important}
.rlt-onboarding-field-full{display:grid;gap:8px;margin:2px 0 18px!important}
.rlt-field-label{display:block;font-size:15px;font-weight:900;color:#111827;line-height:1.3}
.rlt-onboarding-field input,.rlt-onboarding-field select,.rlt-onboarding-field-full textarea{width:100%;min-height:56px;border-radius:16px;border:1px solid #dbe4f0;background:#fff;padding:14px 16px;font-size:16px;line-height:1.45;box-shadow:inset 0 1px 2px rgba(15,23,42,.03)}
.rlt-onboarding-field-full textarea{min-height:120px}
.rlt-onboarding-grid .rlt-onboarding-field:nth-child(1),.rlt-onboarding-grid .rlt-onboarding-field:nth-child(2){grid-row:1}
.rlt-onboarding-grid .rlt-onboarding-field:nth-child(3),.rlt-onboarding-grid .rlt-onboarding-field:nth-child(4){grid-row:2}
.rlt-ai-onboarding-card .rlt-onboarding-header{max-width:980px}
.rlt-ai-onboarding-card .rlt-onboarding-header p{max-width:980px;font-size:18px;line-height:1.6}
.rlt-onboarding-steps{display:flex;flex-wrap:wrap;gap:14px;margin:18px 0 10px}
.rlt-onboarding-steps span{padding:14px 22px;border-radius:999px;background:#fff;border:1px solid #f0c9d6;font-size:18px;font-weight:900;color:#344054}
.rlt-avatar-template{padding:18px 14px 20px!important}
.rlt-avatar-visual{position:relative;display:grid;place-items:center;width:156px;height:156px;margin:0 auto 8px}
.rlt-avatar-template img{width:156px!important;height:156px!important;object-fit:cover;object-position:center center;border-radius:50%;border:6px solid rgba(255,255,255,.96);box-shadow:0 18px 36px rgba(15,23,42,.14);background:radial-gradient(circle at 50% 35%,#ffffff 0%,#f3f4ff 62%,#eef1f7 100%)!important}
.rlt-avatar-badge{position:absolute!important;right:2px;bottom:6px;left:auto!important;top:auto!important;transform:none!important;z-index:4;display:grid;place-items:center;width:38px;height:38px;border-radius:50%;background:#fff;box-shadow:0 10px 22px rgba(15,23,42,.16);font-size:19px;border:1px solid #e6ebff}
.rtl .rlt-avatar-badge{left:2px;right:auto}
.rlt-avatar-template:has(input:checked) .rlt-avatar-badge{transform:scale(1.05)!important;box-shadow:0 12px 26px rgba(91,124,255,.24)}
.rlt-avatar-template .rlt-avatar-template-label{font-size:13px;line-height:1.35;max-width:170px;margin:0 auto}
.rlt-avatar-template.is-recommended:not(:has(input:checked))::before{top:10px}
@media(max-width:980px){.rlt-onboarding-grid{grid-template-columns:1fr 1fr}.rlt-onboarding-steps span{font-size:16px;padding:12px 18px}}
@media(max-width:680px){.rlt-onboarding-grid{grid-template-columns:1fr;gap:14px}.rlt-onboarding-steps span{width:auto}.rlt-avatar-visual{width:126px;height:126px}.rlt-avatar-template img{width:126px!important;height:126px!important}.rlt-avatar-badge{width:34px;height:34px;font-size:17px}}


/* v0.4.6 photo avatar onboarding */
.rlt-photo-avatar-box{background:#f8fbff;border:1px solid #d9e8ff;border-radius:24px;padding:20px 22px;margin:20px 0}
.rlt-photo-avatar-notice{background:#fff;border:1px dashed #c7dafd;color:#41516b;padding:12px 14px;border-radius:16px;margin:10px 0 16px;font-size:14px;line-height:1.6}
.rlt-photo-upload-field{display:grid;gap:8px;margin:0 0 8px}
.rlt-photo-upload-field input[type=file]{padding:12px;border:1px solid #dbe4f0;border-radius:16px;background:#fff}
.rlt-photo-preview{display:flex;gap:14px;align-items:center;background:#fff;border:1px solid #e9eef7;border-radius:18px;padding:12px 14px;margin-top:14px}
.rlt-photo-preview img{width:84px;height:84px;object-fit:cover;border-radius:18px;border:1px solid #dce5f5;box-shadow:0 8px 20px rgba(15,23,42,.08)}
.rlt-photo-preview span{font-size:14px;color:#4b5563;line-height:1.6}
@media(max-width:680px){.rlt-photo-preview{flex-direction:column;align-items:flex-start}.rlt-photo-preview img{width:100px;height:100px}}


/* v0.4.8 AI profile editor access */
.rlt-ai-onboarding-card.is-edit-mode{border-color:#d7e4ff;background:linear-gradient(180deg,#ffffff 0%,#f9fbff 100%)}
.rlt-profile-actions{display:flex;gap:12px;flex-wrap:wrap;align-items:center}

/* v0.4.11 manager actions */
.rlt-button-small{font-size:12px!important;padding:7px 10px!important;line-height:1.1!important}.rlt-button-danger{background:#b42318!important;color:#fff!important;border-color:#b42318!important}.rlt-alert{padding:12px 16px;border-radius:14px;margin:12px 0;font-weight:800}.rlt-alert-success{background:#ecfdf3;color:#027a48;border:1px solid #abefc6}.rlt-alert-error{background:#fef3f2;color:#b42318;border:1px solid #fecdca}


/* v0.4.13 first-use tips and floating AI journal */
.rlt-first-tips{position:fixed;inset:0;background:rgba(15,23,42,.58);z-index:9999;display:grid;place-items:center;padding:20px}
.rlt-first-tips-box{position:relative;width:min(560px,94vw);background:#fff;border-radius:28px;padding:28px;box-shadow:0 24px 80px rgba(15,23,42,.25);border:1px solid #f0d3dc}
.rlt-first-tips-close{position:absolute;top:14px;inset-inline-end:14px;border:0;background:#f8eef2;color:#912d48;border-radius:50%;width:34px;height:34px;font-size:22px;cursor:pointer}
.rlt-tip-step{display:none}.rlt-tip-step.is-active{display:block}.rlt-tip-step strong{font-size:24px;display:block;margin-bottom:10px;color:#111827}.rlt-tip-step p{font-size:16px;line-height:1.7;color:#475467}
.rlt-first-tips-actions{display:flex;justify-content:space-between;gap:12px;margin-top:22px}.rlt-first-tips-actions .rlt-button{min-width:120px;text-align:center}
.rlt-ai-floating-journal{position:fixed;right:22px;bottom:22px;width:58px;height:58px;border-radius:50%;display:grid;place-items:center;background:linear-gradient(135deg,#cc3553,#8b5cf6);color:#fff;text-decoration:none;font-size:28px;box-shadow:0 18px 40px rgba(139,92,246,.28);z-index:900}
.rtl .rlt-ai-floating-journal{right:auto;left:22px}
.rlt-ai-floating-journal:hover{transform:translateY(-2px);color:#fff}

/* v0.4.15 student import/export + role tips lamp */
.rlt-student-import-export-bar{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin:18px 0;padding:16px 18px;border:1px solid #e7edf6;border-radius:22px;background:#fff;box-shadow:0 14px 34px rgba(15,23,42,.05)}
.rlt-student-import-export-bar small{display:block;width:100%;color:#667085;font-weight:700}.rlt-inline-import-form{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin:0}.rlt-file-button{position:relative;overflow:hidden;display:inline-flex;align-items:center;gap:6px;padding:12px 16px;border-radius:999px;border:1px solid #f0c3cc;background:#fff5f8;color:#cc3553;font-weight:900;cursor:pointer}.rlt-file-button input[type=file]{position:absolute;inset:0;opacity:0;cursor:pointer}
.rlt-tips-floating-button{position:fixed;top:22px;right:22px;z-index:950;width:52px;height:52px;border-radius:50%;border:1px solid #fde6a8;background:linear-gradient(135deg,#fff7d6,#ffffff);box-shadow:0 16px 38px rgba(245,158,11,.22);font-size:24px;cursor:pointer}.rtl .rlt-tips-floating-button{right:auto;left:22px}.rlt-tips-floating-button:hover{transform:translateY(-2px)}.rlt-role-tips[hidden]{display:none!important}.rlt-tips-disable{margin-top:14px;width:100%;border:0;background:#fff7ed;color:#9a3412;border-radius:16px;padding:12px 14px;font-weight:900;cursor:pointer}.rlt-tips-disable:hover{background:#ffedd5}


/* v0.4.16 guided contextual tips with spotlight */
.rlt-guided-tour{position:fixed;inset:0;z-index:10000;display:none;pointer-events:none}.rlt-guided-tour[hidden]{display:none!important}.rlt-tour-backdrop{position:fixed;inset:0;background:rgba(15,23,42,.46);pointer-events:auto}.rlt-tour-spotlight{position:fixed;border-radius:22px;border:3px solid rgba(255,255,255,.96);box-shadow:0 0 0 9999px rgba(15,23,42,.42),0 18px 50px rgba(204,53,83,.28);background:rgba(255,255,255,.08);transition:all .18s ease;pointer-events:none}.rlt-tour-target-active{position:relative;z-index:10001!important;box-shadow:0 0 0 4px rgba(255,255,255,.95),0 0 0 8px rgba(204,53,83,.28)!important;border-radius:18px!important}.rlt-tour-card{position:fixed!important;z-index:10002!important;pointer-events:auto;max-width:calc(100vw - 28px);margin:0!important;transition:left .18s ease,top .18s ease}.rlt-tour-step-count{display:inline-flex;align-items:center;justify-content:center;margin-bottom:10px;padding:5px 10px;border-radius:999px;background:#fff5f8;color:#cc3553;font-weight:900;font-size:12px}.rlt-role-tips .rlt-first-tips-box:after{content:"";position:absolute;width:18px;height:18px;background:#fff;transform:rotate(45deg);top:-9px;left:38px;border-left:1px solid #f0d3dc;border-top:1px solid #f0d3dc}.rtl .rlt-role-tips .rlt-first-tips-box:after{left:auto;right:38px}@media(max-width:700px){.rlt-tour-card{left:14px!important;right:14px!important;top:auto!important;bottom:18px!important;width:auto!important}.rlt-role-tips .rlt-first-tips-box:after{display:none}.rlt-tour-spotlight{border-radius:16px}}


/* v0.4.17 guided tips card reachability hotfix */
.rlt-guided-tour{overflow:visible!important}
.rlt-tour-card{box-sizing:border-box!important;max-height:min(360px,calc(100vh - 36px))!important;overflow-y:auto!important;-webkit-overflow-scrolling:touch!important}
.rlt-tour-card .rlt-first-tips-actions{position:sticky;bottom:0;background:linear-gradient(180deg,rgba(255,255,255,.88),#fff 42%);padding-top:12px;z-index:2}
.rlt-tour-card .rlt-tips-disable{position:sticky;bottom:0;z-index:2}
.rlt-role-tips .rlt-first-tips-box:after{display:none!important}
.rlt-tour-backdrop{cursor:pointer}
@media(max-height:620px){.rlt-tour-card{max-height:calc(100vh - 24px)!important}.rlt-tip-step strong{font-size:18px!important}.rlt-tip-step p{font-size:14px!important;line-height:1.5!important}.rlt-first-tips-box{padding:18px!important}}
@media(max-width:700px){.rlt-tour-card{left:12px!important;right:auto!important;width:calc(100vw - 24px)!important;bottom:auto!important;max-height:calc(100vh - 24px)!important}}


/* v0.4.18 guided tips z-index hard fix */
.rlt-guided-tour{
  z-index:2147483000!important;
  pointer-events:none!important;
  isolation:isolate!important;
}
.rlt-tour-backdrop{
  z-index:2147483000!important;
  pointer-events:auto!important;
}
.rlt-tour-spotlight{
  z-index:2147483001!important;
  pointer-events:none!important;
}
.rlt-tour-card,
.rlt-role-tips .rlt-tour-card,
.rlt-guided-tour .rlt-first-tips-box.rlt-tour-card{
  position:fixed!important;
  z-index:2147483006!important;
  pointer-events:auto!important;
  visibility:visible!important;
  opacity:1!important;
}
.rlt-tour-target-active{
  z-index:2147482990!important;
}
.rlt-tour-card *{
  pointer-events:auto!important;
}
.rlt-tour-card .rlt-first-tips-close,
.rlt-tour-card [data-rlt-tips-next],
.rlt-tour-card [data-rlt-tips-prev],
.rlt-tour-card [data-rlt-tips-disable]{
  position:relative!important;
  z-index:2147483007!important;
}
@media(max-width:700px){
  .rlt-tour-card{
    z-index:2147483006!important;
  }
}


/* v0.4.19 gamification profile */
.rlt-rank-pill{background:linear-gradient(135deg,#fff7ed,#fff1f2)!important;color:#9f1239!important;border-color:#fecdd3!important}
.rlt-gamification-mini-stats{display:flex;gap:10px;flex-wrap:wrap;margin:14px 0 8px}
.rlt-gamification-mini-stats span{display:inline-flex;align-items:center;gap:7px;padding:9px 12px;border-radius:16px;background:#fff;border:1px solid #eef2f7;box-shadow:0 10px 24px rgba(15,23,42,.05)}
.rlt-gamification-mini-stats strong{font-size:18px;color:#111827;line-height:1}
.rlt-gamification-mini-stats em{font-style:normal;font-size:12px;color:#667085;font-weight:800}


/* v0.4.26 portal header + split login layout */
.rlt-school-login-page{
    max-width:1280px;
    min-height:calc(100vh - 90px);
}
.rlt-school-login-card-split{
    padding:34px;
}
.rlt-school-login-site-header{
    display:flex;
    justify-content:center;
    align-items:center;
    margin:0 0 26px;
}
.rlt-school-login-site-logo{
    max-width:270px;
    max-height:120px;
    width:auto;
    height:auto;
    object-fit:contain;
    display:block;
}
.rlt-rouyatok-logo-fallback{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    min-height:72px;
    padding:12px 24px;
    border-radius:22px;
    background:#fff3f6;
    color:var(--rlt-primary,#cc3553);
    font-weight:900;
    font-size:24px;
}
.rlt-school-login-split-layout{
    display:grid;
    grid-template-columns:minmax(0,1fr) minmax(300px,440px);
    gap:34px;
    align-items:stretch;
}
.rlt-school-login-form-panel{
    display:flex;
    align-items:center;
    justify-content:center;
}
.rlt-school-login-form-panel .rlt-login-shell{
    width:100%;
}
.rlt-school-login-form-panel .rlt-login-card,
.rlt-school-login-form-panel .rlt-form-card{
    width:100%;
    max-width:620px;
    box-shadow:none;
}
.rlt-school-login-brand-panel{
    display:flex;
    align-items:center;
    justify-content:center;
    border-radius:28px;
    background:linear-gradient(145deg,#fff7f9,#ffffff);
    border:1px solid #f5d4dd;
    padding:34px;
}
.rlt-school-login-brand-panel .rlt-school-login-brand{
    margin-bottom:0;
}
.rlt-school-login-brand-panel .rlt-school-login-logo{
    max-width:320px;
    max-height:220px;
}
.rlt-school-login-brand-panel .rlt-school-login-logo-fallback{
    width:130px;
    height:130px;
}

.rlt-school-portal-topbar-split{
    display:block;
    padding:14px;
}
.rlt-school-portal-logo-header{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:18px;
    width:100%;
    padding:8px 10px 14px;
}
.rlt-portal-site-logo-link,
.rlt-school-portal-brand{
    display:inline-flex;
    align-items:center;
    text-decoration:none!important;
}
.rlt-portal-site-logo{
    max-width:150px;
    max-height:72px;
    object-fit:contain;
    display:block;
}
.rlt-school-portal-brand{
    flex-direction:row!important;
    justify-content:flex-end!important;
    gap:10px!important;
    flex:0 1 auto!important;
    max-width:240px;
    text-align:right!important;
}
.rlt-portal-school-logo{
    width:70px;
    height:70px;
    border-radius:18px;
    object-fit:contain;
    background:#fff;
    border:1px solid #eef2f7;
    padding:6px;
}
.rlt-school-portal-brand-text{
    max-width:145px!important;
}
.rlt-school-portal-brand strong{
    font-size:13px!important;
    line-height:1.15!important;
    color:#111827!important;
}
.rlt-school-portal-menu-full{
    width:100%;
    display:flex!important;
    justify-content:center!important;
    align-items:center;
    gap:8px;
    padding:12px 10px 4px;
    border-top:1px solid #eef2f7;
}
.rlt-school-portal-menu-full .rlt-portal-logout-link{
    margin-inline-start:auto;
}
.rtl .rlt-school-portal-menu-full .rlt-portal-logout-link{
    margin-inline-start:0;
    margin-inline-end:auto;
}

@media(max-width:900px){
    .rlt-school-login-card-split{padding:22px}
    .rlt-school-login-split-layout{
        grid-template-columns:1fr;
    }
    .rlt-school-login-brand-panel{
        order:-1;
        padding:24px;
    }
    .rlt-school-login-site-logo{
        max-width:220px;
        max-height:90px;
    }
    .rlt-school-portal-logo-header{
        flex-direction:row;
    }
    .rlt-school-portal-menu-full{
        justify-content:flex-start!important;
        overflow-x:auto;
        flex-wrap:nowrap!important;
        -webkit-overflow-scrolling:touch;
    }
    .rlt-school-portal-menu-full a{
        white-space:nowrap;
    }
    .rlt-school-portal-menu-full .rlt-portal-logout-link{
        margin-inline-start:0;
    }
}
@media(max-width:560px){
    .rlt-school-portal-logo-header{
        flex-direction:column;
        justify-content:center;
        text-align:center;
    }
    .rlt-school-portal-brand{
        justify-content:center!important;
        text-align:center!important;
    }
}


/* v0.4.27 selectable portal logo + consistent header logos */
.rlt-school-portal-logo-header{
    align-items:center!important;
}
.rlt-portal-site-logo-link{
    min-width:220px;
}
.rlt-portal-site-logo{
    max-width:220px!important;
    max-height:92px!important;
    width:auto!important;
    height:auto!important;
    object-fit:contain!important;
}
.rlt-school-portal-brand{
    flex-direction:column!important;
    align-items:center!important;
    justify-content:center!important;
    gap:5px!important;
    flex:0 0 240px!important;
    max-width:240px!important;
    text-align:center!important;
}
.rlt-portal-school-logo{
    width:auto!important;
    height:auto!important;
    max-width:220px!important;
    max-height:92px!important;
    object-fit:contain!important;
    background:transparent!important;
    border:0!important;
    padding:0!important;
    border-radius:0!important;
    box-shadow:none!important;
}
.rlt-school-portal-brand-text{
    display:block!important;
    max-width:220px!important;
    text-align:center!important;
}
.rlt-school-portal-brand strong{
    display:block!important;
    font-size:12px!important;
    line-height:1.15!important;
    font-weight:900!important;
    color:#111827!important;
    white-space:normal!important;
}
.rlt-school-login-site-logo{
    max-width:280px!important;
    max-height:120px!important;
    object-fit:contain!important;
}
.rlt-school-login-brand-panel .rlt-school-login-logo{
    width:auto!important;
    height:auto!important;
    max-width:320px!important;
    max-height:240px!important;
    object-fit:contain!important;
    border:0!important;
    background:transparent!important;
    padding:0!important;
    border-radius:0!important;
}
@media(max-width:900px){
    .rlt-portal-site-logo-link{
        min-width:auto;
    }
    .rlt-school-portal-brand{
        flex:0 1 auto!important;
    }
}


/* v0.4.28 centered login screen + left platform logo */
.rlt-school-login-mode{
    min-height:100vh;
    display:flex;
    align-items:center;
    justify-content:center;
    padding:28px 18px!important;
}
.rlt-school-login-mode .rlt-school-login-card-split{
    width:min(100%,1320px);
    margin:0 auto!important;
    padding:42px 56px!important;
}
.rlt-school-login-mode .rlt-school-login-split-layout{
    grid-template-columns:minmax(0,1.35fr) minmax(280px,420px)!important;
    align-items:center!important;
    gap:56px!important;
}
.rlt-school-login-form-panel{
    display:flex!important;
    flex-direction:column!important;
    align-items:stretch!important;
    justify-content:center!important;
}
.rlt-school-login-form-panel .rlt-school-login-site-header{
    justify-content:flex-start!important;
    margin:0 0 28px!important;
    width:100%;
    max-width:620px;
}
.rlt-school-login-form-panel .rlt-school-login-site-logo{
    max-width:240px!important;
    max-height:88px!important;
}
.rlt-school-login-form-panel .rlt-login-shell{
    margin:0!important;
}
.rlt-school-login-form-panel .rlt-login-card{
    max-width:620px!important;
    padding:28px!important;
}
.rlt-school-login-brand-panel{
    padding:28px!important;
    min-height:360px;
}
.rlt-school-login-brand-panel .rlt-school-login-logo{
    max-width:260px!important;
    max-height:165px!important;
}
.rlt-school-login-brand-panel .rlt-school-login-brand h1{
    font-size:clamp(24px,2.1vw,34px)!important;
    line-height:1.1!important;
    letter-spacing:-.035em!important;
    margin-top:8px!important;
}
.rlt-school-login-brand-panel .rlt-pill{
    font-size:12px!important;
    padding:5px 12px!important;
}

@media(max-width:900px){
    .rlt-school-login-mode{
        min-height:auto;
        display:block;
    }
    .rlt-school-login-mode .rlt-school-login-card-split{
        padding:24px!important;
    }
    .rlt-school-login-mode .rlt-school-login-split-layout{
        grid-template-columns:1fr!important;
        gap:24px!important;
    }
    .rlt-school-login-form-panel .rlt-school-login-site-header{
        justify-content:center!important;
        max-width:100%;
    }
    .rlt-school-login-form-panel .rlt-login-card{
        max-width:100%!important;
    }
    .rlt-school-login-brand-panel{
        min-height:auto;
    }
    .rlt-school-login-brand-panel .rlt-school-login-logo{
        max-width:220px!important;
        max-height:135px!important;
    }
    .rlt-school-login-brand-panel .rlt-school-login-brand h1{
        font-size:26px!important;
    }
}


/* v0.4.29 login language switcher + no empty bottom scroll */
html:has(body.rlt-standalone-portal),
body.rlt-standalone-portal{
    min-height:100%;
}
body.rlt-standalone-portal{
    margin:0!important;
}
.rlt-standalone-portal .rlt-school-login-mode{
    min-height:100dvh!important;
    width:100%!important;
    max-width:none!important;
    margin:0!important;
    padding:24px 18px!important;
    display:flex!important;
    align-items:center!important;
    justify-content:center!important;
    box-sizing:border-box!important;
}
.rlt-standalone-portal .rlt-school-login-mode .rlt-school-login-card-split{
    position:relative;
    width:min(100%,1320px)!important;
    max-width:1320px!important;
    margin:0 auto!important;
    padding:38px 56px!important;
    box-sizing:border-box!important;
}
.rlt-school-login-language-switcher{
    position:absolute;
    top:20px;
    right:24px;
    z-index:5;
}
.rtl .rlt-school-login-language-switcher{
    right:auto;
    left:24px;
}
.rlt-school-login-language-switcher .rlt-language-switcher{
    margin:0!important;
    box-shadow:0 10px 28px rgba(17,24,39,.08);
    border:1px solid #edf0f4;
    background:#fff;
}
.rlt-standalone-portal .rlt-school-login-mode .rlt-school-login-split-layout{
    align-items:center!important;
}
.rlt-standalone-portal .rlt-school-login-mode .rlt-school-login-form-panel .rlt-school-login-site-header{
    margin-top:0!important;
}
.rlt-standalone-portal .rlt-school-login-mode .rlt-school-login-brand-panel{
    min-height:330px!important;
}
.rlt-standalone-portal .rlt-school-login-mode .rlt-school-login-brand-panel .rlt-school-login-logo{
    max-width:240px!important;
    max-height:145px!important;
}
.rlt-standalone-portal .rlt-school-login-mode .rlt-school-login-brand-panel .rlt-school-login-brand h1{
    font-size:clamp(22px,1.9vw,30px)!important;
}
@media(min-width:901px){
    body.rlt-standalone-portal .rlt-school-login-mode{
        overflow:hidden;
    }
}
@media(max-width:900px){
    .rlt-school-login-language-switcher{
        position:static;
        display:flex;
        justify-content:flex-end;
        margin:0 0 16px;
    }
    .rtl .rlt-school-login-language-switcher{
        justify-content:flex-start;
    }
    .rlt-standalone-portal .rlt-school-login-mode{
        min-height:100svh!important;
        align-items:flex-start!important;
        overflow:visible!important;
        padding:18px!important;
    }
    .rlt-standalone-portal .rlt-school-login-mode .rlt-school-login-card-split{
        padding:22px!important;
    }
}


/* v0.4.30 AI journal availability + certificate preview */
.rlt-ai-floating-journal{overflow:visible}
.rlt-ai-floating-journal .rlt-ai-floating-tip{position:absolute;right:68px;bottom:50%;transform:translateY(50%);white-space:nowrap;background:#111827;color:#fff;padding:8px 12px;border-radius:999px;font-size:12px;font-weight:800;opacity:0;pointer-events:none;transition:opacity .15s ease,transform .15s ease;box-shadow:0 10px 24px rgba(15,23,42,.22)}
.rtl .rlt-ai-floating-journal .rlt-ai-floating-tip{right:auto;left:68px}
.rlt-ai-floating-journal:hover .rlt-ai-floating-tip{opacity:1;transform:translateY(50%) translateX(-2px)}
.rlt-ai-floating-journal.is-inactive{background:#cbd5e1!important;box-shadow:0 12px 24px rgba(148,163,184,.24);color:#475569}
.rlt-ai-floating-journal.is-inactive:hover{color:#475569}
.rlt-ai-journal-availability{margin:0 0 16px;padding:12px 14px;border-radius:16px;font-weight:800}
.rlt-ai-journal-availability.is-active{background:#ecfdf5;border:1px solid #bbf7d0;color:#166534}
.rlt-ai-journal-availability.is-inactive{background:#f8fafc;border:1px solid #e2e8f0;color:#64748b}
.rlt-journal-empty-center{min-height:220px;display:flex;align-items:center;justify-content:center;text-align:center;font-size:20px;font-weight:800}
.rlt-certificate-card{display:flex;flex-direction:column;gap:10px;align-items:flex-start}
.rlt-certificate-preview-wrap{display:grid;gap:18px}
.rlt-certificate-preview{position:relative;width:100%;max-width:1080px;min-height:760px;aspect-ratio:1.414/1;margin:0 auto;background:linear-gradient(180deg,#fffdf8 0%,#ffffff 100%);border:10px solid #f3e8cf;border-radius:30px;padding:36px;box-shadow:0 18px 48px rgba(15,23,42,.08);overflow:hidden}
.rlt-certificate-inner{position:absolute;inset:36px;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center}
.rlt-certificate-platform-logo{max-width:180px;max-height:92px;display:block;margin:0 auto 18px}.rlt-certificate-ribbon{display:inline-block;padding:8px 16px;border-radius:999px;background:#fff1f2;color:#cc3553;font-weight:900;margin-bottom:14px}.rlt-certificate-preview h2{font-size:46px;line-height:1.08;margin:0 0 14px;color:#0f172a}.rlt-certificate-preview h3{font-size:56px;line-height:1.04;margin:10px 0;color:#111827}.rlt-certificate-preview h4{font-size:28px;line-height:1.35;margin:10px 0 8px;color:#cc3553}.rlt-certificate-lead{font-size:19px;line-height:1.9;color:#475569;max-width:780px;margin:0 auto 14px}.rlt-certificate-submeta{font-size:18px;line-height:1.7;color:#64748b}.rlt-certificate-meta{display:flex;justify-content:center;gap:24px;flex-wrap:wrap;margin:16px 0 0;color:#334155;font-weight:700}.rlt-certificate-signature-block{position:absolute;left:60px;right:250px;bottom:58px;text-align:center}.rlt-certificate-signature-block img{display:block;max-width:220px;max-height:86px;margin:0 auto 8px}.rlt-certificate-signature-line{width:220px;max-width:100%;margin:0 auto;border-top:2px solid rgba(15,23,42,.35)}.rlt-certificate-signature-block small{display:block;margin-top:8px;font-size:15px;font-weight:700;color:#475569}.rlt-certificate-qr-corner{position:absolute;right:42px;bottom:42px;width:180px;padding:14px;background:rgba(255,255,255,.94);border:1px solid rgba(226,232,240,.95);border-radius:22px;text-align:center;box-shadow:0 10px 30px rgba(15,23,42,.08)}.rlt-certificate-qr-corner img{display:block;width:126px;height:126px;margin:0 auto 8px;background:#fff;border-radius:14px;padding:8px}.rlt-certificate-qr-corner strong{display:block;font-size:14px;font-weight:900;color:#0f172a}.rlt-certificate-qr-corner small{display:block;font-size:12px;line-height:1.5;color:#64748b;margin-top:2px}@media(max-width:900px){.rlt-certificate-preview{min-height:680px}.rlt-certificate-preview h2{font-size:38px}.rlt-certificate-preview h3{font-size:44px}.rlt-certificate-preview h4{font-size:24px}.rlt-certificate-signature-block{left:36px;right:220px;bottom:36px}.rlt-certificate-qr-corner{right:24px;bottom:24px;width:160px}.rlt-certificate-qr-corner img{width:112px;height:112px}}@media(max-width:640px){.rlt-certificate-preview{min-height:auto;aspect-ratio:auto;padding:22px 18px 200px}.rlt-certificate-inner{position:relative;inset:auto;padding:0}.rlt-certificate-preview h2{font-size:28px}.rlt-certificate-preview h3{font-size:30px}.rlt-certificate-preview h4{font-size:22px}.rlt-certificate-lead{font-size:16px;line-height:1.8}.rlt-certificate-submeta{font-size:15px}.rlt-certificate-signature-block{left:18px;right:18px;bottom:122px}.rlt-certificate-qr-corner{left:50%;right:auto;bottom:18px;transform:translateX(-50%);width:170px}}


/* v0.4.31 path/course redesign + rank badge icons */
.rlt-rank-icon{display:inline-flex;align-items:center;justify-content:center;vertical-align:middle;line-height:1}
img.rlt-rank-icon{width:22px;height:22px;border-radius:50%;object-fit:contain;background:#fff;margin-inline-end:4px}
.rlt-badge-chip img.rlt-rank-icon{width:18px;height:18px;margin-inline-end:6px}
.rlt-path-dashboard{display:grid;gap:24px}
.rlt-active-path-panel{display:grid;grid-template-columns:minmax(0,1fr) 260px;gap:22px;background:linear-gradient(135deg,#ffffff 0%,#fff7fa 100%);border:1px solid #f3d5dc;border-radius:28px;padding:24px;box-shadow:0 18px 45px rgba(15,23,42,.06)}
.rlt-active-path-copy h2{font-size:clamp(28px,4vw,44px);line-height:1.05;margin:10px 0;color:#0f172a}
.rlt-active-path-copy p{color:#64748b;font-weight:750;line-height:1.7;max-width:760px}
.rlt-active-path-meta{display:flex;flex-wrap:wrap;gap:10px;margin:14px 0}
.rlt-active-path-meta span{display:inline-flex;align-items:center;gap:6px;border:1px solid #e5e7eb;background:#fff;border-radius:999px;padding:8px 12px;color:#334155;font-weight:900}
.rlt-active-path-progress{height:12px;margin-top:14px}
.rlt-path-completion-number{display:inline-block;margin-top:8px;color:#cc3553;font-weight:950}
.rlt-active-path-thumb{min-height:220px;border-radius:24px;background-size:cover;background-position:center;box-shadow:inset 0 0 0 1px rgba(255,255,255,.5)}
.rlt-active-path-courses{grid-column:1/-1;margin-top:8px}
.rlt-path-grid-heading{margin-top:4px}
.rlt-path-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:18px}
.rlt-path-grid-card{display:block;text-decoration:none!important;color:inherit;background:#fff;border:1px solid #e5e7eb;border-radius:24px;padding:18px;box-shadow:0 14px 35px rgba(15,23,42,.05);transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease}
.rlt-path-grid-card:hover{transform:translateY(-3px);box-shadow:0 18px 45px rgba(15,23,42,.08);border-color:#f3b7c4}
.rlt-path-grid-card.is-active-path{border-color:#cc3553;box-shadow:0 18px 45px rgba(204,53,83,.12)}
.rlt-path-grid-card .rlt-path-thumb{height:120px;border-radius:18px;background-size:cover;background-position:center;margin-bottom:12px}
.rlt-path-grid-card h3{margin:10px 0 6px;color:#0f172a}
.rlt-path-grid-card p{color:#64748b;font-weight:700;line-height:1.55}
.rlt-course-grid-enhanced{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:18px}
.rlt-course-grid-enhanced .rlt-course-card{height:100%}
.rlt-course-card .rlt-course-content p{min-height:44px}
.rlt-course-meta span:first-child:before{content:"⏱ ";opacity:.8}
.rlt-course-about-panel .rlt-rich-content{font-size:16px;line-height:1.8;color:#334155}
@media(max-width:900px){.rlt-active-path-panel{grid-template-columns:1fr}.rlt-active-path-thumb{min-height:160px}.rlt-active-path-meta span{width:100%;justify-content:center}.rlt-path-grid{grid-template-columns:1fr}.rlt-course-grid-enhanced{grid-template-columns:1fr}}


/* v0.4.32 compact mobile login + front-end overflow protection */
@media(max-width:700px){
    html,
    body.rlt-standalone-portal{
        overflow-x:hidden!important;
    }
    .rlt-portal-shell,
    .rlt-school-login-form-panel .rlt-login-shell{
        width:100%!important;
        max-width:100%!important;
        box-sizing:border-box!important;
    }
    .rlt-form-card,
    .rlt-profile-card,
    .rlt-course-card,
    .rlt-mission-card,
    .rlt-front-stat,
    .rlt-empty-card,
    .rlt-active-path-panel,
    .rlt-path-grid-card,
    .rlt-course-hero,
    .rlt-lesson-content-card,
    .rlt-lessons-sidebar{
        max-width:100%!important;
        box-sizing:border-box!important;
    }
    .rlt-form input,
    .rlt-form textarea,
    .rlt-inline-form input,
    .rlt-login-card input[type="text"],
    .rlt-login-card input[type="password"]{
        max-width:100%!important;
        box-sizing:border-box!important;
    }
    .rlt-standalone-portal .rlt-school-login-mode{
        min-height:100svh!important;
        padding:8px 10px!important;
        align-items:center!important;
        justify-content:center!important;
    }
    .rlt-standalone-portal .rlt-school-login-mode .rlt-school-login-card-split{
        width:100%!important;
        padding:12px!important;
        border-radius:24px!important;
        box-sizing:border-box!important;
    }
    .rlt-school-login-language-switcher{
        margin:0 0 8px!important;
        justify-content:flex-end!important;
    }
    .rtl .rlt-school-login-language-switcher{
        justify-content:flex-start!important;
    }
    .rlt-school-login-language-switcher .rlt-language-switcher{
        padding:4px!important;
    }
    .rlt-school-login-language-switcher .rlt-language-link{
        padding:6px 12px!important;
        font-size:14px!important;
    }
    .rlt-standalone-portal .rlt-school-login-mode .rlt-school-login-split-layout{
        gap:10px!important;
    }
    .rlt-standalone-portal .rlt-school-login-mode .rlt-school-login-brand-panel{
        padding:12px!important;
        min-height:0!important;
        border-radius:22px!important;
    }
    .rlt-school-login-brand-panel .rlt-school-login-brand{
        display:flex!important;
        flex-direction:column!important;
        align-items:center!important;
        justify-content:center!important;
        gap:6px!important;
        text-align:center!important;
    }
    .rlt-standalone-portal .rlt-school-login-mode .rlt-school-login-brand-panel .rlt-school-login-logo,
    .rlt-school-login-brand-panel .rlt-school-login-logo{
        max-width:150px!important;
        max-height:86px!important;
    }
    .rlt-school-login-brand-panel .rlt-pill{
        font-size:11px!important;
        padding:4px 10px!important;
        margin:0!important;
    }
    .rlt-standalone-portal .rlt-school-login-mode .rlt-school-login-brand-panel .rlt-school-login-brand h1,
    .rlt-school-login-brand-panel .rlt-school-login-brand h1{
        font-size:22px!important;
        line-height:1.08!important;
        margin:2px 0 0!important;
        letter-spacing:-.03em!important;
    }
    .rlt-school-login-form-panel{
        align-items:center!important;
        width:100%!important;
    }
    .rlt-school-login-form-panel .rlt-school-login-site-header{
        justify-content:center!important;
        max-width:100%!important;
        margin:0 0 8px!important;
    }
    .rlt-school-login-form-panel .rlt-school-login-site-logo,
    .rlt-school-login-site-logo{
        max-width:170px!important;
        max-height:56px!important;
    }
    .rlt-school-login-form-panel .rlt-login-shell{
        margin:0 auto!important;
        padding:0!important;
    }
    .rlt-school-login-form-panel .rlt-login-card{
        width:100%!important;
        max-width:480px!important;
        margin:0 auto!important;
        padding:16px!important;
        border-radius:22px!important;
        box-shadow:0 10px 24px rgba(17,24,39,.06)!important;
    }
    .rlt-school-login-form-panel .rlt-login-card h2{
        font-size:28px!important;
        line-height:1.05!important;
        margin:0 0 6px!important;
    }
    .rlt-school-login-form-panel .rlt-login-card p{
        font-size:14px!important;
        line-height:1.35!important;
        margin:0 0 10px!important;
    }
    .rlt-school-login-form-panel .rlt-form label{
        margin-bottom:8px!important;
        font-size:14px!important;
    }
    .rlt-school-login-form-panel .rlt-login-card input[type="text"],
    .rlt-school-login-form-panel .rlt-login-card input[type="password"]{
        min-height:42px!important;
        padding:9px 12px!important;
        margin-top:5px!important;
        border-radius:14px!important;
    }
    .rlt-school-login-form-panel .rlt-remember-line{
        margin:6px 0 10px!important;
    }
    .rlt-school-login-form-panel .rlt-button,
    .rlt-school-login-form-panel .login-submit input{
        min-height:42px!important;
        padding:9px 15px!important;
    }
    .rlt-profile-body{
        flex-direction:column!important;
        align-items:center!important;
        text-align:center!important;
        padding:0 18px 20px!important;
    }
    .rlt-avatar{
        width:96px!important;
        height:96px!important;
    }
    .rlt-profile-banner{
        min-height:130px!important;
    }
    .rlt-course-hero{
        padding:18px!important;
    }
    .rlt-video-placeholder{
        min-height:190px!important;
    }
}
@media(max-width:380px){
    .rlt-school-login-form-panel .rlt-login-card h2{
        font-size:24px!important;
    }
    .rlt-standalone-portal .rlt-school-login-mode .rlt-school-login-brand-panel .rlt-school-login-logo,
    .rlt-school-login-brand-panel .rlt-school-login-logo{
        max-height:72px!important;
    }
    .rlt-school-login-form-panel .rlt-school-login-site-logo,
    .rlt-school-login-site-logo{
        max-height:48px!important;
    }
}

/* v0.4.40 lesson locking, auto-next, and persistent tips button */
.rlt-complete-box.is-video-locked{border-color:#fde3ea;background:linear-gradient(135deg,#fff,#fff7fa)}
.rlt-video-lock-note{font-weight:800;color:#667085}
.rlt-video-progress-note{display:inline-flex;align-items:center;gap:8px;margin:10px 0 14px;padding:10px 14px;border-radius:999px;background:#f8fafc;border:1px solid #e5eaf2;color:#334155;font-weight:900;font-size:14px}
.rlt-complete-box.is-video-locked .rlt-button[disabled]{opacity:.65;cursor:not-allowed;filter:grayscale(.15)}
.rlt-auto-next-box{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-top:14px;padding:12px 14px;border-radius:18px;background:#f0fdf4;border:1px solid #bbf7d0;color:#166534;font-weight:900}
.rlt-auto-next-box strong{display:inline-grid;place-items:center;min-width:34px;height:34px;border-radius:999px;background:#16a34a;color:#fff;font-size:18px}
.rlt-auto-next-box a{color:#166534;text-decoration:underline;font-weight:950}
.rlt-tips-floating-button{top:auto!important;right:auto!important;left:22px!important;bottom:94px!important;transition:transform .18s ease,opacity .18s ease,filter .18s ease,box-shadow .18s ease,background .18s ease;}
.rtl .rlt-tips-floating-button{right:auto!important;left:22px!important}
.rlt-tips-floating-button.is-idle{background:linear-gradient(135deg,#f1f5f9,#ffffff)!important;border-color:#e2e8f0!important;box-shadow:0 10px 26px rgba(15,23,42,.12)!important;filter:grayscale(1);opacity:.72}
.rlt-tips-floating-button.is-active{filter:none;opacity:1;box-shadow:0 16px 38px rgba(245,158,11,.24)!important}
@media(max-width:700px){
  .rlt-tips-floating-button,
  .rtl .rlt-tips-floating-button{width:44px!important;height:44px!important;font-size:19px!important;left:auto!important;right:16px!important;bottom:88px!important;z-index:950!important}
  .rlt-auto-next-box{align-items:flex-start;border-radius:16px;font-size:14px}
  .rlt-video-progress-note{border-radius:16px;line-height:1.45;display:flex;white-space:normal}
}


/* v0.4.41 mobile polishing + backend-relation visibility fixes */
@media(max-width:900px){
  .rlt-ai-onboarding-card{padding:22px 18px!important;overflow:hidden!important}
  .rlt-ai-onboarding-card .rlt-onboarding-header h2{font-size:clamp(28px,7.2vw,40px)!important;line-height:1.08!important}
  .rlt-ai-onboarding-card .rlt-onboarding-header p{font-size:16px!important;line-height:1.55!important}
  .rlt-onboarding-grid{grid-template-columns:1fr!important;gap:14px!important}
  .rlt-onboarding-grid .rlt-onboarding-field{grid-row:auto!important;grid-column:1/-1!important;width:100%!important;min-width:0!important}
  .rlt-onboarding-field input,.rlt-onboarding-field select,.rlt-onboarding-field-full textarea{width:100%!important;max-width:100%!important;box-sizing:border-box!important}
  .rlt-onboarding-field-full{width:100%!important;max-width:100%!important;box-sizing:border-box!important}
}
@media(max-width:700px){
  .rlt-course-view-shell{padding-inline:14px!important;margin-top:18px!important;overflow-x:hidden!important}
  .rlt-course-landing-hero.rlt-udemy-hero{display:flex!important;flex-direction:column!important;gap:14px!important;padding:22px 18px!important;border-radius:26px!important;overflow:hidden!important;align-items:stretch!important}
  .rlt-course-landing-hero .rlt-course-hero-copy{min-height:0!important;width:100%!important;max-width:100%!important;display:block!important;position:relative!important;z-index:1!important}
  .rlt-course-landing-hero .rlt-back-link{font-size:15px!important;line-height:1.25!important;max-width:100%!important;white-space:normal!important}
  .rlt-course-landing-hero h1{font-size:clamp(32px,10vw,48px)!important;line-height:1.02!important;margin:12px 0!important;letter-spacing:-.045em!important;max-width:100%!important;overflow-wrap:anywhere!important;word-break:normal!important}
  .rlt-course-landing-hero .rlt-course-hero-meta-clean{display:grid!important;grid-template-columns:1fr!important;gap:8px!important;margin-top:14px!important}
  .rlt-course-hero-meta-clean span{width:max-content!important;max-width:100%!important;white-space:normal!important}
  .rlt-course-landing-hero .rlt-course-hero-card{position:relative!important;z-index:2!important;width:100%!important;max-width:100%!important;align-self:center!important;margin:0!important;border-radius:22px!important;box-shadow:0 16px 34px rgba(15,23,42,.22)!important;transform:none!important}
  .rlt-course-landing-hero .rlt-course-hero-card .rlt-course-hero-thumb{min-height:0!important;height:auto!important;aspect-ratio:16/9!important;background-size:cover!important;background-position:center!important}
  .rlt-course-landing-hero .rlt-course-hero-card-body{padding:14px!important}
  .rlt-course-landing-hero .rlt-start-course-button{min-height:50px!important;border-radius:16px!important;font-size:16px!important;padding:12px 14px!important}
  .rlt-course-about-panel{border-radius:22px!important;padding:22px 18px!important}

  .rlt-avatar-template-picker{padding:14px 12px!important;overflow:hidden!important}
  .rlt-avatar-template-grid{grid-template-columns:repeat(2,minmax(0,1fr))!important;gap:12px!important;width:100%!important;max-width:100%!important;overflow:hidden!important}
  .rlt-avatar-template{min-width:0!important;max-width:100%!important;padding:16px 8px 16px!important;border-radius:20px!important;box-sizing:border-box!important;overflow:hidden!important}
  .rlt-avatar-visual{width:min(112px,100%)!important;height:112px!important;margin:0 auto 8px!important}
  .rlt-avatar-template img{width:112px!important;height:112px!important;max-width:100%!important}
  .rlt-avatar-template .rlt-avatar-template-label{font-size:13px!important;line-height:1.25!important;overflow-wrap:anywhere!important}
}
@media(max-width:390px){
  .rlt-avatar-template-grid{gap:10px!important}
  .rlt-avatar-template{padding-inline:6px!important}
  .rlt-avatar-visual{height:96px!important;width:96px!important}
  .rlt-avatar-template img{width:96px!important;height:96px!important}
  .rlt-avatar-badge{width:30px!important;height:30px!important;font-size:15px!important}
}

/* Tip icon mobile behavior: stable, smaller, and never visually fights with the active tour. */
.rlt-tour-is-open .rlt-ai-floating-journal,
.rlt-tour-is-open .rlt-tips-floating-button{animation:none!important;transition:none!important}
.rlt-tour-is-open .rlt-ai-floating-journal.rlt-tour-target-active,
.rlt-tour-is-open .rlt-tips-floating-button.rlt-tour-target-active{transform:none!important;animation:none!important}
@media(max-width:700px){
  .rlt-ai-floating-journal{width:50px!important;height:50px!important;font-size:23px!important;right:12px!important;bottom:18px!important;z-index:880!important}
  .rtl .rlt-ai-floating-journal{left:12px!important;right:auto!important}
  .rlt-tips-floating-button,
  .rtl .rlt-tips-floating-button{width:38px!important;height:38px!important;font-size:17px!important;right:14px!important;left:auto!important;bottom:76px!important;z-index:890!important;opacity:.8!important}
  .rlt-tips-floating-button.is-active{opacity:1!important}
  .rlt-guided-tour .rlt-tour-card{bottom:16px!important;top:auto!important;width:calc(100vw - 24px)!important;max-height:min(420px,calc(100vh - 32px))!important;border-radius:24px!important;padding:22px 20px!important}
}

/* v0.4.43 requested portal/course refinements */
.rlt-password-field-wrap{position:relative;display:block;width:100%}
.rlt-password-field-wrap input[type="password"],.rlt-password-field-wrap input[type="text"]{padding-inline-end:56px!important}
.rlt-show-password-toggle{position:absolute;inset-inline-end:10px;top:50%;transform:translateY(-50%);width:40px;height:40px;border:0;border-radius:12px;background:#f3f4f6;color:#111827;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;font-size:18px;line-height:1;box-shadow:none;z-index:3}
.rlt-show-password-toggle:hover,.rlt-show-password-toggle.is-visible{background:#fff0f4;color:var(--rlt-primary,#cc3553)}

.rlt-course-detail-columns{display:grid;grid-template-columns:minmax(320px,.9fr) minmax(0,1.25fr);gap:22px;align-items:start;margin-top:22px}
.rlt-course-detail-column{min-width:0}
.rlt-course-detail-columns .rlt-content-panel,.rlt-course-detail-columns .rlt-curriculum-panel{height:100%;margin-bottom:0;box-sizing:border-box}
.rlt-course-info-column .rlt-rich-content{overflow-wrap:anywhere}
.rlt-course-curriculum-column .rlt-curriculum-header{align-items:flex-start;gap:12px}
.rlt-course-curriculum-column .rlt-curriculum-header .rlt-button{white-space:nowrap}

.rlt-school-portal-topbar{position:relative;top:auto;z-index:auto;max-width:100%;box-sizing:border-box;overflow:visible;backdrop-filter:none}
.rlt-school-portal-topbar-split{margin-bottom:0;border-bottom-left-radius:0!important;border-bottom-right-radius:0!important}
.rlt-school-portal-sticky-menu{position:sticky;top:0;z-index:999;max-width:100%;min-width:0;box-sizing:border-box;overflow-x:auto;overflow-y:hidden;flex-wrap:nowrap!important;-webkit-overflow-scrolling:touch;overscroll-behavior-x:contain;scrollbar-width:thin;background:#fff;border:1px solid #e5e7eb;border-top:0;border-radius:0 0 24px 24px;margin:0 0 24px;box-shadow:0 16px 45px rgba(17,24,39,.08)}
.admin-bar .rlt-school-portal-sticky-menu{top:32px}
.rlt-school-portal-menu,.rlt-school-portal-menu-full{max-width:100%;min-width:0;box-sizing:border-box;overflow-x:auto;overflow-y:hidden;flex-wrap:nowrap!important;-webkit-overflow-scrolling:touch;overscroll-behavior-x:contain;scrollbar-width:thin}
.rlt-school-portal-menu a,.rlt-school-portal-menu-full a,.rlt-school-portal-menu .rlt-language-switcher,.rlt-school-portal-menu-full .rlt-language-switcher{flex:0 0 auto;white-space:nowrap}
.rlt-school-portal-menu .rlt-language-switcher,.rlt-school-portal-menu-full .rlt-language-switcher{display:inline-flex;align-items:center}
.rlt-school-portal-menu-full .rlt-portal-logout-link{margin-inline-start:8px!important}
.rtl .rlt-school-portal-menu-full .rlt-portal-logout-link{margin-inline-start:8px!important;margin-inline-end:0!important}
.rlt-course-complete-journal-notice{margin-bottom:18px}


/* v0.4.46 WPBakery toggle/FAQ fallback inside LMS shortcode views */
.rlt-rich-content .vc_toggle{border:1px solid #e5e7eb;border-radius:18px;background:#fff;margin:0 0 14px;overflow:hidden;box-shadow:0 10px 28px rgba(17,24,39,.04)}
.rlt-rich-content .vc_toggle_title{position:relative;display:block;cursor:pointer;padding:17px 58px 17px 20px;color:#111827;transition:background .2s ease,color .2s ease;user-select:none}
.rtl .rlt-rich-content .vc_toggle_title{padding:17px 20px 17px 58px}
.rlt-rich-content .vc_toggle_title:hover{background:#fff3f6;color:var(--rlt-primary,#cc3553)}
.rlt-rich-content .vc_toggle_title h4{font-size:18px;line-height:1.45;margin:0!important;font-weight:900;color:inherit;text-align:inherit}
.rlt-rich-content .vc_toggle_icon{position:absolute;inset-inline-end:22px;top:50%;width:22px;height:22px;transform:translateY(-50%);border-radius:50%;background:#fff3f6;border:1px solid var(--rlt-primary-hover,#f0c3cc)}
.rtl .rlt-rich-content .vc_toggle_icon{inset-inline-end:auto;inset-inline-start:auto;left:22px;right:auto}
.rlt-rich-content .vc_toggle_icon:before,.rlt-rich-content .vc_toggle_icon:after{content:"";position:absolute;left:50%;top:50%;width:10px;height:2px;background:var(--rlt-primary,#cc3553);border-radius:99px;transform:translate(-50%,-50%);transition:transform .2s ease,opacity .2s ease}
.rlt-rich-content .vc_toggle_icon:after{transform:translate(-50%,-50%) rotate(90deg)}
.rlt-rich-content .vc_toggle.vc_toggle_active .vc_toggle_icon:after,.rlt-rich-content .vc_toggle.rlt-vc-toggle-open .vc_toggle_icon:after{opacity:0;transform:translate(-50%,-50%) rotate(0deg)}
.rlt-rich-content .vc_toggle_content{display:none;padding:0 20px 20px;margin:0;color:#374151;line-height:1.85}
.rlt-rich-content .vc_toggle.vc_toggle_active .vc_toggle_content,.rlt-rich-content .vc_toggle.rlt-vc-toggle-open .vc_toggle_content{display:block}
.rlt-rich-content .vc_toggle_content > :first-child{margin-top:0}
.rlt-rich-content .vc_toggle_content > :last-child{margin-bottom:0}

@media(max-width:782px){.admin-bar .rlt-school-portal-sticky-menu{top:46px}}
@media(max-width:900px){
  .rlt-course-detail-columns{grid-template-columns:1fr;gap:18px}
  .rlt-course-curriculum-column{order:1}
  .rlt-course-info-column{order:2}
  .rlt-school-portal-topbar{border-radius:18px 18px 0 0;margin-inline:0;width:100%}
  .rlt-school-portal-sticky-menu{border-radius:0 0 18px 18px;width:100%}
  .rlt-school-portal-menu,.rlt-school-portal-menu-full{justify-content:flex-start!important;padding-inline:8px!important}
  .rlt-school-portal-menu a,.rlt-school-portal-menu-full a{max-width:none}
}


/* v0.4.47: keep WPBakery toggle +/- icon on the visual left in Arabic/RTL course info. */
.rlt-course-view-shell.rlt-rtl .rlt-rich-content .vc_toggle_title,
[dir="rtl"] .rlt-course-view-shell .rlt-rich-content .vc_toggle_title,
html[dir="rtl"] .rlt-course-view-shell .rlt-rich-content .vc_toggle_title,
body.rtl .rlt-course-view-shell .rlt-rich-content .vc_toggle_title{
    padding-right:20px!important;
    padding-left:64px!important;
}
.rlt-course-view-shell.rlt-rtl .rlt-rich-content .vc_toggle_icon,
[dir="rtl"] .rlt-course-view-shell .rlt-rich-content .vc_toggle_icon,
html[dir="rtl"] .rlt-course-view-shell .rlt-rich-content .vc_toggle_icon,
body.rtl .rlt-course-view-shell .rlt-rich-content .vc_toggle_icon{
    inset-inline-start:auto!important;
    inset-inline-end:auto!important;
    right:auto!important;
    left:22px!important;
}
.rlt-course-view-shell.rlt-rtl .rlt-rich-content .vc_toggle_title h4,
[dir="rtl"] .rlt-course-view-shell .rlt-rich-content .vc_toggle_title h4,
html[dir="rtl"] .rlt-course-view-shell .rlt-rich-content .vc_toggle_title h4,
body.rtl .rlt-course-view-shell .rlt-rich-content .vc_toggle_title h4{
    padding-right:0!important;
    padding-left:0!important;
    text-align:right;
}

/* v0.4.48: Forced Arabic school registration shortcode */
.rlt-registration-lang-ar,
.rlt-registration-lang-ar .rlt-form-card,
.rlt-registration-lang-ar .rlt-form{
  direction:rtl;
  text-align:right;
}
.rlt-registration-lang-ar .rlt-form input,
.rlt-registration-lang-ar .rlt-form textarea{
  text-align:right;
}
.rlt-registration-lang-ar .rlt-form input[type="email"],
.rlt-registration-lang-ar .rlt-form input[name="slug"]{
  direction:ltr;
  text-align:left;
}
.rlt-registration-lang-ar .rlt-form input[type="file"]{
  direction:rtl;
}

/* v0.4.53: YouTube lesson progress support + hide YouTube end-screen suggestions inside lessons */
.rlt-responsive-embed.rlt-youtube-embed,
.rlt-responsive-embed[data-rlt-video-wrap="1"]{position:relative;overflow:hidden}
.rlt-youtube-complete-overlay{position:absolute;inset:0;display:none;align-items:center;justify-content:center;text-align:center;padding:24px;background:rgba(11,15,30,.82);color:#fff;z-index:8;pointer-events:none;border-radius:inherit}
.rlt-youtube-ended .rlt-youtube-complete-overlay{display:flex}
.rlt-youtube-complete-overlay div{display:flex;flex-direction:column;gap:8px;align-items:center;justify-content:center;max-width:80%}
.rlt-youtube-complete-overlay strong{font-size:22px;font-weight:900;line-height:1.25;color:#fff}
.rlt-youtube-complete-overlay span{font-size:15px;font-weight:700;color:rgba(255,255,255,.88)}


/* v0.4.54 guided tips shake fix: floating targets must stay fixed and the tour should not animate them. */
.rlt-ai-floating-journal.rlt-tour-target-active,
.rlt-tips-floating-button.rlt-tour-target-active{
  position:fixed!important;
  transform:none!important;
  animation:none!important;
}
.rlt-tour-is-open .rlt-ai-floating-journal,
.rlt-tour-is-open .rlt-tips-floating-button{
  will-change:auto!important;
}

/* v0.4.56 compact demo portal quick-login helpers. Visible only when the current school portal slug is /demo. */
.rlt-demo-login-panel{
    margin:14px 0 18px;
    padding:12px;
    border:1px solid #f5d4dd;
    border-radius:18px;
    background:linear-gradient(145deg,#fff7f9,#ffffff);
    box-shadow:0 10px 26px rgba(204,53,83,.07);
}
.rlt-demo-login-panel-compact{
    display:grid;
    gap:10px;
}
.rlt-demo-login-head{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:10px;
    margin-bottom:0;
}
.rlt-demo-login-head strong{
    color:#111827;
    font-size:15px;
    font-weight:900;
}
.rlt-demo-login-head span{
    color:#667085;
    font-size:13px;
    line-height:1.45;
}
.rlt-demo-login-actions{
    display:grid;
    grid-template-columns:repeat(3,minmax(0,1fr));
    gap:8px;
    margin-bottom:0;
}
.rlt-demo-login-button{
    position:relative;
    border:1px solid #f3bdca;
    background:#fff;
    color:var(--rlt-primary,#cc3553);
    border-radius:15px;
    min-height:42px;
    padding:9px 10px;
    font-weight:900;
    cursor:pointer;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    gap:7px;
    transition:background .18s ease,color .18s ease,border-color .18s ease,transform .18s ease;
}
.rlt-demo-login-button:hover,
.rlt-demo-login-button:focus-visible,
.rlt-demo-login-button.is-selected{
    background:var(--rlt-primary,#cc3553);
    color:#fff;
    border-color:var(--rlt-primary,#cc3553);
    transform:translateY(-1px);
}
.rlt-demo-login-button::after{
    content:attr(data-rlt-demo-tip);
    position:absolute;
    left:50%;
    bottom:calc(100% + 10px);
    transform:translateX(-50%) translateY(4px);
    min-width:220px;
    max-width:280px;
    padding:9px 11px;
    border-radius:12px;
    background:#111827;
    color:#fff;
    font-size:12px;
    line-height:1.35;
    font-weight:700;
    white-space:normal;
    box-shadow:0 12px 30px rgba(17,24,39,.22);
    opacity:0;
    pointer-events:none;
    visibility:hidden;
    z-index:30;
}
.rlt-demo-login-button::before{
    content:'';
    position:absolute;
    left:50%;
    bottom:calc(100% + 4px);
    transform:translateX(-50%);
    border:6px solid transparent;
    border-top-color:#111827;
    opacity:0;
    visibility:hidden;
    z-index:31;
}
.rlt-demo-login-button:hover::after,
.rlt-demo-login-button:hover::before,
.rlt-demo-login-button:focus-visible::after,
.rlt-demo-login-button:focus-visible::before{
    opacity:1;
    visibility:visible;
    transform:translateX(-50%) translateY(0);
}
.rlt-demo-login-credentials,
.rlt-demo-credential-row{
    display:none!important;
}
@media(max-width:760px){
    .rlt-demo-login-actions{
        grid-template-columns:1fr;
    }
    .rlt-demo-login-button::after{
        left:0;
        right:0;
        transform:translateY(4px);
        min-width:0;
        max-width:none;
    }
    .rlt-demo-login-button:hover::after,
    .rlt-demo-login-button:focus-visible::after{
        transform:translateY(0);
    }
    .rlt-demo-login-button::before{
        left:24px;
    }
}

/* v0.4.59 demo feature locking */
.rlt-demo-feature-lock{margin:12px 0;padding:12px 14px;border-radius:14px;background:#fff7ed;border:1px solid #fed7aa;color:#9a3412;font-weight:900;line-height:1.5}.rlt-text-avatar-generator.is-demo-locked{background:linear-gradient(135deg,#fff7ed,#fff);border-color:#fed7aa}.rlt-ai-journal-card .rlt-ai-journal-availability.is-inactive{line-height:1.5}

/* Certificate default platform logo - v0.4.60 */
.rlt-certificate-platform-logo{display:block;max-width:160px;max-height:90px;margin:0 auto 18px;object-fit:contain}
