/* ============================================================
   آفاق توجيه — Frontend Styles
   ============================================================ */

:root {
  --afaq-primary: #1a3a6c;
  --afaq-accent: #2e86de;
  --afaq-accent2: #f9ca24;
  --afaq-success: #27ae60;
  --afaq-danger: #e74c3c;
  --afaq-bg: #f0f4f8;
  --afaq-card: #ffffff;
  --afaq-text: #2c3e50;
  --afaq-muted: #6c757d;
  --afaq-border: #dee2e6;
  --afaq-radius: 16px;
  --afaq-shadow: 0 4px 24px rgba(26,58,108,0.10);
}

#afaq-app {
  font-family: 'Segoe UI', Tahoma, 'Arabic UI Text', Arial, sans-serif;
  direction: rtl;
  max-width: 820px;
  margin: 0 auto;
  padding: 20px 16px 40px;
  color: var(--afaq-text);
  box-sizing: border-box;
}

#afaq-app *, #afaq-app *::before, #afaq-app *::after {
  box-sizing: border-box;
}

/* ===================== SCREENS ===================== */
.afaq-screen { display: none; }
.afaq-screen-active { display: block; }

/* ===================== CARDS ===================== */
.afaq-welcome-card,
.afaq-card,
.afaq-loading-card {
  background: var(--afaq-card);
  border-radius: var(--afaq-radius);
  box-shadow: var(--afaq-shadow);
  padding: 36px 40px;
  margin-bottom: 20px;
}

@media (max-width: 600px) {
  .afaq-welcome-card, .afaq-card, .afaq-loading-card { padding: 24px 18px; }
}

/* ===================== LOGO ===================== */
.afaq-logo-area {
  text-align: center;
  margin-bottom: 20px;
}
.afaq-logo-text {
  font-size: 36px;
  font-weight: 900;
  color: var(--afaq-primary);
  letter-spacing: 1px;
  line-height: 1;
}
.afaq-logo-text span { color: var(--afaq-accent); }
.afaq-logo-sub {
  font-size: 13px;
  color: var(--afaq-muted);
  margin-top: 4px;
}

/* ===================== WELCOME ===================== */
.afaq-welcome-badges {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  justify-content: center;
  margin-bottom: 18px;
}
.afaq-level-badge {
  background: #e8f4fd;
  color: var(--afaq-accent);
  border-radius: 50px;
  padding: 5px 14px;
  font-size: 12px;
  font-weight: 600;
}
.afaq-welcome-title {
  font-size: 26px;
  font-weight: 900;
  color: var(--afaq-primary);
  text-align: center;
  margin-bottom: 12px;
  line-height: 1.4;
}
.afaq-welcome-desc {
  color: var(--afaq-muted);
  font-size: 14px;
  text-align: center;
  line-height: 1.8;
  margin-bottom: 24px;
}
.afaq-features-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
  margin-bottom: 28px;
}
@media (max-width: 600px) { .afaq-features-grid { grid-template-columns: repeat(2, 1fr); } }
.afaq-feature {
  background: var(--afaq-bg);
  border-radius: 12px;
  padding: 14px 10px;
  text-align: center;
  font-size: 12px;
  font-weight: 600;
  color: var(--afaq-primary);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
}
.afaq-feature span:first-child { font-size: 22px; }

/* ===================== PROGRESS ===================== */
.afaq-progress-header {
  margin-bottom: 28px;
}
.afaq-step-indicator {
  font-size: 13px;
  color: var(--afaq-muted);
  font-weight: 600;
  margin-bottom: 8px;
  text-align: center;
}
.afaq-progress-bar {
  height: 8px;
  background: var(--afaq-bg);
  border-radius: 50px;
  overflow: hidden;
}
.afaq-progress-fill {
  height: 100%;
  background: linear-gradient(to left, var(--afaq-accent), var(--afaq-primary));
  border-radius: 50px;
  transition: width 0.4s ease;
}

/* ===================== SECTION TITLE ===================== */
.afaq-section-title {
  font-size: 20px;
  font-weight: 800;
  color: var(--afaq-primary);
  margin-bottom: 24px;
  padding-right: 12px;
  border-right: 4px solid var(--afaq-accent);
}

/* ===================== FORM FIELDS ===================== */
.afaq-fields-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  margin-bottom: 24px;
}
@media (max-width: 600px) { .afaq-fields-grid { grid-template-columns: 1fr; } }

.afaq-field-full { grid-column: 1 / -1; }

.afaq-label {
  display: block;
  font-size: 13px;
  font-weight: 700;
  color: var(--afaq-primary);
  margin-bottom: 6px;
}
.afaq-label .req { color: var(--afaq-danger); }

.afaq-input, .afaq-select {
  width: 100%;
  padding: 12px 14px;
  border: 2px solid var(--afaq-border);
  border-radius: 10px;
  font-size: 14px;
  font-family: inherit;
  color: var(--afaq-text);
  background: var(--afaq-bg);
  direction: rtl;
  transition: border-color 0.2s, box-shadow 0.2s;
  appearance: none;
}
.afaq-input:focus, .afaq-select:focus {
  outline: none;
  border-color: var(--afaq-accent);
  box-shadow: 0 0 0 3px rgba(46,134,222,0.15);
  background: #fff;
}

