/* =========================================
   Ronok Search — استایل‌های اصلی
   نویسنده: فرانت‌اند متخصص | استفاده از کامنت‌های فارسی
   ========================================= */

/* --- وارد کردن Bootstrap فقط از طریق CSS (بدون لینک اضافی در HTML) --- */
/* توجه: این import باعث افزایش سازگاری واکنش‌گرا می‌شود و فقط CSS است. */
@import url("https://cdn.jsdelivr.net/npm/bootstrap@5.3.2/dist/css/bootstrap.min.css");

/* --- فونت‌های فارسی Vazirmatn و Vazir از Google Fonts --- */
/* بارگذاری با display: swap برای عملکرد بهتر */
@import url("https://fonts.googleapis.com/css2?family=Vazirmatn:wght@300;400;500;600;700&family=Vazir:wght@300;400;700&display=swap");

/* --- تنظیمات پایه و متغیرها --- */
:root {
  /* رنگ‌های سیستم (روشن) */
  --rk-bg: #ffffff;
  --rk-surface: #f6f7f9;
  --rk-text: #0f172a;
  --rk-muted: #475569;
  --rk-border: #e5e7eb;
  --rk-primary: #2563eb;
  --rk-primary-contrast: #ffffff;
  --rk-ghost: #0f172a0d;

  /* سایه‌ها و شعاع گوشه‌ها */
  --rk-radius: 12px;
  --rk-radius-sm: 8px;
  --rk-shadow: 0 10px 30px rgba(2, 6, 23, 0.08);
  --rk-shadow-sm: 0 6px 20px rgba(2, 6, 23, 0.06);

  /* ابعاد */
  --rk-container: 1100px;
  --rk-gap: 20px;
  --rk-gap-lg: 28px;
  --rk-header-h: 68px;
}

/* حالت تیره براساس کلاس بدنه */
body.theme-dark {
  --rk-bg: #0b1220;
  --rk-surface: #121a2b;
  --rk-text: #e5e7eb;
  --rk-muted: #94a3b8;
  --rk-border: #1f2937;
  --rk-primary: #60a5fa;
  --rk-primary-contrast: #0b1220;
  --rk-ghost: #e5e7eb12;
}

/* حالت خودکار با ترجیح کاربر */
@media (prefers-color-scheme: dark) {
  body.theme-auto {
    --rk-bg: #0b1220;
    --rk-surface: #121a2b;
    --rk-text: #e5e7eb;
    --rk-muted: #94a3b8;
    --rk-border: #1f2937;
    --rk-primary: #60a5fa;
    --rk-primary-contrast: #0b1220;
    --rk-ghost: #e5e7eb12;
  }
}

/* --- پایه تایپوگرافی و جهت --- */
html {
  /* جهت راست‌به‌چپ برای فارسی */
  scroll-behavior: smooth;
}

body {
  margin: 0;
  background: var(--rk-bg);
  color: var(--rk-text);
  /* استفاده از فونت‌های فارسی */
  font-family: "Vazirmatn", "Vazir", system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", "Noto Sans Arabic", "Noto Naskh Arabic", Arial, sans-serif;
  line-height: 1.6;
}

/* کلاس کمک‌کار برای دسترس‌پذیری */
.rk-visually-hidden {
  position: absolute !important;
  height: 1px; width: 1px;
  overflow: hidden;
  clip: rect(1px, 1px, 1px, 1px);
  white-space: nowrap;
}

/* --- کانتینر واکنشی --- */
.rk-container {
  max-width: var(--rk-container);
  margin-inline: auto;
  padding-inline: 16px;
}

/* --- هدر --- */
.rk-header {
  position: relative;
  background: var(--rk-bg);
  border-bottom: 1px solid var(--rk-border);
}

.rk-header-sticky {
  position: sticky;
  top: 0;
  z-index: 100;
  backdrop-filter: saturate(120%) blur(4px);
}

