/* ============================================================
   بازار هوشمند اقامت ایران — Design System
   Shared theme: tokens, components, RTL, dark mode
   ============================================================ */

@import url('https://cdn.jsdelivr.net/gh/rastikerdar/vazirmatn@v33.003/Vazirmatn-font-face.css');

:root {
  --primary:   #4F46E5;
  --primary-600:#4338CA;
  --secondary: #6366F1;
  --success:   #22C55E;
  --warning:   #F59E0B;
  --danger:    #EF4444;

  --bg:        #F8FAFC;
  --bg-soft:   #EEF2FF;
  --card:      #FFFFFF;
  --border:    #E5E7EB;
  --text:      #111827;
  --muted:     #6B7280;

  --shadow-sm: 0 1px 2px rgba(16,24,40,.06), 0 1px 3px rgba(16,24,40,.08);
  --shadow:    0 4px 6px -1px rgba(16,24,40,.08), 0 2px 4px -2px rgba(16,24,40,.06);
  --shadow-lg: 0 20px 25px -5px rgba(16,24,40,.10), 0 8px 10px -6px rgba(16,24,40,.08);
  --radius:    16px;
  --radius-sm: 12px;
  --grad:      linear-gradient(135deg, #4F46E5 0%, #6366F1 60%, #818CF8 100%);
  --grad-soft: linear-gradient(135deg, rgba(79,70,229,.08), rgba(99,102,241,.04));
}

[data-theme="dark"] {
  --bg:        #0B1020;
  --bg-soft:   #131A2E;
  --card:      #151B2E;
  --border:    #273049;
  --text:      #E5E9F5;
  --muted:     #95A0BC;
  --shadow-sm: 0 1px 2px rgba(0,0,0,.4);
  --shadow:    0 4px 12px rgba(0,0,0,.45);
  --shadow-lg: 0 24px 40px rgba(0,0,0,.55);
  --grad-soft: linear-gradient(135deg, rgba(99,102,241,.16), rgba(79,70,229,.06));
}

* { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  font-family: 'Vazirmatn', system-ui, -apple-system, 'Segoe UI', Tahoma, sans-serif;
  background: var(--bg);
  color: var(--text);
  margin: 0;
  direction: rtl;
  text-align: right;
  -webkit-font-smoothing: antialiased;
  transition: background .3s ease, color .3s ease;
  font-variant-numeric: tabular-nums;
}

a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }

::selection { background: rgba(99,102,241,.25); }

/* ---- Layout helpers ---- */
.container-xl { max-width: 1280px; margin-inline: auto; padding-inline: 20px; }
.muted { color: var(--muted); }
.tnum { font-variant-numeric: tabular-nums; }
.center { text-align: center; }

/* ---- Card ---- */
.card-x {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow-sm);
  transition: transform .25s ease, box-shadow .25s ease, border-color .25s;
}
.card-x:hover { box-shadow: var(--shadow); }
.card-pad { padding: 22px; }
.glass {
  background: color-mix(in srgb, var(--card) 78%, transparent);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border: 1px solid color-mix(in srgb, var(--border) 80%, transparent);
}