/* ===================== QUESTIONS ===================== */
.afaq-question { display: none; }
.afaq-question-active { display: block; }

.afaq-q-badge {
  display: inline-block;
  border-radius: 6px;
  padding: 3px 12px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.5px;
  margin-bottom: 14px;
}
.afaq-q-badge-riasec { background: #e8f4fd; color: var(--afaq-accent); }
.afaq-q-badge-mbti   { background: #f0e8fd; color: #8e44ad; }
.afaq-q-badge-vak    { background: #e8fdf0; color: var(--afaq-success); }

.afaq-q-text {
  font-size: 18px;
  font-weight: 700;
  color: var(--afaq-primary);
  line-height: 1.6;
  margin-bottom: 22px;
}

.afaq-options {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.afaq-option {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 18px;
  border: 2px solid var(--afaq-border);
  border-radius: 12px;
  cursor: pointer;
  transition: all 0.2s;
  background: var(--afaq-bg);
}
.afaq-option:hover {
  border-color: var(--afaq-accent);
  background: #e8f4fd;
}
.afaq-option.selected {
  border-color: var(--afaq-accent);
  background: linear-gradient(135deg, #e8f4fd, #d6eaf8);
  box-shadow: 0 2px 8px rgba(46,134,222,0.15);
}
.afaq-radio { display: none; }
.afaq-option-label {
  font-size: 14px;
  font-weight: 500;
  color: var(--afaq-text);
  flex: 1;
}
.afaq-option.selected .afaq-option-label { color: var(--afaq-primary); font-weight: 700; }
.afaq-option::before {
  content: '';
  width: 20px;
  height: 20px;
  border: 2px solid var(--afaq-border);
  border-radius: 50%;
  flex-shrink: 0;
  transition: all 0.2s;
}
.afaq-option.selected::before {
  background: var(--afaq-accent);
  border-color: var(--afaq-accent);
  box-shadow: inset 0 0 0 4px #fff;
}

/* ===================== BUTTONS ===================== */
.afaq-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 13px 28px;
  border-radius: 10px;
  font-size: 15px;
  font-weight: 700;
  font-family: inherit;
  cursor: pointer;
  border: 2px solid transparent;
  transition: all 0.2s;
  text-decoration: none;
  gap: 8px;
  direction: rtl;
}
.afaq-btn-full { width: 100%; }
.afaq-btn-primary {
  background: linear-gradient(135deg, var(--afaq-accent), var(--afaq-primary));
  color: #fff;
}
.afaq-btn-primary:hover {
  opacity: 0.9;
  transform: translateY(-1px);
  box-shadow: 0 4px 16px rgba(46,134,222,0.35);
}
.afaq-btn-secondary {
  background: var(--afaq-bg);
  color: var(--afaq-primary);
  border-color: var(--afaq-border);
}
.afaq-btn-secondary:hover {
  border-color: var(--afaq-accent);
  background: #e8f4fd;
}
.afaq-btn-success {
  background: linear-gradient(135deg, #27ae60, #1e8449);
  color: #fff;
}
.afaq-btn-success:hover {
  opacity: 0.9;
  transform: translateY(-1px);
  box-shadow: 0 4px 16px rgba(39,174,96,0.35);
}
.afaq-nav-btns {
  display: flex;
  gap: 12px;
  margin-top: 28px;
  flex-wrap: wrap;
}

/* ===================== ERROR ===================== */
.afaq-error-msg {
  color: var(--afaq-danger);
  font-size: 13px;
  font-weight: 600;
  padding: 10px 14px;
  background: #fdf0ef;
  border-radius: 8px;
  border-right: 4px solid var(--afaq-danger);
  margin-top: 10px;
}

/* ===================== LOADING ===================== */
.afaq-loading-card {
  text-align: center;
  padding: 60px 40px;
}
.afaq-spinner {
  width: 64px;
  height: 64px;
  border: 5px solid var(--afaq-bg);
  border-top-color: var(--afaq-accent);
  border-radius: 50%;
  animation: afaq-spin 0.9s linear infinite;
  margin: 0 auto 24px;
}
@keyframes afaq-spin { to { transform: rotate(360deg); } }

.afaq-loading-card h2 {
  color: var(--afaq-primary);
  font-size: 22px;
  margin-bottom: 24px;
}
.afaq-loading-steps {
  display: flex;
  flex-direction: column;
  gap: 10px;
  max-width: 340px;
  margin: 0 auto;
  text-align: right;
}
.afaq-loading-step {
  font-size: 14px;
  color: var(--afaq-muted);
  padding: 8px 14px;
  border-radius: 8px;
  background: var(--afaq-bg);
  transition: all 0.3s;
}
.afaq-loading-step.done {
  background: #e8fdf0;
  color: var(--afaq-success);
  font-weight: 700;
}

/* ===================== RESULTS ===================== */
.afaq-results-card { padding: 0; overflow: hidden; }

.afaq-results-header {
  background: linear-gradient(135deg, var(--afaq-primary) 0%, var(--afaq-accent) 100%);
  color: #fff;
  padding: 36px 40px 28px;
  text-align: center;
}
.afaq-results-logo {
  font-size: 28px;
  font-weight: 900;
  margin-bottom: 10px;
}
.afaq-results-logo span { color: var(--afaq-accent2); }
.afaq-results-header h2 { font-size: 20px; margin-bottom: 6px; }
.afaq-results-header p { opacity: 0.85; font-size: 14px; }

.afaq-result-section {
  padding: 28px 40px;
  border-bottom: 1px solid var(--afaq-border);
}
.afaq-result-section:last-of-type { border-bottom: none; }

.afaq-result-section-title {
  font-size: 17px;
  font-weight: 800;
  color: var(--afaq-primary);
  margin-bottom: 18px;
  display: flex;
  align-items: center;
  gap: 8px;
}

/* Personality Chips */
.afaq-personality-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
}
.afaq-chip {
  flex: 1;
  min-width: 120px;
  border-radius: 14px;
  padding: 16px 20px;
  text-align: center;
}
.afaq-chip-blue   { background: #e8f4fd; border-top: 3px solid var(--afaq-accent); }
.afaq-chip-green  { background: #e8fdf0; border-top: 3px solid var(--afaq-success); }
.afaq-chip-purple { background: #f0e8fd; border-top: 3px solid #8e44ad; }
.chip-label { font-size: 11px; color: var(--afaq-muted); font-weight: 600; margin-bottom: 6px; }
.chip-value { font-size: 20px; font-weight: 900; color: var(--afaq-primary); }

/* RIASEC Bars */
.afaq-riasec-chart { display: flex; flex-direction: column; gap: 12px; }
.afaq-bar-row { display: flex; align-items: center; gap: 12px; }
.afaq-bar-label {
  width: 155px;
  font-size: 12px;
  font-weight: 700;
  color: var(--afaq-text);
  display: flex;
  align-items: center;
  gap: 8px;
  flex-shrink: 0;
}
.afaq-dim-badge {
  color: #fff;
  border-radius: 6px;
  padding: 2px 8px;
  font-size: 12px;
  font-weight: 800;
}
.afaq-bar-track {
  flex: 1;
  background: var(--afaq-bg);
  border-radius: 50px;
  height: 28px;
  overflow: hidden;
}
.afaq-bar-fill {
  height: 100%;
  border-radius: 50px;
  display: flex;
  align-items: center;
  padding: 0 12px;
  color: #fff;
  font-size: 12px;
  font-weight: 700;
  min-width: 48px;
  transition: width 1s ease;
}

/* Specializations Grid */
.afaq-specs-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 14px;
}
@media (max-width: 600px) { .afaq-specs-grid { grid-template-columns: 1fr; } }
.afaq-spec-card {
  border: 2px solid var(--afaq-border);
  border-radius: 14px;
  padding: 16px 18px;
  transition: border-color 0.2s, box-shadow 0.2s;
}
.afaq-spec-card:hover {
  border-color: var(--afaq-accent);
  box-shadow: 0 2px 12px rgba(46,134,222,0.12);
}
.afaq-spec-name { font-size: 14px; font-weight: 800; color: var(--afaq-primary); margin-bottom: 6px; }
.afaq-spec-cat  { font-size: 11px; color: var(--afaq-accent); font-weight: 700; background: #e8f4fd; padding: 2px 8px; border-radius: 50px; display: inline-block; margin-bottom: 8px; }
.afaq-spec-inst { font-size: 11px; color: var(--afaq-muted); margin-bottom: 4px; }
.afaq-spec-city { font-size: 11px; color: var(--afaq-muted); }
.afaq-spec-dur  { font-size: 11px; color: var(--afaq-success); font-weight: 600; margin-top: 6px; }

/* Analysis Box */
.afaq-analysis-box {
  background: var(--afaq-bg);
  border-radius: 14px;
  padding: 24px 28px;
  line-height: 1.9;
  font-size: 14px;
  color: var(--afaq-text);
}
.afaq-analysis-box h3 {
  color: var(--afaq-primary);
  font-size: 15px;
  font-weight: 800;
  margin: 18px 0 8px;
  border-right: 4px solid var(--afaq-accent);
  padding-right: 10px;
}
.afaq-analysis-box h3:first-child { margin-top: 0; }
.afaq-analysis-box strong { color: var(--afaq-primary); }
.afaq-analysis-box ul, .afaq-analysis-box ol { padding-right: 20px; margin: 8px 0; }
.afaq-analysis-box li { margin-bottom: 4px; }

/* Result Actions */
.afaq-result-actions {
  display: flex;
  gap: 14px;
  padding: 24px 40px 32px;
  flex-wrap: wrap;
}
.afaq-result-actions .afaq-btn { flex: 1; min-width: 180px; }

@media (max-width: 600px) {
  .afaq-result-section { padding: 20px 18px; }
  .afaq-result-actions { padding: 16px 18px 24px; }
  .afaq-bar-label { width: 110px; font-size: 11px; }
}