.rk-header-inner {
  height: var(--rk-header-h);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

/* برند */
.rk-brand {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  text-decoration: none;
  color: var(--rk-text);
  font-weight: 700;
}

.rk-logo {
  width: 36px;
  height: 36px;
  display: inline-grid;
  place-items: center;
  border-radius: 50%;
  background: var(--rk-primary);
  color: var(--rk-primary-contrast);
  font-weight: 700;
}

.rk-title {
  font-size: 1.25rem;
  letter-spacing: -0.3px;
}

/* ناوبری */
.rk-nav {
  display: flex;
  align-items: center;
  gap: 8px;
}

.rk-nav-link {
  display: inline-flex;
  padding: 10px 14px;
  border-radius: 10px;
  text-decoration: none;
  color: var(--rk-text);
  background: transparent;
  transition: background 0.2s ease, color 0.2s ease;
}

.rk-nav-link:hover {
  background: var(--rk-ghost);
}

/* --- بخش قهرمان (صفحه اصلی) --- */
.rk-main {
  padding-block: 24px;
}

.rk-hero {
  padding-block: 48px;
  text-align: center;
}

.rk-hero-title {
  font-size: clamp(1.5rem, 2.5vw + 1rem, 2.4rem);
  margin: 0 0 8px;
}

.rk-hero-sub {
  margin: 0 auto 24px;
  max-width: 650px;
  color: var(--rk-muted);
}

/* فرم جستجو بزرگ */
.rk-search-form {
  max-width: 820px;
  margin: 0 auto;
  display: grid;
  gap: 16px;
}

/* ورودی‌ها و کنترل‌ها */
.rk-input,
.rk-select,
.rk-btn {
  font: inherit;
}

.rk-input {
  width: 100%;
  background: var(--rk-surface);
  border: 1px solid var(--rk-border);
  color: var(--rk-text);
  padding: 14px 16px;
  border-radius: var(--rk-radius);
  outline: none;
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.rk-input:focus {
  border-color: var(--rk-primary);
  box-shadow: 0 0 0 3px color-mix(in oklab, var(--rk-primary) 25%, transparent);
}

.rk-input-lg {
  padding: 18px 18px;
  font-size: 1.05rem;
}

/* گروه ورودی‌ها */
.rk-quick-options {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;
}

.rk-input-group {
  display: grid;
  gap: 6px;
}

.rk-label {
  color: var(--rk-muted);
  font-size: 0.95rem;
}

.rk-select {
  width: 100%;
  background: var(--rk-surface);
  border: 1px solid var(--rk-border);
  color: var(--rk-text);
  padding: 12px;
  border-radius: var(--rk-radius-sm);
}

/* دکمه‌ها */
.rk-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 12px 16px;
  border-radius: var(--rk-radius-sm);
  border: 1px solid transparent;
  text-decoration: none;
  cursor: pointer;
  transition: transform 0.02s ease, background 0.2s ease, border-color 0.2s ease, color 0.2s ease;
}

.rk-btn:active {
  transform: translateY(1px);
}

.rk-btn-primary {
  background: var(--rk-primary);
  color: var(--rk-primary-contrast);
}

.rk-btn-primary:hover {
  filter: brightness(1.05);
}

.rk-btn-ghost {
  background: var(--rk-ghost);
  color: var(--rk-text);
}

.rk-btn-ghost:hover {
  background: color-mix(in oklab, var(--rk-ghost) 70%, var(--rk-text) 5%);
}

.rk-btn-lg {
  padding: 14px 18px;
}

.rk-btn-block {
  width: 100%;
}

/* بخش عملیات فرم */
.rk-actions {
  display: flex;
  align-items: center;
  gap: 10px;
  justify-content: center;
}

/* --- بخش‌ها و کارت‌ها --- */
.rk-section {
  padding-block: 32px;
}

.rk-section-title {
  font-size: 1.4rem;
  margin-bottom: 18px;
}

.rk-card {
  background: var(--rk-surface);
  border: 1px solid var(--rk-border);
  border-radius: var(--rk-radius);
  box-shadow: var(--rk-shadow);
  padding: 20px;
}

.rk-card-tight {
  padding: 16px;
}

.rk-card-title {
  margin-top: 0;
  margin-bottom: 14px;
  font-size: 1.1rem;
}

/* --- فرم‌های تنظیمات و فیلترها --- */
.rk-form {
  display: grid;
  gap: 16px;
}

.rk-form-row {
  display: grid;
  gap: 8px;
}

.rk-radio-group,
.rk-checkbox-group {
  display: grid;
  gap: 8px;
}

.rk-radio,
.rk-checkbox {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: var(--rk-text);
}

/* --- صفحه نتایج --- */
.rk-results .rk-container {
  padding-top: 18px;
}

.rk-grid {
  display: grid;
  grid-template-columns: 280px 1fr;
  gap: var(--rk-gap);
}

.rk-sidebar {
  position: sticky;
  top: calc(var(--rk-header-h) + 16px);
  height: fit-content;
}

.rk-content {
  display: grid;
  gap: 16px;
}

.rk-results-meta {
  background: var(--rk-surface);
  border: 1px solid var(--rk-border);
  border-radius: var(--rk-radius);
  padding: 14px 16px;
}

.rk-results-count {
  margin: 0 0 6px;
  font-weight: 600;
}

.rk-results-hint {
  margin: 0;
  color: var(--rk-muted);
}

/* آیتم نتیجه */
.rk-result {
  background: var(--rk-bg);
  border: 1px solid var(--rk-border);
  border-radius: var(--rk-radius);
  padding: 16px;
  box-shadow: var(--rk-shadow-sm);
}

.rk-result-title {
  display: inline-block;
  font-weight: 700;
  font-size: 1.05rem;
  color: var(--rk-primary);
  text-decoration: none;
  margin-bottom: 4px;
}

.rk-result-title:hover {
  text-decoration: underline;
}

.rk-result-url {
  color: var(--rk-muted);
  font-size: 0.92rem;
  margin-bottom: 8px;
}

.rk-result-snippet {
  margin: 0;
}

/* صفحه‌بندی */
.rk-pagination {
  display: inline-flex;
  gap: 8px;
  align-items: center;
  flex-wrap: wrap;
}

.rk-page {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 40px;
  padding: 8px 12px;
  border-radius: 10px;
  border: 1px solid var(--rk-border);
  text-decoration: none;
  color: var(--rk-text);
  background: var(--rk-bg);
}

.rk-page:hover {
  background: var(--rk-ghost);
}

.rk-page-active {
  background: var(--rk-primary);
  color: var(--rk-primary-contrast);
  border-color: transparent;
}

.rk-page-disabled {
  opacity: 0.5;
  pointer-events: none;
}

/* --- نوار جستجو در هدر نتایج --- */
.rk-searchbar {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  flex: 1 1 auto;
  max-width: 600px;
}

.rk-searchbar .rk-input {
  flex: 1 1 auto;
}

/* --- فوتر --- */
.rk-footer {
  border-top: 1px solid var(--rk-border);
  margin-top: 24px;
  background: var(--rk-bg);
}

.rk-footer-inner {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--rk-gap);
  padding-block: 18px;
}

