/* ===== Vazirmatn Font ===== */
@font-face { font-family:'Vazirmatn'; src:url('../fonts/Vazirmatn/Vazirmatn-Regular.woff2') format('woff2'); font-weight:400; font-display:swap; }
@font-face { font-family:'Vazirmatn'; src:url('../fonts/Vazirmatn/Vazirmatn-Medium.woff2') format('woff2'); font-weight:500; font-display:swap; }
@font-face { font-family:'Vazirmatn'; src:url('../fonts/Vazirmatn/Vazirmatn-SemiBold.woff2') format('woff2'); font-weight:600; font-display:swap; }
@font-face { font-family:'Vazirmatn'; src:url('../fonts/Vazirmatn/Vazirmatn-Bold.woff2') format('woff2'); font-weight:700; font-display:swap; }

/* ===== Variables ===== */
:root {
  --bg:       #07111d;
  --surf:     #0d1b2e;
  --surf2:    #132236;
  --surf3:    #1b3050;
  --pri:      #3b82f6;
  --pri-dim:  rgba(59,130,246,.14);
  --pri-glow: rgba(59,130,246,.3);
  --acc:      #93c5fd;
  --txt:      #e0eeff;
  --txt2:     #7a9dbf;
  --txt3:     #334f68;
  --grn:      #22c55e;
  --grn-dim:  rgba(34,197,94,.12);
  --red:      #ef4444;
  --red-dim:  rgba(239,68,68,.12);
  --gld:      #f59e0b;
  --bdr:      rgba(120,180,255,.07);
  --bdr2:     rgba(120,180,255,.13);
  --app-bar:  52px;
  --nav-h:    60px;
  --radius:   16px;
  --radius-s: 12px;
  --shadow:   0 8px 32px rgba(0,0,0,.5);
  --tr:       .18s ease;
}

/* ===== Reset ===== */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { font-size:16px; -webkit-tap-highlight-color:transparent; }
body {
  font-family:'Vazirmatn',system-ui,sans-serif;
  background:#040c18;
  color:var(--txt);
  direction:rtl;
  min-height:100dvh;
  overflow:hidden;
}
button { cursor:pointer; border:none; background:none; font-family:inherit; color:inherit; }
a { color:inherit; text-decoration:none; }
input,textarea { font-family:inherit; }

/* ===== Desktop Centering ===== */
body::before {
  content:'';
  position:fixed; inset:0;
  background:radial-gradient(ellipse 80% 60% at 50% 0%, rgba(37,99,235,.08) 0%, transparent 70%);
  pointer-events:none; z-index:0;
}

/* ===== App Shell ===== */
.app-shell {
  position:fixed;
  inset:0;
  max-width:480px;
  margin:0 auto;
  background:var(--bg);
  display:flex;
  flex-direction:column;
  overflow:hidden;
  z-index:1;
}
@media (min-width:520px) {
  .app-shell {
    top:16px; bottom:16px;
    border-radius:36px;
    box-shadow:0 32px 80px rgba(0,0,0,.7), 0 0 0 1px var(--bdr2);
    overflow:hidden;
  }
}

/* ===== App Bar ===== */
.app-bar {
  height:var(--app-bar);
  flex-shrink:0;
  display:flex; align-items:center; justify-content:space-between;
  padding:0 14px 0 10px;
  background:var(--surf);
  border-bottom:1px solid var(--bdr);
  position:relative; z-index:10;
}
.app-bar-start { display:flex; align-items:center; gap:8px; }
.app-bar-icon {
  width:34px; height:34px; border-radius:10px;
  background:var(--pri-dim); border:1px solid rgba(59,130,246,.2);
  display:flex; align-items:center; justify-content:center;
  color:var(--pri);
}
.app-bar-title { font-weight:700; font-size:.95rem; color:var(--txt); }
.app-bar-end { display:flex; align-items:center; gap:6px; }
.offline-tag {
  display:none; padding:3px 8px; border-radius:20px;
  background:rgba(239,68,68,.15); border:1px solid rgba(239,68,68,.3);
  font-size:.7rem; color:var(--red);
}
.offline-tag.show { display:block; }
.app-bar-btn {
  width:36px; height:36px; border-radius:10px;
  display:flex; align-items:center; justify-content:center;
  background:var(--surf2); border:1px solid var(--bdr);
  color:var(--txt2); transition:var(--tr);
}
.app-bar-btn:hover { color:var(--txt); background:var(--surf3); }

