/* ============================================================
   Beja Platform — Design System
   Color: Deep Red  |  Font: CLusail (AR) + Inter (Latin)
   ============================================================ */

/* ── Variables — Radio Theme (Teal + Gold) ───────────────── */
:root {
  --beja-900: #021f1f;
  --beja-800: #062b2b;
  --beja-700: #0a3d3d;
  --beja-600: #1b6b68;
  --beja-500: #2a8f8b;
  --beja-400: #40aaa6;
  --beja-300: #7dcac7;
  --beja-200: #b8e8e6;
  --beja-100: #e0f5f4;
  --beja-50 : #f2fbfa;

  --beja-gold   : #f0d58a;
  --beja-gold2  : #e8c86a;

  --beja-primary : var(--beja-700);
  --beja-hover   : var(--beja-800);
  --beja-light   : var(--beja-100);
  --beja-surface : var(--beja-50);

  --radius-sm : 6px;
  --radius    : 10px;
  --radius-lg : 16px;
  --shadow-sm : 0 1px 4px rgba(6,43,43,.08);
  --shadow    : 0 3px 12px rgba(6,43,43,.12);
  --shadow-lg : 0 8px 32px rgba(6,43,43,.16);

  --text-primary : #0d1f1f;
  --text-body    : #1f3a3a;
  --text-muted   : #5a8080;
  --border-color : #c8e4e3;
  --card-bg      : #ffffff;
}

/* ── Latin Font — Inter via bunny.net ────────────────────── */
@import url('https://fonts.bunny.net/css?family=inter:400,500,600,700&display=swap');

/* Apply Inter to all LTR/Latin text */
[dir="ltr"], .ltr,
.word-beja, .word-beja-large, .dict-beja,
.morph-part-value, .gram-example, .rule-example,
.analyzer-input, code, pre {
  font-family: 'Inter', 'Segoe UI', sans-serif !important;
  direction: ltr;
  unicode-bidi: embed;
  letter-spacing: 0.01em;
}

/* ── Container ──────────────────────────────────────────── */
.custom-container {
  max-width: 960px;
  margin: 0 auto;
  padding: 0 1.25rem;
  width: 100%;
}

/* ── Hero ────────────────────────────────────────────────── */
.beja-hero {
  background: linear-gradient(135deg, var(--beja-900) 0%, var(--beja-700) 50%, var(--beja-600) 100%);
  padding: 3rem 1.5rem 2.5rem;
  text-align: center;
  margin: -1.5rem -1.5rem 0;
  position: relative;
  overflow: hidden;
}
.beja-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background: url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.03'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
  pointer-events: none;
}
.beja-hero h1 {
  color: #fff;
  font-size: 1.9rem;
  font-weight: 700;
  margin-bottom: 0.5rem;
  text-shadow: 0 2px 8px rgba(0,0,0,.3);
}
.beja-hero p {
  color: rgba(255,255,255,.72);
  margin-bottom: 1.75rem;
  font-size: 0.95rem;
}
.beja-hero-sub {
  color: rgba(255,255,255,.45);
  font-size: 0.78rem;
  letter-spacing: .04em;
  margin-bottom: 0.6rem;
  text-transform: uppercase;
}

/* ── Search Bar ─────────────────────────────────────────── */
.beja-search-bar {
  display: flex;
  max-width: 480px;
  margin: 0 auto;
  border-radius: var(--radius);
  overflow: hidden;
  box-shadow: 0 4px 20px rgba(0,0,0,.3);
}
.beja-search-bar select {
  padding: 0.65rem 0.85rem;
  border: none;
  background: #fff;
  font-size: 0.85rem;
  color: var(--text-body);
  border-left: 1px solid var(--border-color);
  cursor: pointer;
  outline: none;
}
.beja-search-bar input {
  flex: 1;
  padding: 0.65rem 1rem;
  border: none;
  outline: none;
  font-size: 0.92rem;
  color: var(--text-primary);
  min-width: 0;
}
.beja-search-bar button {
  padding: 0.65rem 1.25rem;
  background: var(--beja-700);
  color: #fff;
  border: none;
  cursor: pointer;
  font-size: 0.9rem;
  font-weight: 500;
  transition: background .2s;
  white-space: nowrap;
}
.beja-search-bar button:hover { background: var(--beja-800); }