.rk-footer-col {
  display: grid;
  gap: 8px;
}

.rk-footer-title {
  font-weight: 700;
}

.rk-footer-text {
  color: var(--rk-muted);
  margin: 0;
}

.rk-footer-link {
  color: var(--rk-text);
  text-decoration: none;
  width: fit-content;
  border-radius: 8px;
  padding: 6px 8px;
}

.rk-footer-link:hover {
  background: var(--rk-ghost);
}

.rk-footer-meta {
  color: var(--rk-muted);
}

/* --- واکنش‌گرایی --- */
/* موبایل */
@media (max-width: 768px) {
  .rk-header-inner {
    gap: 8px;
  }

  .rk-nav {
    display: none; /* ساده‌سازی ناوبری در موبایل */
  }

  .rk-quick-options {
    grid-template-columns: 1fr; /* تک‌ستونی در موبایل */
  }

  .rk-grid {
    grid-template-columns: 1fr; /* سایدبار زیر نتایج */
  }

  .rk-sidebar {
    position: static;
  }

  .rk-footer-inner {
    grid-template-columns: 1fr; /* ستون واحد در فوتر موبایل */
  }

  .rk-actions {
    flex-direction: column;
  }
}

/* تبلت */
@media (min-width: 769px) and (max-width: 1024px) {
  .rk-grid {
    grid-template-columns: 240px 1fr;
  }
}

/* دسکتاپ بزرگ */
@media (min-width: 1280px) {
  .rk-hero {
    padding-block: 64px;
  }
}

/* --- بهینه‌سازی دسترس‌پذیری و تعامل --- */
a:focus-visible,
button:focus-visible,
select:focus-visible,
input:focus-visible {
  outline: 2px solid color-mix(in oklab, var(--rk-primary) 60%, transparent);
  outline-offset: 2px;
}

/* جلوگیری از انتخاب ناخواسته روی عناصر UI */
.rk-btn,
.rk-nav-link,
.rk-brand {
  user-select: none;
}

/* جلوگیری از تغییر اندازه ورودی‌ها در iOS */
textarea, input, select {
  font-size: 16px;
}