/**
 * Tichr Student Course Player — Shell CSS
 *
 * Design tokens (:root, [data-theme="dark"], [lang="he"]) live in
 * resources/views/student/layouts/app.blade.php.
 * This file covers layout, components, and motion only.
 */

/* ═══════════════════════════════════
   PREVIEW BANNER
═══════════════════════════════════ */
.banner {
  position:fixed; top:0; left:0; right:0;
  height:var(--banner-h);
  background:var(--ink); display:flex; align-items:center; justify-content:center;
  gap:12px; font-size:12px; font-weight:500;
  color:rgba(255,255,255,.65); z-index:1000;
}
[data-theme="dark"] .banner { background:#0F0D0A; }
.banner a { color:#fff; text-decoration:underline; text-underline-offset:2px; }

/* ═══════════════════════════════════
   APP SHELL — DESKTOP GRID
═══════════════════════════════════ */
.app {
  display:grid;
  grid-template-columns:var(--sw) 1fr;
  grid-template-rows:var(--topbar-h) 1fr;
  height:100vh;
  padding-top:var(--banner-h);
  box-sizing:border-box;
}

/* ═══════════════════════════════════
   SIDEBAR
═══════════════════════════════════ */
.sidebar {
  grid-column:1; grid-row:1/-1;
  background:var(--surf-1); border-right:1px solid var(--i12);
  display:flex; flex-direction:column;
  position:sticky; top:var(--banner-h);
  height:calc(100vh - var(--banner-h));
  overflow:hidden;
  transition:background var(--tm), border-color var(--tm);
}
.sb-head { padding:22px 20px 14px; border-bottom:1px solid var(--i12); flex-shrink:0; }
.sb-label { font-size:11px; font-weight:600; letter-spacing:.08em; text-transform:uppercase; color:var(--i60); margin-bottom:5px; }
.sb-title { font-family:var(--fd); font-size:16px; font-weight:500; line-height:1.3; color:var(--ink); margin-bottom:14px; }

.prog-row { display:flex; justify-content:space-between; align-items:center; margin-bottom:6px; }
.prog-label { font-size:12px; font-weight:500; color:var(--i60); }
.prog-pct { font-size:12px; font-weight:600; color:var(--cp); }
.prog-track { height:4px; background:var(--surf-2); border-radius:99px; overflow:hidden; }
.prog-fill { height:100%; background:var(--cp); border-radius:99px; transition:width var(--ts) var(--eout); }
.lesson-count { font-size:12px; color:var(--i60); margin-top:5px; }

.sb-search { padding:10px 16px; border-bottom:1px solid var(--i06); flex-shrink:0; }
.search-wrap { display:flex; align-items:center; gap:8px; background:var(--surf-2); border:1px solid var(--i12); border-radius:var(--r1); padding:7px 12px; transition:border-color var(--tf), background var(--tf); }
.search-wrap:focus-within { border-color:var(--cp); background:var(--surf-1); }
.search-wrap svg { width:14px; height:14px; color:var(--i55); flex-shrink:0; }
.search-inp { border:none; background:transparent; font-size:13px; color:var(--ink); width:100%; outline:none; }
.search-inp::placeholder { color:var(--i55); }

.sb-scroll { flex:1; min-height:0; overflow-y:auto; padding:6px 0 20px; scrollbar-width:thin; scrollbar-color:var(--surf-3) transparent; }
.sb-scroll::-webkit-scrollbar { width:4px; }
.sb-scroll::-webkit-scrollbar-thumb { background:var(--surf-3); border-radius:99px; }

/* Nav sections */
.nav-section { margin-bottom:2px; }
.sec-btn { width:100%; display:flex; align-items:center; gap:6px; padding:9px 20px; cursor:pointer; user-select:none; text-align:start; background:none; border:none; font-family:inherit; }
.sec-btn:hover .sec-name { color:var(--ink); }
.sec-name { font-size:11px; font-weight:700; letter-spacing:.07em; text-transform:uppercase; color:var(--i60); flex:1; transition:color var(--tf); }
.sec-dur { font-size:11px; color:var(--i45); white-space:nowrap; flex-shrink:0; }
.sec-chev { width:13px; height:13px; color:var(--i45); flex-shrink:0; transition:transform var(--tm) var(--eout); }
.nav-section.open .sec-chev { transform:rotate(180deg); }
.sec-lessons { overflow:hidden; max-height:0; transition:max-height var(--ts) var(--eout); list-style:none; padding:0; margin:0; }
.nav-section.open .sec-lessons { max-height:2000px; }

/* Lesson items */
.lesson-item {
  display:flex; align-items:flex-start; gap:10px; padding:7px 20px;
  cursor:pointer; position:relative; transition:background var(--tf);
  text-decoration:none; color:inherit;
}
.lesson-item::before {
  content:''; position:absolute; inset-inline-start:0; top:0; bottom:0; width:3px;
  background:var(--cp); opacity:0; border-radius:0 2px 2px 0; transition:opacity var(--tf);
}
[dir="rtl"] .lesson-item::before { border-radius:2px 0 0 2px; }
.lesson-item:hover { background:var(--surf-2); text-decoration:none !important; }
.lesson-item:hover .l-name { color:var(--ink); }
.lesson-item.active { background:var(--cp-light); }
.lesson-item.active::before { opacity:1; }
.lesson-item.active .l-name { color:var(--cp); font-weight:500; }
.lesson-item.locked { opacity:.7; }
.lesson-item.locked .l-name { color:var(--i45); }

.l-check { width:16px; height:16px; border:1.5px solid var(--i45); border-radius:4px; flex-shrink:0; margin-top:2px; display:flex; align-items:center; justify-content:center; transition:all var(--tf); }
.lesson-item.done .l-check { background:var(--cp); border-color:var(--cp); }
.lesson-item.done .l-check svg { display:block; }
.l-check svg { display:none; width:9px; height:9px; color:#fff; }
.l-info { flex:1; min-width:0; }
.l-name { font-size:13px; color:var(--i60); line-height:1.4; transition:color var(--tf); }
.l-dur { font-size:12px; color:var(--i45); margin-top:1px; font-variant-numeric:tabular-nums; }

/* Locked lesson tooltip */
.lesson-tooltip { position:relative; display:flex; width:100%; }
.tooltip-text {
  visibility:hidden; width:220px; background:var(--ink); color:var(--bg);
  text-align:start; border-radius:6px; padding:8px 12px;
  position:absolute; z-index:1000; inset-inline-start:50%;
  transform:translateX(-50%); bottom:125%;
  opacity:0; transition:opacity .2s;
  font-size:12px; line-height:1.4; pointer-events:none;
  box-shadow:0 4px 6px rgba(0,0,0,.1);
}
.lesson-tooltip:hover .tooltip-text { visibility:visible; opacity:1; }

/* Sidebar footer */
.sb-foot { padding:14px 20px; border-top:1px solid var(--i06); display:flex; align-items:center; gap:10px; flex-shrink:0; }
.avatar { width:32px; height:32px; border-radius:50%; background:var(--cp-mid); display:flex; align-items:center; justify-content:center; font-family:var(--fd); font-size:14px; font-weight:600; color:var(--cp); flex-shrink:0; }
.u-name { font-size:13px; font-weight:500; color:var(--ink); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.u-links { display:flex; gap:8px; margin-top:1px; }
.u-links a { font-size:12px; color:var(--i60); transition:color var(--tf); text-decoration:none; }
.u-links a:hover { color:var(--cp); }

/* ═══════════════════════════════════
   TOPBAR
═══════════════════════════════════ */
.topbar {
  grid-column:2; grid-row:1;
  background:var(--surf-1); border-bottom:1px solid var(--i12);
  padding:0 40px; height:var(--topbar-h);
  display:flex; align-items:center; justify-content:space-between;
  position:sticky; top:var(--banner-h); z-index:10;
  transition:background var(--tm), border-color var(--tm);
}
.tb-nav { display:flex; gap:4px; }
.tb-btn {
  display:flex; align-items:center; gap:6px; padding:7px 14px;
  border-radius:var(--r1); font-size:13px; font-weight:500;
  color:var(--i60); border:1px solid var(--i12); background:var(--surf-1);
  transition:all var(--tf); text-decoration:none !important; font-family:inherit; cursor:pointer;
}
.tb-btn:hover:not(:disabled) { color:var(--ink); border-color:var(--i45); background:var(--surf-2); text-decoration:none !important; }
/* RTL: flip prev/next arrows so they point in the correct navigation direction */
[dir="rtl"] .tb-nav .tb-btn svg { transform:scaleX(-1); }
.tb-btn:disabled { opacity:.35; cursor:not-allowed; }
.tb-btn svg { width:13px; height:13px; }
.tb-center { display:flex; flex-direction:column; align-items:center; gap:1px; }
.tb-num { font-size:12px; color:var(--i55); font-variant-numeric:tabular-nums; }
.tb-name { font-family:var(--fd); font-size:15px; font-weight:500; color:var(--ink); max-width:380px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.tb-actions { display:flex; gap:6px; align-items:center; }

/* Theme toggle */
.theme-toggle {
  display:flex; align-items:center; justify-content:center;
  width:34px; height:34px; border-radius:var(--r1);
  color:var(--i60); border:1px solid var(--i12); background:var(--surf-1);
  transition:all var(--tf); flex-shrink:0; cursor:pointer;
}
.theme-toggle:hover { color:var(--ink); border-color:var(--i45); background:var(--surf-2); }
.theme-toggle svg { width:16px; height:16px; }
.icon-sun  { display:none; }
.icon-moon { display:block; }
[data-theme="dark"] .icon-sun  { display:block; }
[data-theme="dark"] .icon-moon { display:none; }

/* ═══════════════════════════════════
   MAIN CONTENT
═══════════════════════════════════ */
.main { grid-column:2; grid-row:2; overflow-y:auto; }
.lesson-wrap { max-width:680px; margin:0 auto; padding:52px 40px 140px;  }

/* Lesson header */
.l-header { margin-bottom:40px; padding-bottom:28px; border-bottom:1px solid var(--i12); }
.l-tag { display:inline-flex; align-items:center; gap:6px; padding:4px 10px; background:var(--cp-light); color:var(--cp); border-radius:99px; font-size:12px; font-weight:600; letter-spacing:.05em; text-transform:uppercase; margin-bottom:4px; }
.l-tag-dot { width:5px; height:5px; border-radius:50%; background:var(--cp); }
.l-title { font-family:var(--fd); font-size:36px; font-weight:500; line-height:1.25; letter-spacing:-.01em; color:var(--ink); margin-bottom:16px; }
.l-meta { display:flex; align-items:center; gap:14px; flex-wrap:wrap; }
.l-meta-item { display:flex; align-items:center; gap:5px; font-size:14px; color:var(--i60); }
.l-meta-item svg { width:14px; height:14px; }
.l-meta-dot { width:3px; height:3px; border-radius:50%; background:var(--i45); }

/* TTS button — sits on the trailing edge of the meta row */
.tts-btn {
  display:flex; align-items:center; gap:5px;
  padding:5px 11px; border-radius:var(--r1);
  background:var(--surf-2); border:1px solid var(--i12);
  color:var(--i60); font-size:12px; font-weight:500;
  cursor:pointer; font-family:var(--fb);
  transition:all var(--tf); flex-shrink:0;
  margin-inline-start:auto;
}
.tts-btn:hover { color:var(--ink); border-color:var(--i45); background:var(--surf-3); }
.tts-btn.speaking { color:var(--cp); border-color:var(--cp); background:var(--cp-light); }
.tts-btn svg { width:14px; height:14px; flex-shrink:0; }

/* Lesson body */
.l-body h2 { font-family:var(--fd); font-size:22px; font-weight:500; line-height:1.35; color:var(--ink); margin-top:44px; margin-bottom:16px; }
.l-body h3 { font-family:var(--fd); font-size:18px; font-weight:500; line-height:1.4; color:var(--ink); margin-top:36px; margin-bottom:12px; }
.l-body p { font-size:17px; line-height:1.8; color:var(--ink); margin-bottom:22px; font-weight:300; }
.l-body strong { font-weight:500; }
.l-body em { font-style:italic; }
.l-body blockquote { border-inline-start:3px solid var(--cp); padding:16px 20px; margin:32px 0; background:var(--cp-light); border-radius:0 var(--r1) var(--r1) 0; font-style:italic; }
[dir="rtl"] .l-body blockquote { border-radius:var(--r1) 0 0 var(--r1); }
.l-body blockquote p { margin:0; font-size:16px; line-height:1.7; font-weight:400; }

/* Video embeds */
.l-body .video-container { width:100%; border-radius:var(--r2); overflow:hidden; margin:0 0 32px; }
.l-body .video-container iframe { width:100%; height:66vh; border:none; display:block; }

/* Action callout */
.callout { display:flex; align-items:flex-start; gap:14px; background:var(--surf-2); border:1px solid var(--surf-3); border-radius:var(--r2); padding:18px 20px; margin:32px 0; }
.callout-icon { width:36px; height:36px; background:var(--surf-1); border:1px solid var(--i12); border-radius:var(--r1); display:flex; align-items:center; justify-content:center; flex-shrink:0; font-size:16px; }
.callout-body { flex:1; }
.callout-label { font-size:12px; font-weight:700; letter-spacing:.06em; text-transform:uppercase; color:var(--i60); margin-bottom:6px; }
.callout-body p { margin:0; font-size:16px; line-height:1.65; color:var(--ink); font-weight:300; }

/* ═══════════════════════════════════
   SELF REFLECTION
═══════════════════════════════════ */
.reflect-section { margin-top:0px; padding-top:15px; }
.reflect-marker { display:flex; align-items:center; gap:12px; margin-bottom:28px; }
.reflect-line { flex:1; height:1px; background:var(--i12); }
.reflect-marker-label { font-size:12px; font-weight:700; letter-spacing:.10em; text-transform:uppercase; color:var(--i45); white-space:nowrap; display:flex; align-items:center; gap:6px; }
.reflect-dot { width:4px; height:4px; border-radius:50%; background:var(--cp); flex-shrink:0; }
.reflect-q { font-family:var(--fd) !important; font-size:24px !important; font-weight:400 !important; font-style:italic !important; line-height:1.55 !important; color:var(--ink) !important; margin-bottom:32px; max-width:560px; white-space:pre-line !important; }
.reflect-paper { position:relative; }
.reflect-paper::before { content:''; position:absolute; inset-inline-start:-16px; top:0; bottom:0; width:3px; background:var(--cp); opacity:0; border-radius:99px; transition:opacity var(--tm); }
.reflect-paper:focus-within::before { opacity:.75; }
.reflect-ta {
  width:100%; min-height:160px; background:transparent;
  background-image:repeating-linear-gradient(to bottom, transparent 0, transparent 31px, var(--surf-3) 31px, var(--surf-3) 32px);
  background-position:0 8px;
  border:none; border-bottom:1.5px solid var(--i12);
  padding:8px 0 16px; font-size:16px; line-height:2rem;
  color:var(--ink); resize:none; outline:none; caret-color:var(--cp);
  transition:border-color var(--tm); font-family:var(--fb);
}
.reflect-ta:focus { border-bottom-color:var(--cp); }
.reflect-ta::placeholder { color:var(--i55); font-style:italic; font-size:15px; }
.reflect-short-inp {
  width:100%; background:transparent;
  border:none; border-bottom:1.5px solid var(--i12);
  padding:8px 0 10px; font-size:16px; line-height:1.5;
  color:var(--ink); outline:none; caret-color:var(--cp);
  transition:border-color var(--tm); font-family:var(--fb);
}
.reflect-short-inp:focus { border-bottom-color:var(--cp); }
.reflect-actions { display:flex; align-items:center; justify-content:space-between; margin-top:20px; }
.reflect-note { display:flex; align-items:center; gap:5px; font-size:12px; color:var(--i45); font-style:italic; }
.reflect-note svg { width:11px; height:11px; flex-shrink:0; }
.btn-save { padding:8px 18px; background:transparent; color:var(--cp); border:1.5px solid var(--cp); border-radius:99px; font-size:13px; font-weight:600; letter-spacing:.02em; display:flex; align-items:center; gap:6px; transition:all var(--tf); font-family:inherit; cursor:pointer; }
.btn-save svg { width:12px; height:12px; }
.btn-save:hover { background:var(--cp); color:#fff; }
.btn-save:active { transform:scale(.97); }
.btn-save:disabled { opacity:.6; cursor:not-allowed; }

/* Reflection: multiple choice / checkboxes */
.reflect-options { display:flex; flex-direction:column; gap:8px; margin-bottom:8px; }
.reflect-option { display:flex; align-items:center; gap:10px; padding:10px 14px; background:var(--surf-2); border:1.5px solid var(--i12); border-radius:var(--r1); cursor:pointer; transition:all var(--tf); font-size:15px; color:var(--ink); }
.reflect-option:hover { border-color:var(--i30); background:var(--surf-3); }
.reflect-option input { accent-color:var(--cp); flex-shrink:0; }
/* Reflection: rating */
.reflect-rating { display:flex; gap:8px; justify-content:center; margin-bottom:8px; }
.reflect-rating button { font-size:28px; background:none; border:none; cursor:pointer; transition:transform .1s, color .2s; color:var(--i30); padding:0; }
.reflect-rating button:hover { color:#fbbf24; transform:scale(1.2); }
.reflect-rating button.active { color:#fbbf24; }

/* ═══════════════════════════════════
   COMPLETE BAR
═══════════════════════════════════ */
.complete-bar {
  position:fixed; bottom:0; inset-inline-start:var(--sw); inset-inline-end:0;
  background:var(--surf-1); border-top:1px solid var(--i12);
  padding:14px 40px; display:flex; align-items:center; justify-content:center;
  z-index:20; transition:background var(--tm);
}
.btn-complete { padding:12px 28px; background:var(--ink); color:var(--bg); border-radius:var(--r1); font-size:14px; font-weight:600; display:flex; align-items:center; gap:8px; transition:all var(--tm) var(--eout); border:1.5px solid transparent; cursor:pointer; font-family:inherit; }
.btn-complete svg { width:16px; height:16px; }
.btn-complete:hover:not(:disabled) { background:var(--cp); transform:translateY(-1px); color:#fff; }
.btn-complete:active { transform:none; }
.btn-complete.done { background:var(--cp-light); color:var(--cp); border-color:var(--cp); }
.btn-complete.done:hover { background:var(--cp-mid); transform:none; }
.btn-complete:disabled { opacity:.6; cursor:not-allowed; transform:none; }

/* ═══════════════════════════════════
   TOAST
═══════════════════════════════════ */
.toast { position:fixed; bottom:80px; inset-inline-end:24px; background:var(--surf-1); border:1px solid var(--i12); color:var(--ink); padding:10px 16px; border-radius:var(--r1); font-size:13px; font-weight:500; display:flex; align-items:center; gap:8px; z-index:600; opacity:0; transform:translateY(12px); transition:all var(--tm) var(--eout); pointer-events:none; box-shadow:0 4px 20px rgba(0,0,0,.12); }
.toast.show { opacity:1; transform:translateY(0); }
.toast svg { width:13px; height:13px; color:var(--cp); }

/* ═══════════════════════════════════
   OVERLAY
═══════════════════════════════════ */
.overlay { display:block; position:fixed; inset:0; background:rgba(26,23,20,.5); backdrop-filter:blur(2px); -webkit-backdrop-filter:blur(2px); z-index:300; opacity:0; transition:opacity var(--tm); pointer-events:none; }
.overlay.show { opacity:1; pointer-events:auto; }
[data-theme="dark"] .overlay { background:rgba(0,0,0,.65); }

/* ═══════════════════════════════════
   BOTTOM SHEETS
═══════════════════════════════════ */
.sheet { position:fixed; bottom:0; left:0; right:0; background:var(--surf-1); border-radius:20px 20px 0 0; box-shadow:0 -8px 40px rgba(0,0,0,.14); z-index:400; transform:translateY(110%); transition:transform var(--ts) var(--eout), background var(--tm); display:flex; flex-direction:column; overflow:hidden; max-height:88vh; }
.sheet.show { transform:translateY(0); }
.sheet-handle { width:36px; height:4px; background:var(--i12); border-radius:99px; margin:12px auto 0; flex-shrink:0; }
.sheet-head { padding:12px 20px; border-bottom:1px solid var(--i06); display:flex; align-items:center; justify-content:space-between; flex-shrink:0; }
.sheet-title { font-family:var(--fd); font-size:17px; font-weight:500; color:var(--ink); flex:1; }
.sheet-close { width:28px; height:28px; border-radius:50%; background:var(--surf-2); display:flex; align-items:center; justify-content:center; color:var(--i60); transition:all var(--tf); flex-shrink:0; cursor:pointer; border:none; }
.sheet-close:hover { background:var(--surf-3); color:var(--ink); }
.sheet-close svg { width:13px; height:13px; }
.sheet-progress { padding:10px 20px 12px; border-bottom:1px solid var(--i06); flex-shrink:0; }
.sheet-search { padding:8px 16px 10px; border-bottom:1px solid var(--i06); flex-shrink:0; }
.sheet-scroll { flex:1; overflow-y:auto; padding:6px 0 12px; scrollbar-width:thin; scrollbar-color:var(--surf-3) transparent; min-height:0; }
.sheet-foot { padding:8px 12px 24px; border-top:1px solid var(--i06); display:flex; gap:4px; flex-shrink:0; }
.sheet-link { flex:1; display:flex; align-items:center; justify-content:center; gap:6px; padding:10px 8px; border-radius:var(--r1); font-size:13px; font-weight:500; color:var(--i60); transition:all var(--tf); text-decoration:none !important; }
.sheet-link:hover { background:var(--surf-2); color:var(--ink); text-decoration:none !important; }
.sheet-link svg { width:15px; height:15px; }
.sheet-link.danger { color:#c0392b; }
.sheet-link.danger:hover { background:rgba(192,57,43,.1); }

/* ═══════════════════════════════════
   FONT SIZE SLIDER
═══════════════════════════════════ */
.fs-scale {
  display:flex; align-items:center; gap:2px;
  background:var(--surf-3); border-radius:99px; padding:3px; flex-shrink:0;
}
.fs-btn {
  border:none; background:transparent; cursor:pointer;
  border-radius:99px; width:30px; height:30px;
  display:flex; align-items:center; justify-content:center;
  color:var(--i60); font-family:var(--fd); font-weight:400;
  transition:all var(--tf); line-height:1; padding:0;
  user-select:none; touch-action:none;
}
.fs-btn:hover:not(.active) { color:var(--ink); }
.fs-btn.active { background:var(--surf-1); color:var(--cp); box-shadow:0 1px 4px rgba(0,0,0,.12); }

/* Font size scale values applied to lesson content */
html[data-font-size="-3"] { --content-fs:13px; --content-lh:1.7; }
html[data-font-size="-2"] { --content-fs:14px; --content-lh:1.75; }
html[data-font-size="-1"] { --content-fs:15px; --content-lh:1.77; }
html[data-font-size="1"]  { --content-fs:19px; --content-lh:1.85; }
html[data-font-size="2"]  { --content-fs:21px; --content-lh:1.9; }
html[data-font-size="3"]  { --content-fs:24px; --content-lh:2.0; }

/* Apply font size var to content — overrides lesson-typography.css when set */
html[data-font-size] .l-body p,
html[data-font-size] .lesson-content p { font-size:var(--content-fs, 17px) !important; line-height:var(--content-lh, 1.8) !important; }
html[data-font-size] .l-body li,
html[data-font-size] .lesson-content li { font-size:var(--content-fs, 17px) !important; line-height:var(--content-lh, 1.8) !important; }

/* Settings body */
.settings-body { padding:20px 20px 28px; display:flex; flex-direction:column; gap:20px; overflow-y:auto; }
.settings-sec-label { font-size:11px; font-weight:700; letter-spacing:.07em; text-transform:uppercase; color:var(--i45); margin-bottom:10px; }
.settings-row { display:flex; align-items:center; justify-content:space-between; padding:12px 14px; background:var(--surf-2); border-radius:var(--r2); gap:12px; }
.settings-row-label { font-size:14px; font-weight:500; color:var(--ink); }
.settings-row-sub { font-size:12px; color:var(--i60); margin-top:1px; }
.lang-toggle { display:flex; background:var(--surf-3); border-radius:99px; padding:2px; gap:2px; flex-shrink:0; }
.lang-btn { padding:4px 10px; border-radius:99px; font-size:12px; font-weight:600; color:var(--i60); transition:all var(--tf); border:none; background:none; cursor:pointer; font-family:inherit; }
.lang-btn.active { background:var(--surf-1); color:var(--ink); box-shadow:0 1px 4px rgba(0,0,0,.12); }
.settings-link { display:flex; align-items:center; gap:10px; padding:12px 14px; border-radius:var(--r2); font-size:14px; font-weight:500; color:var(--ink); transition:all var(--tf); text-decoration:none !important; }
.settings-link:hover { background:var(--surf-2); text-decoration:none !important; }
.settings-link svg { width:16px; height:16px; color:var(--i60); }
.settings-link.danger { color:#c0392b; }
.settings-link.danger svg { color:#c0392b; }
.settings-link.danger:hover { background:rgba(192,57,43,.1); }

/* Desktop settings — popover */
@media (min-width:769px) {
  #settingsSheet {
    bottom:auto; inset-inline-start:auto; inset-inline-end:20px;
    top:calc(var(--banner-h) + var(--topbar-h) + 8px);
    width:320px; border-radius:var(--r3); max-height:480px;
    transform:scale(.95) translateY(-10px); opacity:0;
    transition:transform var(--tm) var(--eout), opacity var(--tm), background var(--tm);
    box-shadow:0 8px 32px rgba(0,0,0,.18);
  }
  #settingsSheet.show { transform:scale(1) translateY(0); opacity:1; }
  #settingsSheet .sheet-handle { display:none; }
  #overlay.settings-open { background:transparent; backdrop-filter:none; -webkit-backdrop-filter:none; }
}

/* ═══════════════════════════════════
   MOBILE
═══════════════════════════════════ */
.mob-bar {
  display:none; position:fixed;
  top:var(--banner-h); left:0; right:0;
  height:var(--mob-bar-h);
  background:var(--surf-1); border-bottom:1px solid var(--i12);
  z-index:98; padding:0 16px;
  align-items:center; justify-content:space-between;
  transition:background var(--tm);
}
.mob-title { font-family:var(--fd); font-size:17px; font-weight:500; color:var(--ink); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; max-width:200px; }
.mob-btns { display:flex; gap:4px; align-items:center; }
.icon-btn { width:36px; height:36px; display:flex; align-items:center; justify-content:center; border-radius:var(--r1); color:var(--i60); border:1px solid var(--i12); background:var(--surf-1); transition:all var(--tf); cursor:pointer; }
.icon-btn:hover { background:var(--surf-2); color:var(--ink); }
.icon-btn svg { width:18px; height:18px; }

.mob-nav {
  display:none; position:sticky;
  top:calc(var(--banner-h) + var(--mob-bar-h));
  z-index:10;
  align-items:center; justify-content:space-between;
  padding:8px 16px; background:var(--surf-1);
  border-bottom:1px solid var(--i06);
  transition:background var(--tm);
}
.mob-lesson-name { font-family:var(--fd); font-size:16px; font-weight:500; color:var(--ink); text-align:center; flex:1; padding:0 10px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.mob-nav-btn { width:30px; height:30px; border-radius:50%; border:1px solid var(--i12); display:flex; align-items:center; justify-content:center; color:var(--i60); background:var(--surf-1); transition:all var(--tf); flex-shrink:0; text-decoration:none !important; }
.mob-nav-btn:hover:not([disabled]):not(.disabled) { border-color:var(--i45); color:var(--ink); text-decoration:none !important; }
[dir="rtl"] .mob-nav-btn svg { transform:scaleX(-1); }
.mob-nav-btn[disabled], .mob-nav-btn.disabled { opacity:.3; cursor:not-allowed; pointer-events:none; }
.mob-nav-btn svg { width:13px; height:13px; }

@media (max-width:768px) {
  .app { display:block; padding-top:calc(var(--banner-h) + var(--mob-bar-h) + var(--mob-nav-h)); }
  .sidebar, .topbar { display:none; }
  .mob-bar, .mob-nav { display:flex; }
  .lesson-wrap { padding:28px 20px 140px; padding-top: 0px; }
  .l-title { font-size:26px; }
  .l-body p { font-size:16px; }
  .reflect-q { font-size:20px !important; line-height:1.6 !important; }
  .complete-bar { inset-inline-start:0; padding:12px 20px; }
  #settingsSheet {
    right:0; left:0; width:auto; top:auto; bottom:0;
    border-radius:20px 20px 0 0; max-height:78vh;
    transform:translateY(110%); opacity:1 !important;
  }
  #settingsSheet.show { transform:translateY(0); }
  #settingsSheet .sheet-handle { display:block; }
}

/* ═══════════════════════════════════
   LOCKED LESSON STATE
═══════════════════════════════════ */
.lesson-locked { text-align:center; padding:80px 32px; }
.lesson-locked svg.lock-icon { width:64px; height:64px; margin:0 auto 24px; color:var(--i45); display:block; }
.lesson-locked h2 { font-family:var(--fd); font-size:28px; font-weight:500; color:var(--ink); margin:0 0 12px; }
.lesson-locked p { font-size:16px; color:var(--i60); max-width:480px; margin:0 auto 20px; }
.unlock-date-badge { display:inline-flex; align-items:center; gap:8px; padding:10px 18px; background:var(--cp-light); border-radius:var(--r2); color:var(--cp); font-weight:600; font-size:14px; }
.unlock-date-badge svg { width:18px; height:18px; }

/* ═══════════════════════════════════
   EMPTY STATE
═══════════════════════════════════ */
.lesson-empty { text-align:center; padding:80px 32px; }
.lesson-empty svg { width:64px; height:64px; margin:0 auto 16px; color:var(--i30); display:block; }
.lesson-empty h2 { font-family:var(--fd); font-size:28px; font-weight:500; color:var(--ink); margin:0 0 8px; }
.lesson-empty p { font-size:16px; color:var(--i60); margin:0; }

/* ═══════════════════════════════════
   SEARCH HIDDEN
═══════════════════════════════════ */
.is-search-hidden { display:none !important; }

/* ═══════════════════════════════════
   ANIMATION
═══════════════════════════════════ */
@keyframes fadeUp { from { opacity:0; transform:translateY(8px); } to { opacity:1; transform:translateY(0); } }
.lesson-wrap { animation:fadeUp .35s var(--eout) both; }

/* ═══════════════════════════════════
   HEBREW TYPOGRAPHY ADJUSTMENTS
   Frank Ruhl Libre renders tighter than Playfair;
   bump key title sizes slightly for legibility.
═══════════════════════════════════ */
[lang="he"] .sb-title { font-size:18px; line-height:1.35; }
[lang="he"] .l-title  { font-size:40px; }
[lang="he"] .tb-name  { font-size:16px; }
@media (max-width:768px) {
  [lang="he"] .l-title { font-size:30px; }
}

@media (prefers-reduced-motion:reduce) {
  *,*::before,*::after { animation-duration:.01ms !important; transition-duration:.01ms !important; }
}