/* ---- Buttons ---- */
.btn-x {
  display: inline-flex; align-items: center; gap: 8px; justify-content: center;
  font-family: inherit; font-weight: 700; font-size: 14px;
  border: 1px solid transparent; border-radius: 12px;
  padding: 11px 18px; cursor: pointer; transition: all .2s ease; line-height: 1;
}
.btn-primary { background: var(--grad); color: #fff; box-shadow: 0 8px 18px -8px rgba(79,70,229,.7); }
.btn-primary:hover { transform: translateY(-1px); filter: brightness(1.05); }
.btn-ghost { background: transparent; border-color: var(--border); color: var(--text); }
.btn-ghost:hover { background: var(--bg-soft); }
.btn-soft { background: var(--bg-soft); color: var(--primary); }
.btn-block { width: 100%; }

/* ---- Badges / pills ---- */
.pill { display:inline-flex; align-items:center; gap:6px; font-size:12px; font-weight:700;
  padding:5px 11px; border-radius:999px; }
.pill-success { background: rgba(34,197,94,.14); color:#16a34a; }
.pill-warning { background: rgba(245,158,11,.16); color:#d97706; }
.pill-danger  { background: rgba(239,68,68,.14); color:#dc2626; }
.pill-primary { background: rgba(79,70,229,.14); color: var(--primary); }
.pill-muted   { background: var(--bg-soft); color: var(--muted); }
[data-theme="dark"] .pill-success { color:#4ade80; }
[data-theme="dark"] .pill-warning { color:#fbbf24; }
[data-theme="dark"] .pill-danger  { color:#f87171; }
[data-theme="dark"] .pill-primary { color:#a5b4fc; }

.up   { color: var(--success); }
.down { color: var(--danger); }

/* ---- KPI / stat ---- */
.kpi { display:flex; flex-direction:column; gap:6px; }
.kpi .v { font-size: 26px; font-weight: 800; letter-spacing:-.5px; }
.kpi .l { font-size: 13px; color: var(--muted); }

/* ---- Score bar ---- */
.score-track { height: 8px; border-radius: 999px; background: var(--bg-soft); overflow:hidden; }
.score-fill { height:100%; border-radius:999px; background: var(--grad); }

/* ---- Progress (alerts) ---- */
.prog { height: 10px; border-radius:999px; background: var(--bg-soft); overflow:hidden; }
.prog > span { display:block; height:100%; background: linear-gradient(90deg,#22C55E,#4ade80); }

/* ---- Nav ---- */
.nav-x {
  position: sticky; top: 0; z-index: 50;
  background: color-mix(in srgb, var(--card) 86%, transparent);
  backdrop-filter: blur(14px); -webkit-backdrop-filter: blur(14px);
  border-bottom: 1px solid var(--border);
}
.nav-inner { display:flex; align-items:center; gap:18px; height:66px; }
.brand { display:flex; align-items:center; gap:10px; font-weight:800; font-size:18px; }
.brand .logo { width:38px; height:38px; border-radius:11px; background:var(--grad);
  display:grid; place-items:center; color:#fff; font-size:20px; box-shadow:0 8px 16px -8px rgba(79,70,229,.8); }
.nav-links { display:flex; gap:4px; margin-inline-start: 10px; }
.nav-links a { padding:9px 13px; border-radius:10px; font-weight:600; font-size:14px; color:var(--muted); }
.nav-links a:hover { background: var(--bg-soft); color:var(--text); }
.nav-links a.active { color: var(--primary); background: var(--bg-soft); }
.nav-actions { margin-inline-start:auto; display:flex; align-items:center; gap:8px; }
.icon-btn { width:40px; height:40px; border-radius:11px; border:1px solid var(--border);
  background:var(--card); cursor:pointer; display:grid; place-items:center; font-size:17px; color:var(--text); transition:.2s; }
.icon-btn:hover { background: var(--bg-soft); }
.nav-toggle { display:none; }

/* ---- Footer ---- */
.footer-x { background: var(--card); border-top:1px solid var(--border); margin-top:60px; }
.footer-grid { display:grid; grid-template-columns: 1.6fr 1fr 1fr 1fr; gap:30px; padding:48px 0 24px; }
.footer-x h4 { font-size:14px; margin:0 0 14px; }
.footer-x ul { list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:9px; }
.footer-x ul a { color:var(--muted); font-size:13.5px; }
.footer-x ul a:hover { color:var(--primary); }
.footer-bottom { border-top:1px solid var(--border); padding:18px 0; display:flex; justify-content:space-between; flex-wrap:wrap; gap:10px; color:var(--muted); font-size:13px; }

/* ---- Section title ---- */
.sec-title { display:flex; align-items:center; justify-content:space-between; gap:12px; margin:0 0 18px; }
.sec-title h2 { font-size:22px; margin:0; font-weight:800; }
.sec-title .sub { color:var(--muted); font-size:13.5px; }

/* ---- Table ---- */
.tbl { width:100%; border-collapse: collapse; font-size:14px; }
.tbl th, .tbl td { padding:13px 14px; text-align:right; border-bottom:1px solid var(--border); }
.tbl th { color:var(--muted); font-weight:700; font-size:12.5px; }
.tbl tbody tr:hover { background: var(--bg-soft); }

/* ---- Inputs ---- */
.field { display:flex; flex-direction:column; gap:7px; }
.field label { font-size:13px; font-weight:600; color:var(--muted); }
.inp, select.inp, textarea.inp {
  font-family:inherit; font-size:14px; color:var(--text);
  background:var(--card); border:1px solid var(--border); border-radius:12px;
  padding:11px 13px; width:100%; transition:.2s; outline:none;
}
.inp:focus { border-color: var(--primary); box-shadow:0 0 0 3px rgba(79,70,229,.15); }

/* ---- Heatmap chips ---- */
.heat-chip { padding:14px; border-radius:14px; color:#fff; font-weight:700; display:flex; flex-direction:column; gap:4px; }

/* ---- Avatar ---- */
.avatar { width:44px; height:44px; border-radius:50%; background:var(--grad); color:#fff; display:grid; place-items:center; font-weight:800; }

/* ---- utilities ---- */
.grid-cards { display:grid; gap:18px; }
.hide-scroll::-webkit-scrollbar { display:none; }

/* ---- Responsive ---- */
@media (max-width: 992px){
  .footer-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 820px){
  .nav-links { display:none; }
  .nav-toggle { display:grid; }
}
@media (max-width: 560px){
  .footer-grid { grid-template-columns: 1fr; }
  .kpi .v { font-size:22px; }
}

/* mobile drawer */
.drawer { position:fixed; inset:0 0 0 auto; width:280px; background:var(--card); z-index:100;
  transform: translateX(100%); transition: transform .3s ease; padding:20px; box-shadow:var(--shadow-lg); border-inline-start:1px solid var(--border); }
.drawer.open { transform: translateX(0); }
.drawer a { display:block; padding:12px 10px; border-radius:10px; font-weight:600; color:var(--muted); }
.drawer a:hover { background:var(--bg-soft); color:var(--text); }
.scrim { position:fixed; inset:0; background:rgba(0,0,0,.45); z-index:99; opacity:0; pointer-events:none; transition:.3s; }
.scrim.open { opacity:1; pointer-events:auto; }