/* ===== Tab Views ===== */
.tab-view {
  display:none;
  flex:1;
  flex-direction:column;
  overflow:hidden;
  min-height:0;
}
.tab-view.active { display:flex; }

.scroll-area {
  flex:1;
  overflow-y:auto;
  overflow-x:hidden;
  -webkit-overflow-scrolling:touch;
  overscroll-behavior:contain;
  padding-bottom:8px;
}
.scroll-area::-webkit-scrollbar { display:none; }

/* ===== Search Bar ===== */
.search-bar-wrap {
  padding:10px 14px 8px;
  background:var(--bg);
  border-bottom:1px solid var(--bdr);
  flex-shrink:0;
}
.search-bar {
  display:flex; align-items:center; gap:8px;
  background:var(--surf);
  border:1px solid var(--bdr2);
  border-radius:14px;
  padding:0 12px;
  height:44px;
  transition:var(--tr);
}
.search-bar:focus-within {
  border-color:var(--pri);
  box-shadow:0 0 0 3px var(--pri-dim);
}
.search-icon { color:var(--txt3); flex-shrink:0; }
.search-input {
  flex:1; border:none; background:transparent;
  color:var(--txt); font-size:.95rem; outline:none;
  direction:rtl;
}
.search-input::placeholder { color:var(--txt3); }
.search-x {
  color:var(--txt3); flex-shrink:0;
  opacity:0; pointer-events:none; transition:var(--tr);
  display:flex; align-items:center; justify-content:center;
  width:24px; height:24px;
}
.search-x.show { opacity:1; pointer-events:all; }
.search-x:hover { color:var(--red); }

/* ===== Contact List ===== */
.contact-list { padding:6px 0; }

.contact-item {
  display:flex; align-items:center; gap:12px;
  padding:11px 14px;
  cursor:pointer;
  transition:background var(--tr);
  position:relative;
  border-bottom:1px solid var(--bdr);
}
.contact-item:last-child { border-bottom:none; }
.contact-item:active { background:var(--surf2); }
@media (hover:hover) {
  .contact-item:hover { background:var(--surf); }
}

/* Avatar */
.c-avatar {
  width:46px; height:46px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  font-weight:700; color:#fff;
  flex-shrink:0;
  font-size:.75rem;
  line-height:1;
  text-align:center;
  overflow:hidden;
  word-break:break-all;
  padding:2px;
}

