/* /critical_mind/assets/critical_mind.css — v6 */

/* ── الصفحة الرئيسية ──────────────────────────────────────────────────── */
.cm-page { max-width: 1100px; margin: 0 auto; padding: 0 16px 48px; }

/* ── Hero ─────────────────────────────────────────────────────────────── */
.cm-hero {
  margin-bottom: 36px;
  border-radius: 20px;
  overflow: hidden;
  border: 1px solid rgba(9,58,83,.14);
  background: linear-gradient(135deg, #FFF4DD 0%, #f0fbfb 100%);
}
.cm-hero-grid {
  display: grid;
  grid-template-columns: 1fr 420px;
  min-height: 340px;
  align-items: center;
}
@media (max-width: 900px) {
  .cm-hero-grid { grid-template-columns: 1fr; }
  .cm-hero-visual { display: none; }
}
.cm-hero-text { padding: 32px 36px; }
.cm-hero-kicker {
  font-size: 11px; font-weight: 600; letter-spacing: .1em;
  text-transform: uppercase; color: #7a6030; margin-bottom: 8px;
}
.cm-hero-title {
  font-size: 26px; font-weight: 700; color: #093A53;
  line-height: 1.3; margin: 0 0 12px;
}
.cm-hero-title em { font-style: normal; color: #188283; }
.cm-hero-desc {
  font-size: 14px; color: #4a3c1a;
  line-height: 1.75; margin: 0 0 16px;
}
.cm-hero-feats { display: flex; flex-direction: column; gap: 8px; margin-bottom: 16px; }
.cm-hero-feat  { display: flex; align-items: flex-start; gap: 8px; font-size: 13.5px; color: #093A53; }
.cm-hero-pip   { flex-shrink: 0; width: 8px; height: 8px; border-radius: 50%; margin-top: 5px; }
.cm-hero-note  { font-size: 12.5px; line-height: 1.65; padding: 10px 14px; border-radius: 10px; }
.cm-hero-note--guest  { background: rgba(233,182,34,.12); color: #7a5c10; }
.cm-hero-note--member { background: rgba(26,140,148,.10); color: #0c5259; }
.cm-hero-note a { color: inherit; font-weight: 600; }
.cm-hero-visual { background: #0b1115; }
.cm-hero-svg    { display: block; width: 100%; height: auto; }

/* ── Badges ───────────────────────────────────────────────────────────── */
.cm-badge {
  display: inline-block; padding: 2px 8px; border-radius: 999px;
  font-size: 11px; font-weight: 600; white-space: nowrap; margin-right: 4px;
}
.cm-badge--free    { background: #dcfce7; color: #166534; }
.cm-badge--premium { background: #fef9c3; color: #854d0e; }
.cm-badge--lock    { background: #fee2e2; color: #991b1b; }

/* ── Buttons ──────────────────────────────────────────────────────────── */
.cm-btn {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 8px 14px; border-radius: 10px; font-size: 13px; font-weight: 600;
  border: none; cursor: pointer; text-decoration: none;
  transition: opacity .15s, transform .1s;
}
.cm-btn:hover { opacity: .88; }
.cm-btn:active { transform: scale(.97); }
.cm-btn--primary { background: #1a8c94; color: #fff; }
.cm-btn--outline { background: transparent; border: 1.5px solid #1a8c94; color: #1a8c94; }
.cm-btn--ghost   { background: rgba(10,58,74,.07); color: rgba(10,58,74,.75); }
.cm-btn--gold    { background: #e9b622; color: #fff; }
.cm-btn--sm { padding: 5px 10px; font-size: 12px; border-radius: 8px; }

/* ── Domains Section ──────────────────────────────────────────────────── */
.cm-section-header { margin-bottom: 20px; }
.cm-section-title  { font-size: 18px; font-weight: 800; color: #093A53; margin: 0 0 4px; }
.cm-section-sub    { font-size: 13.5px; color: rgba(10,58,74,.60); margin: 0; }

.cm-domain-card {
  border: 1px solid rgba(10,58,74,.12);
  border-radius: 14px; background: #fff;
  margin-bottom: 12px; overflow: hidden;
  transition: box-shadow .2s;
}
.cm-domain-card:hover { box-shadow: 0 4px 18px rgba(10,58,74,.10); }
.cm-domain-card.cm-domain-open { border-color: var(--dom-color, #1a8c94); }
.cm-domain-locked { opacity: .75; }

.cm-domain-head {
  display: flex; align-items: center; gap: 10px; padding: 14px 16px; cursor: default;
}
.cm-domain-dot   { width: 14px; height: 14px; border-radius: 50%; flex-shrink: 0; }
.cm-domain-info  { flex: 1; min-width: 0; }
.cm-domain-name  { font-size: 15px; font-weight: 700; color: #093A53; }
.cm-domain-meta  { font-size: 12px; color: rgba(10,58,74,.55); margin-top: 2px; }
.cm-domain-desc  { font-size: 13px; color: rgba(10,58,74,.65); padding: 0 16px 12px; margin: 0; line-height: 1.6; }

.cm-domain-toggle {
  background: transparent; border: none; cursor: pointer;
  color: rgba(10,58,74,.5); padding: 4px; border-radius: 6px;
  transition: transform .2s, color .15s;
}
.cm-domain-card.cm-domain-open .cm-domain-toggle { transform: rotate(180deg); color: var(--dom-color, #1a8c94); }

/* ── Paths List ───────────────────────────────────────────────────────── */
.cm-paths-list { border-top: 1px solid rgba(10,58,74,.08); padding: 8px 16px; background: #fafcfc; }
.cm-paths-empty { font-size: 12.5px; color: rgba(10,58,74,.45); padding: 10px 0; text-align: center; }

.cm-path-item {
  display: flex; align-items: center; justify-content: space-between;
  gap: 12px; padding: 10px 0; border-bottom: 1px solid rgba(10,58,74,.06);
  flex-wrap: wrap;
}
.cm-path-item:last-child { border-bottom: none; }
.cm-path-locked { opacity: .65; }
.cm-path-done .cm-path-name { color: #166534; }
.cm-path-started .cm-path-name { color: #1a8c94; }

.cm-path-info  { flex: 1; min-width: 0; }
.cm-path-name  { font-size: 14px; font-weight: 600; color: #093A53; margin-bottom: 2px; }
.cm-path-meta  { font-size: 11.5px; color: rgba(10,58,74,.50); }
.cm-path-desc  { font-size: 12.5px; color: rgba(10,58,74,.60); margin-top: 3px; line-height: 1.5; }
.cm-path-actions { display: flex; gap: 6px; flex-shrink: 0; }
.cm-path-checkmark { color: #16a34a; margin-left: 4px; }

/* ── Atlas Section ────────────────────────────────────────────────────── */
.cm-atlas-section { margin-bottom: 32px; border-radius: 18px; overflow: hidden; border: 1px solid rgba(0,0,0,.10); }
.cm-atlas-section.is-hidden { display: none; }
.cm-atlas-section:fullscreen { border-radius: 0; }

/* ── Toolbar ──────────────────────────────────────────────────────────── */
.cm-toolbar {
  display: flex; align-items: center; justify-content: space-between;
  padding: 10px 14px; background: #0e1520;
  border-bottom: 1px solid rgba(255,255,255,.08); flex-wrap: wrap; gap: 8px;
}
.cm-toolbar-right   { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; }
.cm-toolbar-label   { font-size: 13px; font-weight: 600; color: rgba(255,255,255,.85); }
.cm-toolbar-btns    { display: flex; align-items: center; gap: 6px; }

.cm-tool-btn {
  display: flex; align-items: center; gap: 5px;
  padding: 6px 10px; border-radius: 8px; border: none; cursor: pointer;
  background: rgba(255,255,255,.07); color: rgba(255,255,255,.75);
  font-size: 12.5px; transition: background .15s;
}
.cm-tool-btn:hover       { background: rgba(255,255,255,.13); }
.cm-tool-btn--gold       { background: rgba(233,182,34,.2); color: #f5d060; }
.cm-tool-btn--gold:hover { background: rgba(233,182,34,.32); }
.cm-tool-btn--exit       { background: rgba(220,90,90,.15); color: rgba(255,150,150,.85); }
.cm-tool-btn--exit:hover { background: rgba(220,90,90,.25); }

/* ── Progress bar ─────────────────────────────────────────────────────── */
.cm-progress-bar-wrap {
  display: flex; align-items: center; gap: 7px; cursor: help;
}
.cm-progress-track {
  background: rgba(255,255,255,.15); border-radius: 999px;
  height: 5px; width: 90px; overflow: hidden; flex-shrink: 0;
}
.cm-progress-bar {
  height: 100%; background: #4ade80; border-radius: 999px;
  transition: width .5s ease;
}
.cm-progress-text {
  font-size: 12px; font-weight: 700; color: rgba(255,255,255,.80);
  white-space: nowrap; min-width: 32px;
}

/* ── Quiz Banner ──────────────────────────────────────────────────────── */
.cm-quiz-banner {
  background: rgba(233,182,34,.15);
  border-bottom: 1px solid rgba(233,182,34,.3);
  padding: 8px 14px;
  display: flex; align-items: center; justify-content: space-between; gap: 12px;
  font-size: 13px; color: #f5d060; flex-wrap: wrap;
}
.cm-quiz-banner-btns { display: flex; gap: 6px; }

/* ── Layout ───────────────────────────────────────────────────────────── */
.cm-atlas-layout {
  display: grid; grid-template-columns: 1fr 400px;
  height: 72vh; min-height: 560px;
}
@media (max-width: 992px) {
  .cm-atlas-layout { grid-template-columns: 1fr; height: auto; min-height: auto; }
}

/* ── Canvas ───────────────────────────────────────────────────────────── */
.cm-canvas-wrap {
  position: relative; overflow: hidden;
  background: radial-gradient(700px 420px at 60% 30%, rgba(26,140,148,.15), transparent 65%),
              radial-gradient(500px 400px at 30% 60%, rgba(233,182,34,.09), transparent 65%),
              #0b1115;
  height: 100%;
}
#cm-canvas { width: 100%; height: 100%; display: block; }

/* ── Legend ───────────────────────────────────────────────────────────── */
.cm-legend {
  position: absolute; bottom: 12px; right: 12px;
  background: rgba(11,17,21,.85); border: 1px solid rgba(255,255,255,.1);
  border-radius: 10px; padding: 8px 12px; font-size: 11px; color: rgba(255,255,255,.70);
  backdrop-filter: blur(4px);
}
.cm-legend-title { font-weight: 700; margin-bottom: 5px; color: rgba(255,255,255,.85); }
.cm-legend-item  { display: flex; align-items: center; gap: 6px; margin-bottom: 3px; }
.cm-legend-item:last-child { margin-bottom: 0; }
.cm-legend-dot   { width: 9px; height: 9px; border-radius: 50%; flex-shrink: 0; }

/* ── Panel ────────────────────────────────────────────────────────────── */
.cm-panel {
  background: #0e151b; border-right: 1px solid rgba(255,255,255,.08);
  color: #e9eef2; overflow-y: auto; height: 100%; padding: 14px;
}
.cm-panel-empty {
  display: flex; flex-direction: column; align-items: center;
  justify-content: center; height: 100%;
  color: rgba(233,238,242,.45); font-size: 14px; text-align: center;
  line-height: 1.8;
}

/* ── Node Card ────────────────────────────────────────────────────────── */
.cm-card {
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 14px; padding: 14px;
  box-shadow: 0 8px 24px rgba(0,0,0,.22);
}
.cm-card h2 { margin: 0 0 8px; font-size: 22px; letter-spacing: .2px; }
.cm-meta    { display: flex; flex-wrap: wrap; gap: 6px; margin: 8px 0 12px; }
.cm-pill {
  font-size: 11.5px; padding: 3px 9px; border-radius: 999px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(0,0,0,.18); color: rgba(233,238,242,.88);
}
.cm-section { margin-top: 12px; padding-top: 10px; border-top: 1px solid rgba(255,255,255,.08); }
.cm-section h3 { margin: 0 0 6px; font-size: 13px; color: rgba(233,238,242,.88); }
.cm-section p  { margin: 0; font-size: 14px; line-height: 1.9; color: rgba(233,238,242,.76); }
.cm-section ul { margin: 6px 0 0; padding-right: 18px; font-size: 14px; line-height: 1.9; color: rgba(233,238,242,.76); }

/* ── Reflective Questions ─────────────────────────────────────────────── */
.cm-reflective-section { margin-top: 14px; padding-top: 12px; border-top: 1px solid rgba(255,255,255,.08); }
.cm-reflective-title   { font-size: 12px; font-weight: 700; color: rgba(26,140,148,.9); margin-bottom: 8px; display: flex; align-items: center; gap: 5px; }
.cm-reflective-loading { font-size: 12px; color: rgba(255,255,255,.45); }
.cm-ref-q {
  display: block; width: 100%; text-align: right; padding: 8px 12px;
  background: rgba(26,140,148,.12); border: 1px solid rgba(26,140,148,.25);
  border-radius: 10px; color: rgba(233,238,242,.88); font-size: 13px;
  cursor: pointer; margin-bottom: 6px; transition: background .15s;
}
.cm-ref-q:hover { background: rgba(26,140,148,.22); }

/* ── Reflective Modal ─────────────────────────────────────────────────── */
.cm-ref-modal-bg {
  display: none; position: fixed; inset: 0;
  background: rgba(0,0,0,.6); z-index: 9000;
  align-items: center; justify-content: center;
}
.cm-ref-modal-bg.open { display: flex; }
.cm-ref-modal {
  background: #0e1920; border: 1px solid rgba(255,255,255,.12);
  border-radius: 16px; width: min(640px, 96vw);
  max-height: 80vh; display: flex; flex-direction: column;
  box-shadow: 0 24px 64px rgba(0,0,0,.45);
  color: #e9eef2;
}
.cm-ref-modal-hd {
  padding: 12px 16px; border-bottom: 1px solid rgba(255,255,255,.10);
  display: flex; align-items: center; justify-content: space-between;
}
.cm-ref-modal-hd h4 { margin: 0; font-size: 14px; color: rgba(233,238,242,.9); }
.cm-ref-modal-close {
  background: transparent; border: none; font-size: 22px; line-height: 1;
  color: rgba(255,255,255,.5); cursor: pointer;
}
.cm-ref-modal-body { padding: 14px; overflow-y: auto; flex: 1; }
.cm-ref-audio-btn {
  display: flex; align-items: center; gap: 6px;
  background: rgba(26,140,148,.18); border: 1px solid rgba(26,140,148,.3);
  border-radius: 10px; padding: 8px 12px; color: #a5f3fc;
  font-size: 13px; cursor: pointer; margin-bottom: 12px;
  width: 100%; transition: background .15s;
}
.cm-ref-audio-btn:hover { background: rgba(26,140,148,.28); }
.cm-ref-audio-el { margin-bottom: 12px; width: 100%; }
.cm-ref-ai-text {
  font-size: 13.5px; line-height: 1.85; color: rgba(233,238,242,.80);
  padding: 10px 12px; background: rgba(255,255,255,.04);
  border-radius: 10px; margin-bottom: 10px;
}
.cm-ref-chat-area {
  background: rgba(0,0,0,.25); border-radius: 10px;
  padding: 10px; min-height: 80px; margin-bottom: 10px;
  font-size: 13px; line-height: 1.75; color: rgba(233,238,242,.70);
}
.cm-ref-input-row { display: flex; gap: 8px; }
.cm-ref-input {
  flex: 1; padding: 9px 12px; border-radius: 10px;
  background: rgba(255,255,255,.07); border: 1px solid rgba(255,255,255,.14);
  color: #e9eef2; font-size: 13px;
}
.cm-ref-input::placeholder { color: rgba(255,255,255,.35); }
.cm-ref-send {
  padding: 9px 14px; background: #1a8c94; border: none;
  border-radius: 10px; color: #fff; font-size: 13px; cursor: pointer;
}
.cm-ref-send:hover { opacity: .88; }

/* ── Path complete button ─────────────────────────────────────────────── */
.cm-complete-path-row { margin-top: 14px; padding-top: 12px; border-top: 1px solid rgba(255,255,255,.08); }

/* ── Accordion ────────────────────────────────────────────────────────── */
.cm-accordion-section { margin-top: 32px; }

/* ── Path Track (قائمة عقد المسار في الـ panel) ─────────────────────── */
.cm-path-track {
  padding: 10px 0 4px;
  margin-bottom: 8px;
}
.cm-track-header {
  font-size: 11px; font-weight: 700; text-transform: uppercase;
  letter-spacing: .07em; color: rgba(233,238,242,.40);
  margin-bottom: 8px; padding-bottom: 5px;
  border-bottom: 1px solid rgba(255,255,255,.07);
}
.cm-track-row {
  display: flex; align-items: center; gap: 8px;
  padding: 5px 4px; border-radius: 6px;
  font-size: 12.5px; line-height: 1.3;
  transition: background .12s;
}
.cm-track-done {
  color: rgba(233,238,242,.85);
}
.cm-track-pending {
  color: rgba(233,238,242,.38);
}
.cm-track-icon {
  font-size: 11px; width: 16px; text-align: center; flex-shrink: 0;
}
.cm-track-done .cm-track-icon  { color: #4ade80; }
.cm-track-pending .cm-track-icon { color: rgba(255,255,255,.25); }
.cm-track-title { flex: 1; }
.cm-panel-hint {
  font-size: 11.5px; color: rgba(233,238,242,.30); text-align: center;
  padding: 8px 0 2px; line-height: 1.6;
}

/* ── Section headers — تمييز عناوين الأقسام ─────────────────────────── */
.cm-section { margin-top: 14px; padding-top: 12px; border-top: 1px solid rgba(255,255,255,.07); }
.cm-section-head {
  display: flex; align-items: center; gap: 7px; margin-bottom: 7px;
}
.cm-section-icon {
  width: 22px; height: 22px; border-radius: 6px; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  background: rgba(26,140,148,.18); color: rgba(26,140,148,.95);
  font-size: 11px; font-weight: 700;
}
.cm-section-title {
  margin: 0; font-size: 11.5px; font-weight: 700;
  text-transform: uppercase; letter-spacing: .07em;
  color: rgba(26,140,148,.85);
}