/* ── Stats Cards ─────────────────────────────────────────── */
.stat-card {
  background: #fff;
  border: 1px solid var(--border-color);
  border-radius: var(--radius);
  padding: 1.25rem 1rem;
  text-align: center;
  transition: transform .15s, box-shadow .15s;
  box-shadow: var(--shadow-sm);
}
.stat-card:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow);
}
.stat-num {
  font-size: 1.75rem;
  font-weight: 700;
  color: var(--beja-700);
  line-height: 1;
  font-family: 'Inter', sans-serif !important;
}
.stat-label {
  font-size: 0.75rem;
  color: var(--text-muted);
  margin-top: 0.35rem;
}

/* ── Service Cards ───────────────────────────────────────── */
.service-card {
  border: 1.5px solid var(--border-color);
  border-radius: var(--radius);
  padding: 1.25rem 1rem;
  text-align: center;
  background: #fff;
  transition: border-color .2s, box-shadow .2s, transform .15s;
  box-shadow: var(--shadow-sm);
}
.service-card:hover {
  border-color: var(--beja-300);
  box-shadow: var(--shadow);
  transform: translateY(-2px);
}
.svc-icon {
  width: 48px;
  height: 48px;
  background: var(--beja-50);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 0.75rem;
  color: var(--beja-600);
  font-size: 1.2rem;
  border: 1.5px solid var(--beja-100);
}
.svc-title {
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--text-primary);
  margin-bottom: 0.5rem;
}

/* ── Word Cards ──────────────────────────────────────────── */
.word-card-link {
  display: block;
  background: #fff;
  border: 1.5px solid var(--border-color);
  border-radius: var(--radius);
  padding: 0.9rem;
  text-decoration: none;
  color: inherit;
  transition: border-color .2s, box-shadow .2s;
  box-shadow: var(--shadow-sm);
}
.word-card-link:hover {
  border-color: var(--beja-300);
  box-shadow: var(--shadow);
  text-decoration: none;
  color: inherit;
}
.word-beja {
  font-size: 1rem;
  font-weight: 600;
  color: var(--beja-700);
  direction: ltr;
  letter-spacing: .01em;
}
.word-ar {
  font-size: 0.82rem;
  color: var(--text-muted);
  margin-top: 4px;
}

/* ── Dictionary Row ──────────────────────────────────────── */
.dict-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0.8rem 1rem;
  border-bottom: 1px solid #f5ecee;
  cursor: pointer;
  transition: background .1s;
}
.dict-row:last-child { border-bottom: none; }
.dict-row:hover { background: var(--beja-50); }
.dict-beja {
  font-size: 0.96rem;
  font-weight: 600;
  color: var(--beja-700);
  direction: ltr;
  letter-spacing: .01em;
}
.dict-ar {
  font-size: 0.82rem;
  color: var(--text-muted);
  margin-top: 2px;
}

/* ── Word Header (show page) ─────────────────────────────── */
.word-header {
  padding: 1.75rem 0 1.25rem;
  border-bottom: 2px solid var(--beja-100);
  margin-bottom: 1.5rem;
}
.word-beja-large {
  font-size: 2.2rem;
  font-weight: 700;
  color: var(--beja-700);
  direction: ltr;
  letter-spacing: .02em;
  line-height: 1.2;
  font-family: 'Inter', sans-serif !important;
}
.word-ar-large {
  font-size: 1.2rem;
  color: var(--text-primary);
  margin-top: 0.3rem;
  font-weight: 500;
}
.word-en {
  font-size: 0.9rem;
  color: var(--text-muted);
  direction: ltr;
  margin-top: 0.2rem;
  font-family: 'Inter', sans-serif !important;
}