.c-info { flex:1; min-width:0; }
.c-name { font-weight:600; font-size:.93rem; color:var(--txt); margin-bottom:3px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.c-sub { font-size:.78rem; color:var(--txt2); display:flex; align-items:center; gap:6px; flex-wrap:wrap; }
.c-dot { width:3px; height:3px; border-radius:50%; background:var(--txt3); flex-shrink:0; }
.c-num { direction:ltr; font-size:.75rem; color:var(--txt3); }

.c-chevron {
  color:var(--txt3); flex-shrink:0;
  transition:transform var(--tr);
}
.contact-item:hover .c-chevron { transform:translateX(-3px); color:var(--pri); }

/* ===== Empty State ===== */
.empty-state {
  display:flex; flex-direction:column; align-items:center;
  padding:3rem 2rem; gap:.6rem;
}
.empty-icon { font-size:3rem; opacity:.5; }
.empty-title { font-size:1rem; font-weight:600; color:var(--txt2); }
.empty-sub { font-size:.82rem; color:var(--txt3); text-align:center; line-height:1.6; }

/* ===== Dial Pad ===== */
.dial-area { display:flex; flex-direction:column; align-items:center; padding:16px 16px 0; }

.dial-area { align-items:center; }
.dial-display {
  width:100%; max-width:330px;
  background:linear-gradient(180deg,var(--surf2),var(--surf));
  border:1px solid var(--bdr2);
  border-radius:20px;
  padding:20px 18px 16px;
  margin-bottom:24px;
  text-align:center;
  position:relative; min-height:78px;
  display:flex; flex-direction:column; justify-content:center;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.03);
}
.dial-number {
  font-size:2.2rem; font-weight:600; letter-spacing:3px;
  color:var(--txt); direction:ltr; unicode-bidi:plaintext; min-height:42px;
  display:flex; align-items:center; justify-content:center;
  overflow-x:auto; white-space:nowrap;
}
.dial-hint { font-size:.82rem; color:var(--txt3); margin-top:2px; }
.dial-backspace {
  position:absolute; left:14px; top:50%; transform:translateY(-50%);
  color:var(--txt3); padding:8px;
  border-radius:10px; transition:var(--tr);
  opacity:0; pointer-events:none;
}
.dial-backspace.show { opacity:1; pointer-events:all; }
.dial-backspace:hover { color:var(--red); background:var(--red-dim); }

/* LTR so the keypad reads 1-2-3 left-to-right even on an RTL page */
.dialpad {
  display:grid; grid-template-columns:repeat(3,1fr); direction:ltr;
  gap:14px; width:100%; max-width:300px;
  margin-bottom:22px;
}
.dial-key {
  aspect-ratio:1;
  border-radius:50%;
  background:var(--surf);
  border:1px solid var(--bdr2);
  display:flex; flex-direction:column;
  align-items:center; justify-content:center;
  cursor:pointer;
  user-select:none; transition:var(--tr);
  -webkit-tap-highlight-color:transparent;
}
.dial-key:active { transform:scale(.9); background:var(--pri); border-color:var(--pri); }
.dial-key:active .dk-n, .dial-key:active .dk-s { color:#fff; }
@media (hover:hover) { .dial-key:hover { background:var(--surf2); border-color:var(--pri); box-shadow:0 2px 10px rgba(59,130,246,.15); } }
.dk-n { font-size:1.55rem; font-weight:600; color:var(--txt); line-height:1.1; }
.dk-s { font-size:.56rem; color:var(--txt3); letter-spacing:1px; margin-top:2px; font-weight:600; }

.dial-actions { margin-bottom:16px; }
.dial-call-btn {
  width:66px; height:66px; border-radius:50%;
  background:linear-gradient(135deg,#22c55e,#16a34a);
  color:#fff;
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 6px 22px rgba(34,197,94,.4);
  transition:var(--tr); cursor:pointer;
}
.dial-call-btn:hover { transform:scale(1.05); box-shadow:0 8px 26px rgba(34,197,94,.5); }
.dial-call-btn:active { transform:scale(.93); }

.dial-results { width:100%; }

/* ===== Trending Section ===== */
.section-block {
  padding:16px 14px 4px;
}
.section-head {
  display:flex; align-items:center; gap:6px;
  font-size:.82rem; font-weight:700;
  color:var(--pri); text-transform:uppercase;
  letter-spacing:.5px; margin-bottom:12px;
}

.tag-cloud { display:flex; flex-wrap:wrap; gap:7px; padding-bottom:12px; }
.search-tag {
  padding:5px 13px; border-radius:20px;
  background:var(--surf); border:1px solid var(--bdr2);
  font-size:.8rem; color:var(--txt2);
  cursor:pointer; transition:var(--tr);
}
.search-tag:active { background:var(--pri-dim); color:var(--pri); border-color:var(--pri); }
@media (hover:hover) { .search-tag:hover { background:var(--pri-dim); color:var(--pri); border-color:var(--pri); } }

/* ===== Shimmer loading ===== */
.shimmer-row {
  height:56px; border-radius:12px;
  background:linear-gradient(90deg, var(--surf) 25%, var(--surf2) 50%, var(--surf) 75%);
  background-size:200% 100%;
  animation:shimmer 1.4s infinite;
  margin-bottom:8px;
}
@keyframes shimmer { 0%{background-position:200% 0} 100%{background-position:-200% 0} }

/* ===== Bottom Nav ===== */
.bottom-nav {
  display:flex;
  height:var(--nav-h);
  padding-bottom:env(safe-area-inset-bottom,0px);
  background:var(--surf);
  border-top:1px solid var(--bdr);
  flex-shrink:0;
}
.nav-tab {
  flex:1; display:flex; flex-direction:column;
  align-items:center; justify-content:center;
  gap:3px; padding:4px 2px;
  color:var(--txt3); font-size:.68rem;
  transition:color var(--tr);
  position:relative;
}
.nav-tab.active { color:var(--pri); }
.nav-tab.active::after {
  content:'';
  position:absolute; top:0; left:20%; right:20%; height:2px;
  background:var(--pri); border-radius:0 0 3px 3px;
}
.nav-tab:active { opacity:.7; }
.nav-tab svg { transition:transform var(--tr); }
.nav-tab.active svg { transform:scale(1.1); }

/* ===== Sheet Backdrop ===== */
.sheet-backdrop {
  position:fixed; inset:0;
  background:rgba(0,0,0,.6);
  backdrop-filter:blur(4px);
  z-index:200;
  opacity:0; pointer-events:none;
  transition:opacity .3s;
}
.sheet-backdrop.open { opacity:1; pointer-events:all; }

/* ===== Bottom Sheet ===== */
.bottom-sheet {
  position:fixed; bottom:0; left:0; right:0;
  max-width:480px; margin:0 auto;
  background:var(--surf);
  border-radius:24px 24px 0 0;
  border-top:1px solid var(--bdr2);
  z-index:201;
  max-height:90dvh;
  display:flex; flex-direction:column;
  transform:translateY(100%);
  transition:transform .35s cubic-bezier(.32,.72,0,1);
  pointer-events:none;
}
.bottom-sheet.open { transform:translateY(0); pointer-events:auto; }
.sheet-handle {
  width:40px; height:4px; border-radius:2px;
  background:var(--bdr2); margin:12px auto 0;
  flex-shrink:0;
}
.sheet-body {
  overflow-y:auto; padding:16px 16px 32px;
  -webkit-overflow-scrolling:touch;
  flex:1;
}
.sheet-body::-webkit-scrollbar { display:none; }

/* Sheet Content */
.sheet-header {
  display:flex; align-items:center; gap:14px;
  margin-bottom:20px;
}
.sheet-avatar {
  width:64px; height:64px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  font-weight:700; font-size:.85rem; color:#fff;
  flex-shrink:0; word-break:break-all;
  text-align:center; padding:4px;
}
.sheet-name { font-size:1.2rem; font-weight:700; color:var(--txt); margin-bottom:6px; }
.badge-row { display:flex; flex-wrap:wrap; gap:5px; }
.badge {
  padding:3px 10px; border-radius:20px;
  font-size:.72rem; font-weight:500;
  background:var(--pri-dim); border:1px solid rgba(59,130,246,.25);
  color:var(--acc);
}

.info-block {
  background:var(--bg);
  border:1px solid var(--bdr);
  border-radius:var(--radius-s);
  overflow:hidden;
  margin-bottom:14px;
}
.info-row {
  display:flex; align-items:center;
  padding:11px 14px; gap:10px;
  border-bottom:1px solid var(--bdr);
}
.info-row:last-child { border-bottom:none; }
.info-lbl { font-size:.75rem; color:var(--txt3); min-width:88px; flex-shrink:0; }
.info-val { font-size:.88rem; color:var(--txt); flex:1; }
.call-link {
  display:flex; align-items:center; gap:4px;
  padding:5px 11px; border-radius:8px;
  background:var(--grn-dim); border:1px solid rgba(34,197,94,.25);
  color:var(--grn); font-size:.75rem; white-space:nowrap;
  transition:var(--tr);
}
.call-link:active { background:rgba(34,197,94,.25); }

.action-row {
  display:flex; gap:8px; margin-bottom:16px; flex-wrap:wrap;
}
.act-btn {
  flex:1; min-width:90px;
  padding:11px 12px;
  border-radius:var(--radius-s);
  background:var(--surf2); border:1px solid var(--bdr);
  color:var(--txt2); font-size:.82rem;
  display:flex; align-items:center; justify-content:center; gap:6px;
  transition:var(--tr);
}
.act-btn:active { background:var(--surf3); }
@media (hover:hover) { .act-btn:hover { background:var(--surf3); color:var(--txt); } }
.act-btn.liked { background:var(--red-dim); border-color:rgba(239,68,68,.3); color:var(--red); }
.act-btn.calling { background:var(--grn-dim); border-color:rgba(34,197,94,.3); color:var(--grn); }

/* Comments */
.comments-title {
  font-size:.82rem; font-weight:600; color:var(--txt2);
  margin-bottom:10px; display:flex; align-items:center; gap:6px;
}
.comment-card {
  background:var(--bg); border:1px solid var(--bdr);
  border-radius:var(--radius-s); padding:10px 12px;
  margin-bottom:8px;
}
.comment-text { font-size:.85rem; color:var(--txt2); line-height:1.6; }
.comment-date { font-size:.7rem; color:var(--txt3); margin-top:5px; }

.comment-form { margin-top:14px; }
.comment-ta {
  width:100%; padding:11px 13px;
  background:var(--bg); border:1px solid var(--bdr2);
  border-radius:var(--radius-s);
  color:var(--txt); font-family:inherit; font-size:.85rem;
  resize:none; min-height:82px; direction:rtl; outline:none;
  transition:var(--tr);
}
.comment-ta:focus { border-color:var(--pri); }
.comment-ta::placeholder { color:var(--txt3); }
.comment-send {
  margin-top:8px; padding:9px 20px;
  background:var(--pri); border-radius:var(--radius-s);
  color:#fff; font-family:inherit; font-size:.85rem; font-weight:600;
  transition:var(--tr);
}
.comment-send:active { opacity:.8; }
.comment-send:disabled { opacity:.45; pointer-events:none; }

/* ===== Toast ===== */
.toast {
  position:fixed; bottom:calc(var(--nav-h) + 12px); left:50%;
  transform:translateX(-50%) translateY(8px);
  background:var(--surf2); border:1px solid var(--bdr2);
  border-radius:12px; padding:9px 18px;
  font-size:.83rem; color:var(--txt);
  box-shadow:var(--shadow); z-index:300;
  opacity:0; transition:all .25s; pointer-events:none;
  white-space:nowrap; max-width:280px; text-align:center;
}
.toast.show { opacity:1; transform:translateX(-50%) translateY(0); }
.toast.ok { border-color:rgba(34,197,94,.4); color:var(--grn); }
.toast.err { border-color:rgba(239,68,68,.4); color:var(--red); }

/* ===== Install Banner ===== */
.install-banner {
  position:fixed; bottom:calc(var(--nav-h) + 12px);
  left:12px; right:12px; max-width:calc(480px - 24px); margin:0 auto;
  background:var(--surf2); border:1px solid var(--bdr2);
  border-radius:var(--radius); padding:14px;
  z-index:300; box-shadow:var(--shadow);
  transform:translateY(calc(100% + 80px));
  transition:transform .4s cubic-bezier(.32,.72,0,1);
}
.install-banner.show { transform:translateY(0); }
.install-info { display:flex; align-items:center; gap:12px; margin-bottom:12px; }
.install-info img { border-radius:12px; }
.install-title { font-weight:600; font-size:.9rem; }
.install-sub { font-size:.75rem; color:var(--txt2); margin-top:2px; }
.install-btns { display:flex; gap:8px; justify-content:flex-end; }
.install-dismiss { padding:7px 16px; border-radius:10px; background:var(--surf3); color:var(--txt2); font-size:.82rem; font-family:inherit; }
.install-do { padding:7px 18px; border-radius:10px; background:var(--pri); color:#fff; font-size:.82rem; font-weight:600; font-family:inherit; }

/* ===== Suggest Edit ===== */
.suggest-btn {
  width:28px; height:28px; border-radius:7px;
  background:transparent; border:1px solid transparent;
  color:var(--txt3); font-size:.78rem;
  display:flex; align-items:center; justify-content:center;
  flex-shrink:0; transition:var(--tr); margin-right:auto; padding:0;
}
.suggest-btn:active,
.suggest-btn:hover { background:var(--pri-dim); border-color:rgba(59,130,246,.3); color:var(--pri); }

.suggest-add-btn {
  padding:3px 10px; border-radius:20px;
  background:transparent; border:1px dashed var(--bdr2);
  color:var(--txt3); font-size:.72rem; font-family:inherit;
  transition:var(--tr); white-space:nowrap;
}
.suggest-add-btn:active,
.suggest-add-btn:hover { background:var(--pri-dim); border-color:var(--pri); color:var(--pri); }

.suggest-drawer {
  flex-shrink:0; overflow:hidden;
  max-height:0; transition:max-height .3s cubic-bezier(.32,.72,0,1);
  background:var(--surf2);
  border-top:1px solid var(--bdr);
}
.suggest-drawer.open { max-height:240px; }
.suggest-drawer-inner { padding:14px 16px 20px; }
.suggest-drawer-head {
  display:flex; align-items:center; justify-content:space-between;
  margin-bottom:10px;
}
.suggest-drawer-title { font-size:.88rem; font-weight:600; color:var(--txt); }
.suggest-drawer-close {
  width:28px; height:28px; border-radius:50%;
  background:var(--surf3); color:var(--txt2);
  display:flex; align-items:center; justify-content:center; font-size:.8rem;
  transition:var(--tr);
}
.suggest-drawer-close:hover { color:var(--red); background:var(--red-dim); }
.suggest-current {
  font-size:.75rem; color:var(--txt3); margin-bottom:8px;
  display:flex; align-items:center; gap:5px;
}
.suggest-current-val { color:var(--txt2); direction:ltr; }
.suggest-input {
  width:100%; padding:10px 12px;
  background:var(--bg); border:1px solid var(--bdr2);
  border-radius:var(--radius-s); color:var(--txt);
  font-family:inherit; font-size:.9rem; outline:none;
  transition:var(--tr); direction:ltr; margin-bottom:8px;
}
.suggest-input:focus { border-color:var(--pri); box-shadow:0 0 0 3px var(--pri-dim); }
.suggest-note { font-size:.72rem; color:var(--txt3); margin-bottom:12px; display:flex; align-items:center; gap:4px; }
.suggest-actions { display:flex; gap:8px; }
.suggest-cancel-btn {
  padding:9px 14px; border-radius:var(--radius-s);
  background:var(--surf3); color:var(--txt2);
  font-family:inherit; font-size:.82rem; transition:var(--tr);
}
.suggest-submit-btn {
  flex:1; padding:9px 14px; border-radius:var(--radius-s);
  background:var(--pri); color:#fff;
  font-family:inherit; font-size:.85rem; font-weight:700;
  transition:var(--tr);
}
.suggest-submit-btn:disabled { opacity:.45; pointer-events:none; }

/* ===== PWA Install Sheet ===== */
.install-sheet-body {
  padding:20px 20px 32px;
}
.install-app-row {
  display:flex; align-items:center; gap:14px;
  margin-bottom:18px;
}
.install-app-icon { border-radius:16px; flex-shrink:0; }
.install-app-name { font-size:1.05rem; font-weight:700; color:var(--txt); }
.install-app-domain { font-size:.78rem; color:var(--txt3); margin-top:3px; }
.install-desc {
  font-size:.88rem; color:var(--txt2); line-height:1.7;
  margin-bottom:16px;
}
.install-features {
  display:flex; flex-direction:column; gap:8px;
  background:var(--bg); border:1px solid var(--bdr);
  border-radius:var(--radius-s); padding:14px;
  margin-bottom:20px;
}
.install-feat {
  display:flex; align-items:center; gap:10px;
  font-size:.85rem; color:var(--txt2);
}
.feat-icon { font-size:1rem; flex-shrink:0; }
.install-actions {
  display:flex; gap:10px;
}
.install-dismiss-btn {
  flex:1; padding:12px;
  background:var(--surf2); border:1px solid var(--bdr);
  border-radius:var(--radius-s); color:var(--txt3);
  font-family:inherit; font-size:.85rem;
  transition:var(--tr);
}
.install-dismiss-btn:active { background:var(--surf3); }
.install-do-btn {
  flex:2; padding:12px 16px;
  background:var(--pri); border-radius:var(--radius-s);
  color:#fff; font-family:inherit; font-size:.9rem; font-weight:700;
  display:flex; align-items:center; justify-content:center; gap:7px;
  transition:var(--tr); box-shadow:0 4px 16px var(--pri-glow);
}
.install-do-btn:active { opacity:.85; }

/* ===== About Sheet ===== */
.about-sheet-body {
  padding:20px 20px 32px;
  display:flex; flex-direction:column;
}
.about-header {
  display:flex; flex-direction:column; align-items:center; gap:12px;
  margin-bottom:20px; text-align:center;
}
.about-icon { border-radius:18px; }
.about-title { font-size:1.1rem; font-weight:700; color:var(--txt); }
.about-content {
  flex:1;
  font-size:.9rem; color:var(--txt2); line-height:1.8;
  white-space:pre-wrap;
  background:var(--bg); border:1px solid var(--bdr);
  border-radius:var(--radius-s); padding:14px;
  margin-bottom:20px; min-height:80px;
}
.about-footer {
  display:flex; align-items:center; justify-content:flex-start;
  direction:ltr; text-align:left;
  gap:5px; font-size:.75rem; color:var(--txt3);
  padding-top:16px; border-top:1px solid var(--bdr);
}
.about-dev-link {
  color:var(--pri); font-weight:600;
  transition:color var(--tr);
}
.about-dev-link:hover { color:var(--acc); }

/* ===== Admin (shared) ===== */
.admin-wrap { max-width:1100px; margin:0 auto; padding:1.5rem 1rem; }
.admin-title { font-size:1.3rem; font-weight:700; color:var(--acc); margin-bottom:1.5rem; }
.form-group { margin-bottom:1rem; }
.form-label { display:block; font-size:.83rem; color:var(--txt2); margin-bottom:4px; }
.form-input,.form-select,.form-textarea {
  width:100%; padding:10px 13px;
  background:var(--surf); border:1px solid var(--bdr2);
  border-radius:var(--radius-s); color:var(--txt);
  font-family:inherit; font-size:.9rem; outline:none;
  transition:var(--tr); direction:rtl;
}
.form-input:focus,.form-select:focus,.form-textarea:focus {
  border-color:var(--pri); box-shadow:0 0 0 3px var(--pri-dim);
}
.form-textarea { resize:vertical; min-height:80px; }
.btn-primary {
  padding:10px 22px; background:var(--pri); border-radius:var(--radius-s);
  color:#fff; font-family:inherit; font-size:.9rem; font-weight:600;
  transition:var(--tr); border:none;
}
.btn-primary:hover { opacity:.9; }
.btn-danger {
  padding:5px 12px; background:var(--red-dim);
  border:1px solid rgba(239,68,68,.3); border-radius:8px;
  color:var(--red); font-family:inherit; font-size:.8rem; transition:var(--tr);
}
.btn-danger:hover { background:rgba(239,68,68,.22); }
.btn-success {
  padding:5px 12px; background:var(--grn-dim);
  border:1px solid rgba(34,197,94,.3); border-radius:8px;
  color:var(--grn); font-family:inherit; font-size:.8rem; transition:var(--tr);
}
.btn-success:hover { background:rgba(34,197,94,.22); }
.btn-sm {
  padding:5px 13px; border-radius:8px;
  background:var(--surf2); border:1px solid var(--bdr);
  color:var(--txt2); font-family:inherit; font-size:.8rem;
  transition:var(--tr);
}
.btn-sm:hover { background:var(--surf3); color:var(--txt); }
.table-wrap { overflow-x:auto; border-radius:var(--radius); border:1px solid var(--bdr); }
table { width:100%; border-collapse:collapse; }
thead tr { background:rgba(0,0,0,.25); }
th,td { padding:10px 13px; text-align:right; font-size:.84rem; border-bottom:1px solid var(--bdr); }
th { color:var(--txt2); font-weight:600; }
td { color:var(--txt); }
tbody tr:hover { background:rgba(255,255,255,.02); }
tbody tr:last-child td { border-bottom:none; }
.alert { padding:11px 14px; border-radius:var(--radius-s); margin-bottom:1rem; font-size:.88rem; }
.alert-success { background:var(--grn-dim); border:1px solid rgba(34,197,94,.3); color:var(--grn); }
.alert-error   { background:var(--red-dim); border:1px solid rgba(239,68,68,.3); color:var(--red); }
.alert-info    { background:var(--pri-dim); border:1px solid rgba(59,130,246,.3); color:var(--acc); }
.admin-layout { display:flex; min-height:calc(100vh - 60px); }
.admin-sidebar { width:200px; flex-shrink:0; background:var(--surf); border-left:1px solid var(--bdr); padding:1.2rem .75rem; }
.sidebar-nav { display:flex; flex-direction:column; gap:3px; }
.nav-item { display:flex; align-items:center; gap:8px; padding:9px 11px; border-radius:var(--radius-s); color:var(--txt2); font-size:.86rem; transition:var(--tr); }
.nav-item:hover,.nav-item.active { background:var(--surf2); color:var(--txt); }
.nav-item.active { color:var(--acc); }
.admin-content { flex:1; padding:1.5rem; overflow-x:auto; }
.stats-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(180px,1fr)); gap:1rem; margin-bottom:1.5rem; }
.stat-card { background:var(--surf); border:1px solid var(--bdr); border-radius:var(--radius); padding:1.1rem; text-align:center; }
.stat-num { font-size:1.8rem; font-weight:700; color:var(--acc); }
.stat-label { font-size:.8rem; color:var(--txt2); margin-top:3px; }
.upload-area { border:2px dashed var(--bdr2); border-radius:var(--radius); padding:2rem; text-align:center; cursor:pointer; transition:var(--tr); background:rgba(0,0,0,.15); }
.upload-area:hover,.upload-area.dragover { border-color:var(--pri); background:var(--pri-dim); }
.upload-icon { font-size:2.5rem; margin-bottom:.5rem; opacity:.45; }
.upload-text { color:var(--txt2); font-size:.88rem; }
.header { background:var(--surf); border-bottom:1px solid var(--bdr); position:sticky; top:0; z-index:100; padding:0 1rem; }
.header-inner { max-width:1100px; margin:0 auto; display:flex; align-items:center; justify-content:space-between; height:56px; }
.logo { display:flex; align-items:center; gap:8px; font-weight:700; font-size:1rem; color:var(--acc); }
.admin-btn { padding:5px 14px; background:var(--surf2); border:1px solid var(--bdr); border-radius:8px; font-size:.82rem; color:var(--txt2); transition:var(--tr); }
.admin-btn:hover { color:var(--txt); background:var(--surf3); }
.pagination { display:flex; justify-content:center; gap:5px; margin-top:1rem; flex-wrap:wrap; }
.page-btn { padding:6px 13px; border-radius:8px; background:var(--surf); border:1px solid var(--bdr); color:var(--txt2); font-family:inherit; font-size:.82rem; transition:var(--tr); }
.page-btn.active,.page-btn:hover { background:var(--pri); border-color:var(--pri); color:#fff; }