/* ── Morphology ──────────────────────────────────────────── */
.morph-card {
  background: #fff;
  border: 1.5px solid var(--border-color);
  border-radius: var(--radius-lg);
  padding: 1.5rem;
  margin: 1.25rem 0;
  box-shadow: var(--shadow-sm);
}
.morph-card h3 {
  font-size: 0.88rem;
  font-weight: 600;
  color: var(--text-muted);
  margin-bottom: 1rem;
  text-transform: uppercase;
  letter-spacing: .06em;
}
.morph-breakdown {
  display: flex;
  gap: 3px;
  border-radius: var(--radius);
  overflow: hidden;
}
.morph-part {
  flex: 1;
  padding: 1rem 0.75rem;
  text-align: center;
  transition: opacity .15s;
}
.morph-prefix  { background: #e8f0fb; border-radius: var(--radius) 0 0 var(--radius); }
.morph-root    { flex: 2; background: var(--beja-100); }
.morph-suffix  { background: #ede8fb; border-radius: 0 var(--radius) var(--radius) 0; }
.morph-part-label {
  font-size: 0.62rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--text-muted);
  margin-bottom: 0.4rem;
}
.morph-part-value {
  font-size: 1.15rem;
  font-weight: 700;
  color: var(--text-primary);
  direction: ltr;
  font-family: 'Inter', sans-serif !important;
}
.morph-prefix .morph-part-value  { color: #2c5fa3; }
.morph-root   .morph-part-value  { color: var(--beja-700); }
.morph-suffix .morph-part-value  { color: #5f3fa3; }
.morph-part-meaning {
  font-size: 0.72rem;
  margin-top: 0.3rem;
  color: var(--text-muted);
}
.morph-confidence {
  font-size: 0.75rem;
  color: var(--text-muted);
  text-align: center;
  margin-top: 0.85rem;
  font-family: 'Inter', sans-serif !important;
}

/* ── Rating ──────────────────────────────────────────────── */
.rating-section {
  padding: 1.25rem 0;
  border-top: 1px solid var(--border-color);
  margin-top: 1.25rem;
}
.rating-section > p {
  font-size: 0.88rem;
  color: var(--text-muted);
  margin-bottom: 0.75rem;
}
.btn-rate {
  padding: 0.45rem 1rem;
  border-radius: var(--radius-sm);
  border: 1.5px solid var(--border-color);
  background: #fff;
  font-size: 0.85rem;
  cursor: pointer;
  transition: all .15s;
  font-family: inherit;
}
.btn-pos   { border-color: #1d8a60; color: #155a3e; }
.btn-pos:hover   { background: #e6f5ee; border-color: #1d8a60; }
.btn-great { border-color: var(--beja-500); color: var(--beja-700); }
.btn-great:hover { background: var(--beja-50); border-color: var(--beja-400); }
.btn-neg   { border-color: #c0392b; color: #7a1a10; }
.btn-neg:hover   { background: #fdecea; border-color: #c0392b; }

/* ── Badges ──────────────────────────────────────────────── */
.badge-confirmed { background: #e6f5ee; color: #155a3e; font-size: 0.7rem; padding: 3px 10px; border-radius: 99px; font-weight: 500; }
.badge-probable  { background: #e8f0fb; color: #1e3f87; font-size: 0.7rem; padding: 3px 10px; border-radius: 99px; font-weight: 500; }
.badge-uncertain { background: #f5f5f5; color: #666;    font-size: 0.7rem; padding: 3px 10px; border-radius: 99px; font-weight: 500; }
.badge-unknown   { background: #f5f5f5; color: #999;    font-size: 0.7rem; padding: 3px 10px; border-radius: 99px; font-weight: 500; }
.badge-cat       { background: var(--beja-100); color: var(--beja-700); font-size: 0.7rem; padding: 3px 10px; border-radius: 99px; font-weight: 500; }
.badge-rating    { background: #fff8e8; color: #7a5000; font-size: 0.7rem; padding: 3px 10px; border-radius: 99px; font-weight: 500; }
.badge-soon      { background: #fff0e0; color: #8a4000; font-size: 0.72rem; padding: 3px 10px; border-radius: 99px; font-weight: 500; }
.badge-active    { background: #e6f5ee; color: #155a3e; font-size: 0.72rem; padding: 3px 10px; border-radius: 99px; font-weight: 500; }
.badge-soon-large {
  display: inline-block;
  padding: 0.5rem 1.5rem;
  border-radius: 99px;
  background: var(--beja-100);
  color: var(--beja-700);
  font-weight: 600;
  font-size: 0.9rem;
  margin: 1rem 0;
  border: 1px solid var(--beja-200);
}

/* Rank badges */
.rank-badge  { display: inline-block; padding: 0.25rem 0.85rem; border-radius: 99px; font-size: 0.82rem; font-weight: 600; }
.rank-purple { background: #f0e8ff; color: #5b21b6; }
.rank-teal   { background: #e0f7f5; color: #0f766e; }
.rank-green  { background: #dcfce7; color: #15803d; }
.rank-gray   { background: #f3f4f6; color: #4b5563; }

/* ── Grammar ─────────────────────────────────────────────── */
.grammar-filter {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-bottom: 1.5rem;
}
.grammar-filter button {
  padding: 0.35rem 0.9rem;
  border: 1.5px solid var(--border-color);
  border-radius: 99px;
  background: #fff;
  cursor: pointer;
  font-size: 0.82rem;
  font-family: inherit;
  color: var(--text-body);
  transition: all .15s;
}
.grammar-filter button.active,
.grammar-filter button:hover {
  background: var(--beja-700);
  color: #fff;
  border-color: var(--beja-700);
}
.rule-card {
  border: 1.5px solid var(--border-color);
  border-radius: var(--radius);
  padding: 1.1rem 1.25rem;
  margin-bottom: 0.75rem;
  background: #fff;
  transition: border-color .15s, box-shadow .15s;
  box-shadow: var(--shadow-sm);
}
.rule-card:hover {
  border-color: var(--beja-200);
  box-shadow: var(--shadow);
}
.rule-title {
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--text-primary);
  margin-bottom: 0.4rem;
}
.rule-desc {
  font-size: 0.85rem;
  color: var(--text-muted);
  margin-bottom: 0.5rem;
  line-height: 1.6;
}
.rule-example {
  font-size: 0.84rem;
  background: var(--beja-50);
  border: 1px solid var(--beja-100);
  padding: 0.45rem 0.85rem;
  border-radius: var(--radius-sm);
  direction: ltr;
  color: var(--beja-800);
  font-family: 'Inter', sans-serif !important;
  font-weight: 500;
}

/* ── Analyzer Input ──────────────────────────────────────── */
.analyzer-input-wrap {
  max-width: 520px;
  margin: 2rem auto;
}
.analyzer-input {
  width: 100%;
  padding: 0.9rem 1.25rem;
  font-size: 1.1rem;
  border: 2px solid var(--border-color);
  border-radius: var(--radius);
  text-align: center;
  direction: ltr;
  transition: border-color .2s, box-shadow .2s;
  outline: none;
  font-family: 'Inter', sans-serif !important;
  color: var(--beja-800);
  background: #fff;
}
.analyzer-input:focus {
  border-color: var(--beja-500);
  box-shadow: 0 0 0 3px rgba(123,27,51,.12);
}

/* ── Contribute CTA ──────────────────────────────────────── */
.contribute-cta {
  background: var(--beja-50);
  border: 1.5px solid var(--beja-200);
  border-radius: var(--radius);
  padding: 0.85rem 1.1rem;
  margin-top: 1.5rem;
  font-size: 0.88rem;
  color: var(--text-body);
}
.contribute-cta a {
  color: var(--beja-600);
  text-decoration: none;
  font-weight: 500;
}
.contribute-cta a:hover { text-decoration: underline; }

/* ── Progress Bar ─────────────────────────────────────────── */
.progress-bar-wrap { background: var(--beja-100); border-radius: 99px; height: 7px; margin: 0.5rem 0; }
.progress-bar-fill { height: 7px; border-radius: 99px; background: linear-gradient(90deg, var(--beja-600), var(--beja-400)); transition: width .4s; }

/* ── Nav Links ───────────────────────────────────────────── */
.beja-nav-links .nav-link { font-size: 0.88rem; }

/* ── Buttons (Beja primary) ──────────────────────────────── */
.btn-beja {
  background: linear-gradient(135deg, var(--beja-700), var(--beja-600));
  color: #fff;
  border: none;
  border-radius: var(--radius-sm);
  padding: 0.5rem 1.5rem;
  font-size: 0.9rem;
  font-weight: 500;
  cursor: pointer;
  transition: all .2s;
  font-family: inherit;
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
}
.btn-beja:hover {
  background: linear-gradient(135deg, var(--beja-800), var(--beja-700));
  color: #fff;
  box-shadow: 0 4px 14px rgba(123,27,51,.3);
  transform: translateY(-1px);
}
.btn-beja:active { transform: translateY(0); }

/* ── Forms (professional) ─────────────────────────────────── */
.beja-form .form-label {
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--text-body);
  margin-bottom: 0.4rem;
}
.beja-form .form-control,
.beja-form .form-select {
  border: 1.5px solid var(--border-color);
  border-radius: var(--radius-sm);
  padding: 0.6rem 0.9rem;
  font-size: 0.9rem;
  color: var(--text-primary);
  background: #fff;
  transition: border-color .2s, box-shadow .2s;
  font-family: inherit;
}
.beja-form .form-control:focus,
.beja-form .form-select:focus {
  border-color: var(--beja-500);
  box-shadow: 0 0 0 3px rgba(123,27,51,.1);
  outline: none;
}
.beja-form .form-control[dir="ltr"],
.beja-form input[dir="ltr"] {
  font-family: 'Inter', sans-serif !important;
  letter-spacing: .01em;
}
.beja-form textarea.form-control {
  resize: vertical;
  min-height: 80px;
}
.beja-form .form-text {
  font-size: 0.78rem;
  color: var(--text-muted);
  margin-top: 0.25rem;
}

/* Override Bootstrap for all form controls in beja pages */
.beja-page .form-control,
.beja-page .form-select {
  border: 1.5px solid var(--border-color);
  border-radius: var(--radius-sm);
  font-size: 0.9rem;
  transition: border-color .2s, box-shadow .2s;
}
.beja-page .form-control:focus,
.beja-page .form-select:focus {
  border-color: var(--beja-500);
  box-shadow: 0 0 0 3px rgba(123,27,51,.1);
}
.beja-page .btn-success,
.beja-page .btn-primary {
  background: linear-gradient(135deg, var(--beja-700), var(--beja-600));
  border-color: transparent;
  font-weight: 500;
}
.beja-page .btn-success:hover,
.beja-page .btn-primary:hover {
  background: linear-gradient(135deg, var(--beja-800), var(--beja-700));
  border-color: transparent;
  box-shadow: 0 4px 14px rgba(123,27,51,.3);
}
.beja-page .btn-outline-success {
  border-color: var(--beja-500);
  color: var(--beja-700);
}
.beja-page .btn-outline-success:hover {
  background: var(--beja-700);
  border-color: var(--beja-700);
  color: #fff;
}

/* ── Section Headings ─────────────────────────────────────── */
.beja-section-title {
  font-size: 1rem;
  font-weight: 700;
  color: var(--text-primary);
  margin-bottom: 1rem;
  display: flex;
  align-items: center;
  gap: 0.6rem;
}
.beja-section-title::after {
  content: '';
  flex: 1;
  height: 1px;
  background: var(--border-color);
}

/* ── Card Overrides ───────────────────────────────────────── */
.beja-page .card {
  border: 1.5px solid var(--border-color);
  border-radius: var(--radius);
  box-shadow: var(--shadow-sm);
}
.beja-page .card:hover {
  box-shadow: var(--shadow);
}

/* ── Page wrapper (add to body section in each view) ─────── */
.beja-page main,
.beja-page .py-4 { padding-top: 0 !important; }

/* ── Alert override ───────────────────────────────────────── */
.beja-page .alert-success {
  background: #e8f5ee;
  border-color: #b3dfc5;
  color: #155a3e;
  border-radius: var(--radius-sm);
}
.beja-page .alert-danger {
  background: var(--beja-50);
  border-color: var(--beja-200);
  color: var(--beja-800);
  border-radius: var(--radius-sm);
}

/* ── Pagination override ──────────────────────────────────── */
.beja-page .pagination .page-link {
  border-radius: var(--radius-sm) !important;
  border-color: var(--border-color);
  color: var(--beja-700);
  font-size: 0.85rem;
  margin: 0 2px;
}
.beja-page .pagination .page-item.active .page-link {
  background: var(--beja-700);
  border-color: var(--beja-700);
  color: #fff;
}

/* ── Responsive ──────────────────────────────────────────── */
@media (max-width: 576px) {
  .beja-hero { padding: 2rem 1rem 1.75rem; }
  .beja-hero h1 { font-size: 1.45rem; }
  .beja-search-bar { border-radius: var(--radius-sm); }
  .stat-num { font-size: 1.4rem; }
  .word-beja-large { font-size: 1.7rem; }
  .custom-container { padding: 0 0.85rem; }
}
